

***Rockchip***  
***RK3506***  
***Technical Reference Manual***  
***(Part 1)***

**Revision 1.1**  
**Nov. 2024**

Rockchip Confidential

## **Revision History**

| <b>Date</b> | <b>Revision</b> | <b>Description</b>                                                            |
|-------------|-----------------|-------------------------------------------------------------------------------|
| 2024-11-22  | 1.1             | Update the CRU, PMU, GRF, Mailbox, Audio Subsystem, ASRC, and SDMMC Chapters. |
| 2024-09-02  | 1.0             | Initial release                                                               |

Rockchip Confidential

## Table of Content

|                                                  |     |
|--------------------------------------------------|-----|
| Table of Content .....                           | 3   |
| Figure Index .....                               | 9   |
| Table Index.....                                 | 13  |
| Warranty Disclaimer.....                         | 16  |
| Chapter 1 System Overview .....                  | 17  |
| 1.1 Address Mapping.....                         | 17  |
| 1.2 System Boot.....                             | 18  |
| 1.3 System Interrupt Connection .....            | 20  |
| 1.4 System DMA Hardware Request Connection ..... | 26  |
| 1.5 Rockchip Matrix IO Function List.....        | 27  |
| Chapter 2 Clock & Reset Unit (CRU) .....         | 30  |
| 2.1 Overview .....                               | 30  |
| 2.2 Block Diagram .....                          | 30  |
| 2.3 Function Description .....                   | 30  |
| 2.4 CRU Register Description.....                | 32  |
| 2.5 SCRU Register Description .....              | 96  |
| 2.6 CRU_PMU Register Description .....           | 102 |
| 2.7 SCRU PMU Register Description .....          | 126 |
| 2.8 Application Notes .....                      | 126 |
| Chapter 3 Cortex-A7 .....                        | 130 |
| 3.1 Overview .....                               | 130 |
| 3.2 Block Diagram .....                          | 130 |
| 3.3 Function Description .....                   | 130 |
| 3.4 Register Description.....                    | 130 |
| Chapter 4 Cortex-M0 .....                        | 131 |
| 4.1 Overview .....                               | 131 |
| 4.2 Block Diagram .....                          | 131 |
| 4.3 Function Description .....                   | 131 |
| 4.4 Register Description.....                    | 132 |
| 4.5 Interface Description .....                  | 133 |
| 4.6 Application Notes .....                      | 134 |
| Chapter 5 General Register Files (GRF).....      | 139 |
| 5.1 Overview .....                               | 139 |
| 5.2 Function Description .....                   | 139 |
| 5.3 GRF Register Description.....                | 139 |
| 5.4 GRF_CORE Register Description.....           | 179 |
| 5.5 GRF_PMU Register Description .....           | 187 |
| Chapter 6 Power Management Unit (PMU).....       | 230 |
| 6.1 Overview .....                               | 230 |
| 6.2 Block Diagram .....                          | 230 |
| 6.3 Function Description .....                   | 230 |
| 6.4 Register Description.....                    | 233 |
| 6.5 Application Notes .....                      | 267 |
| Chapter 7 Internal SRAM .....                    | 269 |
| 7.1 Overview .....                               | 269 |
| 7.2 Block Diagram .....                          | 269 |
| 7.3 Function Description .....                   | 269 |
| Chapter 8 DMA Controller (DMAC) .....            | 271 |
| 8.1 Overview .....                               | 271 |

|                                                 |     |
|-------------------------------------------------|-----|
| 8.2 Block Diagram .....                         | 272 |
| 8.3 Function Description .....                  | 272 |
| 8.4 Register Description.....                   | 273 |
| 8.5 Timing Diagram .....                        | 329 |
| 8.6 Interface Description .....                 | 329 |
| 8.7 Application Notes .....                     | 330 |
| Chapter 9 DMA2DDR .....                         | 337 |
| 9.1 Overview .....                              | 337 |
| 9.2 Architecture .....                          | 337 |
| 9.3 Register description .....                  | 338 |
| 9.4 Application Notes .....                     | 355 |
| Chapter 10 TIMER .....                          | 356 |
| 10.1 Overview.....                              | 356 |
| 10.2 Block Diagram .....                        | 356 |
| 10.3 Function Description .....                 | 356 |
| 10.4 Register Description.....                  | 357 |
| 10.5 Application Notes.....                     | 359 |
| Chapter 11 HPTIMER .....                        | 361 |
| 11.1 Overview.....                              | 361 |
| 11.2 Block Diagram .....                        | 361 |
| 11.3 Function Description .....                 | 361 |
| 11.4 Register Description.....                  | 362 |
| 11.5 Application Notes.....                     | 369 |
| Chapter 12 Watchdog Timer (WDT) .....           | 373 |
| 12.1 Overview.....                              | 373 |
| 12.2 Block Diagram .....                        | 373 |
| 12.3 Function Description .....                 | 373 |
| 12.4 Register Description.....                  | 374 |
| Chapter 13 Mailbox .....                        | 377 |
| 13.1 Overview.....                              | 377 |
| 13.2 Block Diagram .....                        | 377 |
| 13.3 Function Description .....                 | 377 |
| 13.4 Register Description.....                  | 378 |
| 13.5 Application Notes.....                     | 381 |
| Chapter 14 SARADC .....                         | 382 |
| 14.1 Overview.....                              | 382 |
| 14.2 Block Diagram .....                        | 382 |
| 14.3 Function Description .....                 | 382 |
| 14.4 Register Description.....                  | 382 |
| 14.5 Application Notes.....                     | 390 |
| Chapter 15 Temperature-Sensor ADC (TSADC) ..... | 391 |
| 15.1 Overview.....                              | 391 |
| 15.2 Block Diagram .....                        | 391 |
| 15.3 Function Description .....                 | 391 |
| 15.4 Register Description.....                  | 391 |
| 15.5 Interface Description.....                 | 398 |
| 15.6 Application Notes.....                     | 398 |
| Chapter 16 SPINLOCK .....                       | 400 |
| 16.1 Overview.....                              | 400 |
| 16.2 Block Diagram .....                        | 400 |
| 16.3 Function Description .....                 | 400 |

---

|                                                 |     |
|-------------------------------------------------|-----|
| 16.4 Register Description.....                  | 400 |
| 16.5 Application Notes.....                     | 402 |
| Chapter 17 GPIO .....                           | 404 |
| 17.1 Overview.....                              | 404 |
| 17.2 Block Diagram .....                        | 404 |
| 17.3 Function Description .....                 | 404 |
| 17.4 Register Description.....                  | 407 |
| 17.5 Interface Description.....                 | 418 |
| 17.6 Application Notes.....                     | 422 |
| Chapter 18 IO Controller (IOC).....             | 423 |
| 18.1 Overview.....                              | 423 |
| 18.2 Function Description .....                 | 423 |
| 18.3 GPIO0_IOC Register Description .....       | 423 |
| 18.4 GPIO1_IOC Register Description .....       | 450 |
| 18.5 GPIO2_IOC Register Description .....       | 482 |
| 18.6 GPIO3_IOC Register Description .....       | 501 |
| 18.7 GPIO4_IOC Register Description .....       | 517 |
| 18.8 Application Notes.....                     | 518 |
| Chapter 19 Rockchip Matrix IO .....             | 520 |
| 19.1 Overview.....                              | 520 |
| 19.2 Block Diagram .....                        | 520 |
| 19.3 Function Description .....                 | 520 |
| 19.4 Register Description.....                  | 521 |
| 19.5 Interface Description.....                 | 587 |
| 19.6 Application Notes.....                     | 588 |
| Chapter 20 Audio Subsystem .....                | 589 |
| 20.1 Overview.....                              | 589 |
| 20.2 Block Diagram .....                        | 589 |
| 20.3 Function Description .....                 | 589 |
| Chapter 21 Audio DSM .....                      | 592 |
| 21.1 Overview.....                              | 592 |
| 21.2 Block Diagram .....                        | 592 |
| 21.3 Function description.....                  | 593 |
| 21.4 Register Description.....                  | 593 |
| 21.5 Interface Description.....                 | 605 |
| 21.6 Application Notes.....                     | 605 |
| Chapter 22 Audio ADC.....                       | 607 |
| 22.1 Overview.....                              | 607 |
| 22.2 Block Diagram .....                        | 607 |
| 22.3 Function Description .....                 | 608 |
| 22.4 Register Description.....                  | 611 |
| 22.5 Application Notes.....                     | 627 |
| Chapter 23 Serial Audio Interface (SAI).....    | 628 |
| 23.1 Overview.....                              | 628 |
| 23.2 Block Diagram .....                        | 628 |
| 23.3 Function Description .....                 | 629 |
| 23.4 Register Description.....                  | 631 |
| 23.5 Interface Description.....                 | 643 |
| 23.6 Application Notes.....                     | 646 |
| Chapter 24 Pulse Density Modulation (PDM) ..... | 647 |
| 24.1 Overview.....                              | 647 |

|                                                              |     |
|--------------------------------------------------------------|-----|
| 24.2 Block Diagram .....                                     | 647 |
| 24.3 Function Description .....                              | 648 |
| 24.4 Register Description.....                               | 649 |
| 24.5 Interface Description.....                              | 657 |
| 24.6 Application Notes.....                                  | 658 |
| Chapter 25 SPDIF TX.....                                     | 659 |
| 25.1 Overview.....                                           | 659 |
| 25.2 Block Diagram .....                                     | 659 |
| 25.3 Function Description .....                              | 660 |
| 25.4 Register Description.....                               | 661 |
| 25.5 Interface Description.....                              | 667 |
| 25.6 Application Notes.....                                  | 668 |
| Chapter 26 SPDIF RX .....                                    | 669 |
| 26.1 Overview.....                                           | 669 |
| 26.2 Block Diagram .....                                     | 669 |
| 26.3 Function description .....                              | 670 |
| 26.4 Register Description.....                               | 672 |
| 26.5 Interface Description.....                              | 680 |
| 26.6 Application Notes.....                                  | 681 |
| Chapter 27 Asynchronous Sample Rate Converter (ASRC).....    | 682 |
| 27.1 Overview.....                                           | 682 |
| 27.2 Block Diagram .....                                     | 682 |
| 27.3 Function Description .....                              | 683 |
| 27.4 Register Description.....                               | 686 |
| 27.5 Application Notes.....                                  | 697 |
| Chapter 28 Flexible Serial Peripheral Interface (FSPI) ..... | 700 |
| 28.1 Overview.....                                           | 700 |
| 28.2 Block Diagram .....                                     | 700 |
| 28.3 Function Description .....                              | 701 |
| 28.4 Register Description.....                               | 701 |
| 28.5 Interface Description.....                              | 724 |
| 28.6 Application Notes.....                                  | 725 |
| Chapter 29 Serial Peripheral Interface (SPI) .....           | 729 |
| 29.1 Overview.....                                           | 729 |
| 29.2 Block Diagram .....                                     | 729 |
| 29.3 Function Description .....                              | 731 |
| 29.4 Register Description.....                               | 732 |
| 29.5 Interface Description.....                              | 741 |
| 29.6 Application Notes.....                                  | 742 |
| Chapter 30 SPI2APB.....                                      | 745 |
| 30.1 Overview.....                                           | 745 |
| 30.2 Block Diagram .....                                     | 745 |
| 30.3 Function Description .....                              | 745 |
| 30.4 Register Description.....                               | 748 |
| 30.5 Interface Description.....                              | 750 |
| 30.6 Application Notes.....                                  | 750 |
| Chapter 31 Pulse Width Modulation (PWM).....                 | 751 |
| 31.1 Overview.....                                           | 751 |
| 31.2 Block Diagram .....                                     | 752 |
| 31.3 Function Description .....                              | 752 |
| 31.4 Register Description.....                               | 754 |
| 31.5 Interface Description.....                              | 782 |

---

|                                                                               |      |
|-------------------------------------------------------------------------------|------|
| 31.6 Application Notes.....                                                   | 782  |
| Chapter 32 Inter-Integrated Circuit (I2C).....                                | 786  |
| 32.1 Overview.....                                                            | 786  |
| 32.2 Block Diagram .....                                                      | 786  |
| 32.3 Function Description .....                                               | 787  |
| 32.4 Register Description.....                                                | 789  |
| 32.5 Interface Description.....                                               | 798  |
| 32.6 Application Notes.....                                                   | 799  |
| Chapter 33 Universal Asynchronous Receiver/Transmitter .....                  | 802  |
| 33.1 Overview.....                                                            | 802  |
| 33.2 Block Diagram .....                                                      | 802  |
| 33.3 Function Description .....                                               | 803  |
| 33.4 Register Description.....                                                | 805  |
| 33.5 Interface Description.....                                               | 825  |
| 33.6 Application Notes.....                                                   | 827  |
| Chapter 34 Controller Area Network (CAN) .....                                | 830  |
| 34.1 Overview.....                                                            | 830  |
| 34.2 Function Description .....                                               | 830  |
| 34.3 Register Description.....                                                | 837  |
| 34.4 Interface Description.....                                               | 864  |
| 34.5 Application Notes.....                                                   | 864  |
| Chapter 35 Master Double Data Rate Serial Memory Controller (MASTER DSMC)...  | 867  |
| 35.1 Overview.....                                                            | 867  |
| 35.2 Block Diagram .....                                                      | 867  |
| 35.3 Function Description .....                                               | 868  |
| 35.4 Register Description.....                                                | 871  |
| 35.5 Interface Description.....                                               | 885  |
| 35.6 Application Notes.....                                                   | 886  |
| Chapter 36 Slave Double Date Rate Serial Memory Controller (SLAVE DSMC) ..... | 889  |
| 36.1 Overview.....                                                            | 889  |
| 36.2 Block Diagram .....                                                      | 889  |
| 36.3 Function Description .....                                               | 890  |
| 36.4 Register Description.....                                                | 891  |
| 36.5 Common Register Description.....                                         | 900  |
| 36.6 Interface Description.....                                               | 905  |
| 36.7 Application Notes.....                                                   | 905  |
| Chapter 37 Flexible Bus (FlexBUS) .....                                       | 906  |
| 37.1 Overview.....                                                            | 906  |
| 37.2 Block Diagram .....                                                      | 907  |
| 37.3 Function Description .....                                               | 907  |
| 37.4 Register Description.....                                                | 912  |
| 37.5 Interface Description.....                                               | 928  |
| 37.6 Application Notes.....                                                   | 930  |
| Chapter 38 MAC Ethernet Interface (MAC) .....                                 | 933  |
| 38.1 Overview.....                                                            | 933  |
| 38.2 Block Diagram .....                                                      | 936  |
| 38.3 Function Description .....                                               | 937  |
| 38.4 Register Description.....                                                | 941  |
| 38.5 Interface Description.....                                               | 1051 |
| 38.6 Application Note.....                                                    | 1052 |
| Chapter 39 Mobile Storage Host Controller (SDMMC&EMMC) .....                  | 1078 |

|                                 |      |
|---------------------------------|------|
| 39.1 Overview.....              | 1078 |
| 39.2 Block Diagram .....        | 1078 |
| 39.3 Function Description ..... | 1080 |
| 39.4 Register Description.....  | 1099 |
| 39.5 Interface Description..... | 1120 |
| 39.6 Application Notes.....     | 1121 |

Rockchip Confidential

## Figure Index

|                                                                           |     |
|---------------------------------------------------------------------------|-----|
| Fig. 1-1 RK3506 Boot Procedure Flow .....                                 | 19  |
| Fig. 2-1 CRU Block Diagram .....                                          | 30  |
| Fig. 2-2 PLL Block Diagram .....                                          | 31  |
| Fig. 2-3 Reset Architecture Diagram .....                                 | 32  |
| Fig. 3-1 Core Subsystem Architecture.....                                 | 130 |
| Fig. 4-1 Cortex-M0 Integration Architecture.....                          | 131 |
| Fig. 6-1 PMU Bock Diagram.....                                            | 230 |
| Fig. 6-2 RK3506 Voltage Domain and Power Domain Partition .....           | 231 |
| Fig. 7-1 System SRAM Block Diagram.....                                   | 269 |
| Fig. 8-1 Block diagram of DMAC.....                                       | 272 |
| Fig. 8-2 DMAC operation states .....                                      | 273 |
| Fig. 8-3 DMAC request and acknowledge timing .....                        | 329 |
| Fig. 9-1 DMA2DDR architecture .....                                       | 337 |
| Fig. 10-1 TIMER Block Diagram .....                                       | 356 |
| Fig. 10-2 Timing between timer_en and timer_clk .....                     | 360 |
| Fig. 10-3 Timer Usage Flow.....                                           | 360 |
| Fig. 11-1 HPTIMER Block Diagram.....                                      | 361 |
| Fig. 11-2 Clock Selection of clk_timer .....                              | 370 |
| Fig. 12-1 WDT Block Diagram.....                                          | 373 |
| Fig. 12-2 WDT Operation Flow (RMOD=1) .....                               | 374 |
| Fig. 13-1 Mailbox Block Diagram .....                                     | 377 |
| Fig. 14-1 SARADC Block Diagram.....                                       | 382 |
| Fig. 15-1 TSADC Controller Block Diagram .....                            | 391 |
| Fig. 15-2 Timing Diagram for TSADC .....                                  | 399 |
| Fig. 16-1 Spinlock in System .....                                        | 400 |
| Fig. 17-1 GPIO Block Diagram .....                                        | 404 |
| Fig. 18-1 Connect directly from IOC to function IP .....                  | 519 |
| Fig. 18-2 Some IPs are connected to the IO PAD through RMIO and IOC ..... | 519 |
| Fig. 18-3 IP which has multiple paths connecting to the I/O PAD .....     | 519 |
| Fig. 19-1 RM_IO Block Diagram .....                                       | 520 |
| Fig. 20-1 Audio Subsystem Block Diagram .....                             | 589 |
| Fig. 20-2 SAI Series Mode Structure.....                                  | 590 |
| Fig. 20-3 ASRC MEM2MEM Series Mode Structure.....                         | 590 |
| Fig. 20-4 SPDIF SDO Selector .....                                        | 590 |
| Fig. 20-5 Audio DSM Input Clock Selector .....                            | 591 |
| Fig. 20-6 SAI Input Clock Selector .....                                  | 591 |
| Fig. 21-1 RK DSM Block Diagram .....                                      | 592 |
| Fig. 22-1 Audio ADC Block Diagram.....                                    | 607 |
| Fig. 22-2 I2S Normal Mode Timing Format .....                             | 608 |
| Fig. 22-3 I2S Left Justified Mode Timing Format .....                     | 608 |
| Fig. 22-4 I2S Right Justified Mode Timing Format .....                    | 608 |
| Fig. 22-5 PCM Early Mode Timing Format .....                              | 608 |
| Fig. 22-6 PCM Late1 Mode Timing Format .....                              | 609 |
| Fig. 22-7 PCM Late2 Mode Timing Format .....                              | 609 |
| Fig. 22-8 PCM Late3 Mode Timing Format .....                              | 609 |
| Fig. 23-1 SAI Block Diagram .....                                         | 628 |
| Fig. 23-2 SAI transmitter-master & receiver-slave condition.....          | 629 |
| Fig. 23-3 I2S Normal Mode Timing Format .....                             | 630 |
| Fig. 23-4 I2S Left Justified Mode Timing Format .....                     | 630 |
| Fig. 23-5 I2S Right Justified Mode Timing Format .....                    | 630 |
| Fig. 23-6 PCM Early Mode Timing Format .....                              | 630 |
| Fig. 23-7 SAI PCM mode timing format .....                                | 631 |
| Fig. 23-8 SAI I2S left mode timing format.....                            | 631 |
| Fig. 23-9 SAI I2S right mode timing format.....                           | 631 |
| Fig. 23-10 fs shift timing format .....                                   | 631 |

---

|                                                              |     |
|--------------------------------------------------------------|-----|
| Fig. 23-11 SAI controller transmit operation flow chart..... | 646 |
| Fig. 24-1 PDM Block Diagram .....                            | 647 |
| Fig. 24-2 PDM with Eight Mono MIC.....                       | 648 |
| Fig. 24-3 PDM with Four Stereo MIC.....                      | 648 |
| Fig. 24-4 PDM interface diagram with external MIC.....       | 649 |
| Fig. 24-5 PDM operation flow.....                            | 658 |
| Fig. 25-1 SPDIF transmitter Block Diagram.....               | 659 |
| Fig. 25-2 SPDIF Frame Format .....                           | 660 |
| Fig. 25-3 SPDIF Sub-frame Format.....                        | 660 |
| Fig. 25-4 SPDIF Channel Coding .....                         | 661 |
| Fig. 25-5 SPDIF Preamble .....                               | 661 |
| Fig. 25-6 SPDIF transmitter operation flow chart.....        | 668 |
| Fig. 26-1 SPDIF receiver Block Diagram .....                 | 669 |
| Fig. 26-2 SPDIF Frame Format .....                           | 670 |
| Fig. 26-3 SPDIF Sub-frame Format.....                        | 670 |
| Fig. 26-4 SPDIF Channel Coding .....                         | 671 |
| Fig. 26-5 SPDIF Preamble .....                               | 671 |
| Fig. 26-6 SPDIF receiver operation flow chart .....          | 681 |
| Fig. 27-1 ASRC Block Diagram.....                            | 682 |
| Fig. 27-2 ASRC Memory Fetch Mode Structure .....             | 683 |
| Fig. 27-3 ASRC MEM2MEM Mode Structure .....                  | 684 |
| Fig. 27-4 ASRC MEM2DST Mode Structure.....                   | 684 |
| Fig. 27-5 ASRC SRC2MEM Mode Structure.....                   | 685 |
| Fig. 27-6 ASRC SRC2DST Mode Structure .....                  | 685 |
| Fig. 27-7 ASRC MEM2MEM Series Mode Structure.....            | 685 |
| Fig. 28-1 FSPI Architecture .....                            | 700 |
| Fig. 28-2 Program Flow .....                                 | 725 |
| Fig. 28-3 Read Flow .....                                    | 726 |
| Fig. 28-4 Command with DMA Flow .....                        | 727 |
| Fig. 28-5 SPI mode.....                                      | 728 |
| Fig. 28-6 Idle cycles.....                                   | 728 |
| Fig. 29-1 SPI Controller Block Diagram .....                 | 730 |
| Fig. 29-2 SPI Master and Slave Interconnection .....         | 731 |
| Fig. 29-3 SPI Format (SCPH=0 SCPOL=0).....                   | 731 |
| Fig. 29-4 SPI Format (SCPH=0 SCPOL=1).....                   | 732 |
| Fig. 29-5 SPI Format (SCPH=1 SCPOL=0).....                   | 732 |
| Fig. 29-6 SPI Format (SCPH=1 SCPOL=1).....                   | 732 |
| Fig. 29-7 SPI Master Transfer Flow Diagram .....             | 743 |
| Fig. 29-8 SPI Slave Transfer Flow Diagram .....              | 744 |
| Fig. 30-1 SPI2APB Block Diagram .....                        | 745 |
| Fig. 30-2 Write Operation .....                              | 746 |
| Fig. 30-3 Read Operation .....                               | 746 |
| Fig. 30-4 Query Operation .....                              | 746 |
| Fig. 30-5 Write Message Operation.....                       | 747 |
| Fig. 31-1 PWM Block Diagram.....                             | 752 |
| Fig. 31-2 PWM Capture Mode .....                             | 752 |
| Fig. 31-3 PWM Continuous Left-aligned Output Mode .....      | 753 |
| Fig. 31-4 PWM Continuous Center-aligned Output Mode .....    | 753 |
| Fig. 31-5 PWM One-shot Center-aligned Output Mode .....      | 753 |
| Fig. 32-1 I2C Architecture.....                              | 786 |
| Fig. 32-2 I2C DATA Validity .....                            | 789 |
| Fig. 32-3 I2C Start and Stop Conditions .....                | 789 |
| Fig. 32-4 I2C Acknowledge .....                              | 789 |
| Fig. 32-5 I2C Byte Transfer .....                            | 789 |
| Fig. 32-6 I2C Flow Chat for Transmit Only Mode .....         | 799 |
| Fig. 32-7 I2C Flow Chat for Receive Only Mode .....          | 800 |
| Fig. 32-8 I2C Flow Chat for Mix Mode .....                   | 801 |

---

|                                                                            |     |
|----------------------------------------------------------------------------|-----|
| Fig. 33-1 UART Architecture .....                                          | 802 |
| Fig. 33-2 UART Serial protocol .....                                       | 803 |
| Fig. 33-3 UART Baud Rate.....                                              | 803 |
| Fig. 33-4 UART Auto Flow Control Block Diagram .....                       | 804 |
| Fig. 33-5 UART AUTO RTS TIMING .....                                       | 805 |
| Fig. 33-6 UART AUTO CTS TIMING .....                                       | 805 |
| Fig. 33-7 UART None FIFO Mode .....                                        | 827 |
| Fig. 33-8 UART FIFO Mode .....                                             | 828 |
| Fig. 34-1 RKCAN Controller Block Diagram .....                             | 830 |
| Fig. 34-2 ATF Mode .....                                                   | 831 |
| Fig. 34-3 Bit timing FSM .....                                             | 832 |
| Fig. 34-4 Bit timing waveform diagram .....                                | 832 |
| Fig. 34-5 Bit Timing .....                                                 | 833 |
| Fig. 34-6 Three sampling diagram.....                                      | 833 |
| Fig. 34-7 Hard_sync waveform diagram .....                                 | 834 |
| Fig. 34-8 Resynchronization .....                                          | 834 |
| Fig. 34-9 Measurement of Transceiver Delay.....                            | 835 |
| Fig. 34-10 Data storage format under external storage mode.....            | 836 |
| Fig. 34-11 Initialization Flow .....                                       | 865 |
| Fig. 34-12 Loop-back Mode .....                                            | 865 |
| Fig. 34-13 Silent Mode .....                                               | 866 |
| Fig. 35-1 DSMC Block Diagram .....                                         | 868 |
| Fig. 35-2 HyperRAM Read Waveform .....                                     | 868 |
| Fig. 35-3 HyperRAM Write Waveform .....                                    | 869 |
| Fig. 35-4 Region division of LocalBus device .....                         | 870 |
| Fig. 35-5 Separated Transaction .....                                      | 887 |
| Fig. 35-6 Data mapping relationship between memory and DSMC interface..... | 887 |
| Fig. 35-7 Timing Adjustment .....                                          | 888 |
| Fig. 36-1 SLAVE DSMC Block Diagram .....                                   | 889 |
| Fig. 36-2 LocalBus Read Waveform .....                                     | 890 |
| Fig. 36-3 LocalBus Write Waveform .....                                    | 890 |
| Fig. 36-4 LocalBus Read Waveform .....                                     | 891 |
| Fig. 36-5 LocalBus Read Waveform .....                                     | 891 |
| Fig. 37-1 FlexBUS Controller Block diagram .....                           | 907 |
| Fig. 37-2 FlexBUS Format (CPHA=0 CPOL=0) .....                             | 908 |
| Fig. 37-3 FlexBUS Format (CPHA=0 CPOL=1) .....                             | 908 |
| Fig. 37-4 FlexBUS Format (CPHA=1 CPOL=0) .....                             | 909 |
| Fig. 37-5 FlexBUS Format (CPHA=1 CPOL=1) .....                             | 909 |
| Fig. 37-6 FlexBUS TX Then RX Mode (CPHA=1 CPOL=0) .....                    | 909 |
| Fig. 37-7 Timing Diagram When VSYNC Low Active .....                       | 909 |
| Fig. 37-8 Timing Diagram When VSYNC High Active.....                       | 909 |
| Fig. 37-9 Timing Diagram When HREF High Active.....                        | 909 |
| Fig. 37-10 Timing Diagram When HREF Low Active .....                       | 910 |
| Fig. 37-11 Timing Diagram When Y Data First.....                           | 910 |
| Fig. 37-12 Timing Diagram When U Data First .....                          | 910 |
| Fig. 37-13 Timing Diagram When B Data First .....                          | 910 |
| Fig. 37-14 Timing Diagram When R Data First .....                          | 910 |
| Fig. 37-15 Crop .....                                                      | 911 |
| Fig. 37-16 Timing diagram in QSPI Mode .....                               | 911 |
| Fig. 37-17 Timing diagram in Multi-line.....                               | 911 |
| Fig. 38-1 MAC Block Diagram .....                                          | 936 |
| Fig. 38-2 MAC in SOC.....                                                  | 936 |
| Fig. 38-3 Frame Format.....                                                | 937 |
| Fig. 38-4 RMII Transmission Bit Ordering .....                             | 937 |
| Fig. 38-5 Start of MII and RMII Transmission in 100-Mbps Mode.....         | 938 |
| Fig. 38-6 End of MII and RMII Transmission in 100-Mbps Mode .....          | 938 |
| Fig. 38-7 Start of MII and RMII Transmission in 10-Mbps Mode .....         | 938 |

|                                                                     |      |
|---------------------------------------------------------------------|------|
| Fig. 38-8 End of MII and RMII Transmission in 10-Mbps Mode .....    | 938  |
| Fig. 38-9 RMII Receive Bit Ordering .....                           | 939  |
| Fig. 38-10 Descriptor Ring Structure .....                          | 1053 |
| Fig. 38-11 RMII Clock Architecture When Clock Source From PHY ..... | 1077 |
| Fig. 38-12 RMII Clock Architecture When Clock Source From CRU.....  | 1077 |
| Fig. 39-1 Mobile Storage Host Control Block Diagram.....            | 1079 |
| Fig. 39-2 Host Controller Command Path State Machine .....          | 1085 |
| Fig. 39-3 Host Controller Data Transmit State Machine.....          | 1087 |
| Fig. 39-4 Host Controller Data Receive State Machine .....          | 1089 |
| Fig. 39-5 Dual-Buffer Descriptor Structure .....                    | 1095 |
| Fig. 39-6 Chain Descriptor Structure .....                          | 1095 |
| Fig. 39-7 Descriptor Formats for 32-bit AHB Address Bus Width ..... | 1095 |
| Fig. 39-8 Clock Generation Unit .....                               | 1099 |
| Fig. 39-9 Host Controller Initialization Sequence .....             | 1122 |
| Fig. 39-10 Voltage Switching Command Flow Diagram .....             | 1130 |
| Fig. 39-11 ACMD41 Argument .....                                    | 1131 |
| Fig. 39-12 ACMD41 Response(R3).....                                 | 1131 |
| Fig. 39-13 Voltage Switch Normal Scenario .....                     | 1132 |
| Fig. 39-14 Voltage Switch Error Scenario .....                      | 1133 |

## Table Index

|                                                                                   |     |
|-----------------------------------------------------------------------------------|-----|
| Table 1-1 RK3506 Address Mapping.....                                             | 17  |
| Table 1-2 RK3506 BootROM /System SRAM Remap Function .....                        | 18  |
| Table 1-3 RK3506 DDR /DSMC_MEM Remap Function .....                               | 18  |
| Table 1-4 RK3506 Interrupt Connection List.....                                   | 20  |
| Table 1-5 RK3506 MCU Interrupt Connection List .....                              | 23  |
| Table 1-6 INTMUX Interrupt Connection List .....                                  | 24  |
| Table 1-7 RK3506 DMAC0 Hardware Request Connection List .....                     | 26  |
| Table 1-8 RK3506 DMAC1 Hardware Request Connection List .....                     | 27  |
| Table 1-9 RK3506 Rockchip Matrix IO Function List.....                            | 27  |
| Table 2-1 PLL Main Features .....                                                 | 30  |
| Table 4-1 Cortex-M0 Interface Description.....                                    | 133 |
| Table 4-2 M0 System Configure Signals .....                                       | 134 |
| Table 4-3 M0 System Status Signals .....                                          | 134 |
| Table 4-4 M0 Interrupt .....                                                      | 134 |
| Table 4-5 INTMUX Interrupt Source .....                                           | 135 |
| Table 6-1 RK3506 Voltage Domain and Power Domain Summary .....                    | 231 |
| Table 6-2 Power Management IO Interface .....                                     | 267 |
| Table 6-3 PMU Debug Information Decode.....                                       | 267 |
| Table 8-1 DMAC0 Request Mapping Table .....                                       | 271 |
| Table 8-2 DMAC1 Request Mapping Table .....                                       | 271 |
| Table 8-3 DMAC0 boot interface.....                                               | 329 |
| Table 8-4 DMAC1 boot interface.....                                               | 329 |
| Table 8-5 DMAC interrupt interface.....                                           | 330 |
| Table 8-6 DMAC peripheral request .....                                           | 330 |
| Table 8-7 Source size in CCRn .....                                               | 334 |
| Table 8-8 DMAC Instruction sets .....                                             | 335 |
| Table 8-9 DMAC instruction encoding .....                                         | 335 |
| Table 10-1 Clock Source and Frequency .....                                       | 359 |
| Table 11-1 Clock Frequency .....                                                  | 369 |
| Table 15-1 TSADC Rockchip Matrix IO Interface Description .....                   | 398 |
| Table 15-2 TSADC Start Timing.....                                                | 399 |
| Table 15-3 TSADC Lookup Table.....                                                | 399 |
| Table 17-1 GPIO filter Description .....                                          | 406 |
| Table 17-2 GPIO Interface Description .....                                       | 418 |
| Table 19-1 RM_IO Interface Description .....                                      | 587 |
| Table 21-1 Audio DSM M0 Interface Description .....                               | 605 |
| Table 21-2 Audio DSM M1 Interface Description .....                               | 605 |
| Table 22-1 Relationship of ACDC_CLK, ADC_CLK and Sample Rates in Normal Mode..... | 610 |
| Table 23-1 SAI0 Interface Description.....                                        | 643 |
| Table 23-2 SAI0 Rm Interface Description .....                                    | 644 |
| Table 23-3 SAI1 Interface Description.....                                        | 644 |
| Table 23-4 SAI1 Rm Interface Description .....                                    | 644 |
| Table 23-5 SAI2 M0 Interface Description.....                                     | 645 |
| Table 23-6 SAI2 M1 Interface Description.....                                     | 645 |
| Table 23-7 SAI3 Interface Description.....                                        | 645 |
| Table 24-1 Relation between PDM_CLK and sample rate .....                         | 649 |
| Table 24-2 PDM Interface Description .....                                        | 657 |
| Table 25-1 Maximum Frequency of MCLK for the SPDIF Transmitter .....              | 659 |
| Table 25-2 SPDIF TX Interface Description .....                                   | 668 |
| Table 26-1 SPDIF RX Interface Description .....                                   | 680 |
| Table 27-1 ASRC4ch0 Src_Irck Selector Description .....                           | 697 |
| Table 27-2 ASRC4ch0 Dst_Irck Selector Description .....                           | 697 |
| Table 27-3 ASRC4ch1 Src_Irck Selector Description .....                           | 697 |
| Table 27-4 ASRC4ch1 Dst_Irck Selector Description .....                           | 697 |
| Table 27-5 ASRC DMA Mode Description.....                                         | 698 |

---

|                                                                 |      |
|-----------------------------------------------------------------|------|
| Table 27-6 ASRC Series Description.....                         | 699  |
| Table 28-1 FSPI Interface Description .....                     | 724  |
| Table 29-1 SPI Interface Description.....                       | 741  |
| Table 29-2 SPI Rockchip Matrix IO Interface Description.....    | 742  |
| Table 30-1 State Register Information .....                     | 746  |
| Table 30-2 Command Encoding Information .....                   | 747  |
| Table 30-3 SPI0 Interface Description.....                      | 750  |
| Table 31-1 PWM Channel Address Map.....                         | 754  |
| Table 31-2 PWM Rockchip Matrix IO Interface Description.....    | 782  |
| Table 32-1 I2C Rockchip Matrix IO Interface Description.....    | 798  |
| Table 33-1 UART0 Interface Description .....                    | 825  |
| Table 33-2 UART1 Rockchip Matrix IO Interface Description ..... | 825  |
| Table 33-3 UART2 Rockchip Matrix IO Interface Description ..... | 825  |
| Table 33-4 UART3 Rockchip Matrix IO Interface Description ..... | 825  |
| Table 33-5 UART4 Rockchip Matrix IO Interface Description ..... | 825  |
| Table 33-6 UART5 Rockchip Matrix IO Interface Description ..... | 826  |
| Table 33-7 UART Baud Rate Configuration .....                   | 828  |
| Table 34-1 CAN IO Interface Description .....                   | 864  |
| Table 35-1 C/A Format of DSMC for Hyper Device.....             | 869  |
| Table 35-2 C/A Format of DSMC for LocalBus Device.....          | 870  |
| Table 35-3 DSMC interface description.....                      | 885  |
| Table 36-1 SLAVE DSMC interface description .....               | 905  |
| Table 37-1 FlexBUS Tranfer Modes Port List .....                | 907  |
| Table 37-2 Flexbus Interface Description .....                  | 928  |
| Table 38-1 MDIO Clause 45 Frame Structure .....                 | 939  |
| Table 38-2 MDIO Clause 22 Frame Structure .....                 | 940  |
| Table 38-3 MAC Interface.....                                   | 1051 |
| Table 38-4 MAC Rockchip Matrix IO Interface.....                | 1052 |
| Table 38-5 TDES0 Normal Descriptor (Read Format).....           | 1053 |
| Table 38-6 TDES1 Normal Descriptor (Read Format) .....          | 1054 |
| Table 38-7 TDES2 Normal Descriptor (Read Format) .....          | 1054 |
| Table 38-8 TDES3 Normal Descriptor (Read Format) .....          | 1055 |
| Table 38-9 TDES0 Normal Descriptor (Write-Back Format) .....    | 1057 |
| Table 38-10 TDES1 Normal Descriptor (Write-Back Format) .....   | 1058 |
| Table 38-11 TDES2 Normal Descriptor (Write-Back Format) .....   | 1058 |
| Table 38-12 TDES2 Normal Descriptor (Write-Back Format) .....   | 1058 |
| Table 38-13 TDES0 Context Descriptor .....                      | 1065 |
| Table 38-14 TDES1 Context Descriptor .....                      | 1065 |
| Table 38-15 TDES2 Context Descriptor .....                      | 1066 |
| Table 38-16 TDES3 Context Descriptor .....                      | 1066 |
| Table 38-17 TDES0 Normal Descriptor (Read Format) .....         | 1068 |
| Table 38-18 TDES1 Normal Descriptor(Read Format) .....          | 1068 |
| Table 38-19 TDES2 Normal Descriptor(Read Format) .....          | 1068 |
| Table 38-20 TDES3 Normal Descriptor(Read Format) .....          | 1068 |
| Table 38-21 TDES0 Normal Descriptor (Write-Back Format) .....   | 1069 |
| Table 38-22 TDES1 Normal Descriptor(Write-Back Format) .....    | 1069 |
| Table 38-23 TDES2 Normal Descriptor (Write-Back Format) .....   | 1071 |
| Table 38-24 TDES3 Normal Descriptor (Write-Back Format) .....   | 1073 |
| Table 38-25 TDES0 Context Descriptor .....                      | 1075 |
| Table 38-26 TDES1 Context Descriptor .....                      | 1076 |
| Table 38-27 TDES2 Context Descriptor .....                      | 1076 |
| Table 38-28 TDES3 Context Descriptor .....                      | 1076 |
| Table 39-1 Bits in Interrupt Status Register .....              | 1081 |
| Table 39-2 Auto-Stop Generation .....                           | 1090 |
| Table 39-3 Non-data Transfer Commands and Requirements .....    | 1091 |
| Table 39-4 Bits in IDMAC DES0 Element.....                      | 1095 |
| Table 39-5 Bits in IDMAC DES1 Element.....                      | 1096 |

|                                                                      |      |
|----------------------------------------------------------------------|------|
| Table 39-6 Bits in IDMAC DES2 Element.....                           | 1096 |
| Table 39-7 Bits in IDMAC DES3 Element.....                           | 1097 |
| Table 39-8 SDMMC 1bit mode Interface Description .....               | 1120 |
| Table 39-9 SDMMC 4 bits mode Interface Description.....              | 1120 |
| Table 39-10 Command Settings for No-Data Command .....               | 1124 |
| Table 39-11 Command Setting for Single or Multiple-Block Read.....   | 1126 |
| Table 39-12 Command Settings for Single or Multiple-Block Write..... | 1127 |
| Table 39-13 PBL and Watermark Levels.....                            | 1135 |

Rockchip Confidential

## **Warranty Disclaimer**

Copyright © 2024 Rockchip Electronics Co., Ltd. All rights reserved.

No part of this document may be reproduced, transmitted or used in any form or by any means without the written prior consent of Rockchip Electronics Co., Ltd.

### **Trademark**

Rockchip is a registered trademark of Rockchip Electronics Co., Ltd. in the People's Republic of China and other countries/areas. Other brands, product names mentioned in this document are the property of their respective owners.

### **Disclaimer**

Rockchip Electronics Co., Ltd. ("Rockchip") may make changes to any information in this document at any time without any prior notice.

Information in this document is provided just as a reference or typical applications. All or part of product features described in this document may not be within the purchase scope or the usage scope, and may be subject to the third party licensing requirements. All statements, information in this document is provided "AS IS" without warranties of any kind, either express or implied. Actual performance of Rockchip products may vary in different applications. Third party licenses maybe required to use some features supported by Rockchip products. Customers shall be solely and exclusively responsible to obtain all appropriately required third party licenses prior to its such use. Should customers use the features supported by Rockchip products without any required third party license, customers shall indemnify and hold Rockchip and its subsidiaries, affiliates as well as distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of any claim associated with such unauthorized use.

Rockchip products are not intended for use in military, airplane, medical devices, lifesaving or life sustaining applications ("Unintended Uses"). Customers shall take any and all actions to ensure using Rockchip products in a lawful manner and shall be liable for Unintended Uses.

# Chapter 1 System Overview

## 1.1 Address Mapping

RK3506 address mapping is provided in below two table.

Table 1-1 RK3506 Address Mapping

| Module       | Start Address | Size   | Module             | Start Address | Size  |
|--------------|---------------|--------|--------------------|---------------|-------|
| DDR          | 0x00000000    | 3072MB | SAI4               | 0xFF4A8000    | 32KB  |
| DSMC_MEM     | 0xC0000000    | 1008MB | Audio DSM          | 0xFF4B0000    | 32KB  |
| DMAC0        | 0xFF000000    | 32KB   | SPI2               | 0xFF4C0000    | 32KB  |
| DMAC1        | 0xFF008000    | 32KB   | MAC0               | 0xFF4C8000    | 32KB  |
| I2C0         | 0xFF040000    | 64KB   | MAC1               | 0xFF4D0000    | 32KB  |
| I2C1         | 0xFF050000    | 64KB   | GPIO2/3/4_IOC      | 0xFF4D8000    | 32KB  |
| I2C2         | 0xFF060000    | 64KB   | UART5              | 0xFF4E0000    | 32KB  |
| UART0        | 0xFF0A0000    | 64KB   | SARADC             | 0xFF4E8000    | 32KB  |
| UART1        | 0xFF0B0000    | 64KB   | NS OPTC            | 0xFF4F0000    | 32KB  |
| UART2        | 0xFF0C0000    | 64KB   | Audio ADC          | 0xFF4F8000    | 32KB  |
| UART3        | 0xFF0D0000    | 64KB   | Secure OTPC        | 0xFF520000    | 32KB  |
| UART4        | 0xFF0E0000    | 64KB   | OTP MASK           | 0xFF528000    | 32KB  |
| SPI0         | 0xFF120000    | 64KB   | KEY READER         | 0xFF530000    | 32KB  |
| SPI1         | 0xFF130000    | 64KB   | GIC400             | 0xFF580000    | 32KB  |
| PWM1         | 0xFF170000    | 32KB   | VOP                | 0xFF600000    | 64KB  |
| GPIO2        | 0xFF1C0000    | 16KB   | RGA                | 0xFF610000    | 64KB  |
| GPIO3        | 0xFF1D0000    | 16KB   | DSI HOST           | 0xFF640000    | 64KB  |
| GPIO4        | 0xFF1E0000    | 16KB   | TSADC              | 0xFF650000    | 64KB  |
| Secure DMAC0 | 0xFF200000    | 32KB   | GPIO1_IOC          | 0xFF660000    | 64KB  |
| Secure DMAC1 | 0xFF208000    | 32KB   | DPHY               | 0xFF670000    | 64KB  |
| SGRF         | 0xFF210000    | 32KB   | NS CRYPTO          | 0xFF700000    | 64KB  |
| SPINLOCK     | 0xFF240000    | 16KB   | NS RNG             | 0xFF710000    | 64KB  |
| TIMER0       | 0xFF250000    | 32KB   | USB2.0 OTG0        | 0xFF740000    | 256KB |
| TIMER1       | 0xFF258000    | 32KB   | USB2.0 OTG1        | 0xFF780000    | 256KB |
| WDT0         | 0xFF260000    | 32KB   | DDRPHY             | 0xFF7C0000    | 64KB  |
| WDT1         | 0xFF268000    | 32KB   | A7_DEBUG           | 0xFF800000    | 256KB |
| DDRCTL       | 0xFF270000    | 32KB   | GRF_CORE           | 0xFF840000    | 16KB  |
| DDRMON       | 0xFF278000    | 32KB   | GPIO1              | 0xFF870000    | 16KB  |
| DDR_LPC      | 0xFF280000    | 32KB   | FLEXBUS/Slave DSMC | 0xFF880000    | 64KB  |
| GRF          | 0xFF288000    | 16KB   | DSMC               | 0xFF8B0000    | 64KB  |
| MAILBOX      | 0xFF290000    | 16KB   | PMU                | 0xFF900000    | 64KB  |
| INTMUX       | 0xFF2A0000    | 32KB   | GRF_PMU/RMIO       | 0xFF910000    | 16KB  |
| DMA2DDR      | 0xFF2A8000    | 32KB   | PWM0               | 0xFF930000    | 16KB  |
| USBPHY       | 0xFF2B0000    | 32KB   | GPIO0              | 0xFF940000    | 16KB  |
| SAI0         | 0xFF300000    | 64KB   | GPIO0_SHADOW       | 0xFF948000    | 16KB  |
| SAI1         | 0xFF310000    | 64KB   | GPIO0_IOC          | 0xFF950000    | 64KB  |
| CAN0         | 0xFF320000    | 64KB   | SGRF_PMU           | 0xFF960000    | 64KB  |
| CAN1         | 0xFF330000    | 64KB   | HPTIMER            | 0xFF980000    | 64KB  |
| PDM          | 0xFF380000    | 64KB   | TOUCH KEY          | 0xFF990000    | 64KB  |

| Module   | Start Address | Size | Module        | Start Address | Size |
|----------|---------------|------|---------------|---------------|------|
| SPDIF_TX | 0xFF3A0000    | 64KB | CRU           | 0xFF9A0000    | 64KB |
| SPDIF_RX | 0xFF3B0000    | 64KB | CRU_PMU       | 0xFF9B0000    | 64KB |
| ASRC0    | 0xFF3C0000    | 64KB | System SRAM   | 0xFFFF80000   | 48KB |
| ASRC1    | 0xFF3D0000    | 64KB | Secure Crypto | 0xFFFFC0000   | 32KB |
| SDMMC    | 0xFF480000    | 32KB | Secure KEYLAD | 0xFFFFD0000   | 64KB |
| FSPI     | 0xFF488000    | 32KB | Secure RNG    | 0xFFFFE0000   | 64KB |
| SAI2     | 0xFF498000    | 32KB | BOOTROM       | 0xFFFFF0000   | 24KB |
| SAI3     | 0xFF4A0000    | 32KB |               |               |      |

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

Table 1-2 RK3506 BootROM /System SRAM Remap Function

| Before remap |                  | After remap             |                  |
|--------------|------------------|-------------------------|------------------|
| 0xFFFF80000  | System SRAM(48K) | 0xFFFF80000/0xFFFFF0000 | System SRAM(48K) |
| 0xFFFFF0000  | BootROM(24K)     | Not Access              | BootROM(24K)     |

The following table shows the DDR /DSMC\_MEM address before and after remapping. Before remapping, 0x00000000 and 0xC0000000 is the base address for DDR and DSMC\_MEM separately. After remapping, DDR could not be accessed, 0x00000000 is the base address for DSMC\_MEM.

Table 1-3 RK3506 DDR /DSMC\_MEM Remap Function

| Before remap |                 | After remap |                 |
|--------------|-----------------|-------------|-----------------|
| 0xC0000000   | DSMC_MEM(1008M) | 0x00000000  | DSMC_MEM(1008M) |
| 0x00000000   | DDR(3072M)      | Not Access  | DDR(3072M)      |

## 1.2 System Boot

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

The following features are supported by ROM code.

- Support system boot from the following device:
  - eMMC Interface, 4bits data width
  - Serial NOR Flash, 1/4bits data width
  - SDMMC Card, 4bits data width
- Support system code download by USB2.0 OTG0
- Support system code download by SPI2

Following figure shows typical RK3506 boot procedure flow. Boot sequence can be adjusted by changing SARADC\_IN0 voltage level.



Fig. 1-1 RK3506 Boot Procedure Flow

## 1.3 System Interrupt Connection

RK3506 provides a general interrupt controller (GIC) for CPU, which has 154 SPI (shared peripheral interrupts) interrupt sources and 6 PPI (Private peripheral interrupt) interrupt sources. The triggered type for each SPI interrupt is high level sensitive, and for each PPI interrupt is low level sensitive, both are not programmable. The detailed interrupt sources connection is in the following table.

Table 1-4 RK3506 Interrupt Connection List

| Interrupt Type | Interrupt ID  | Source | Polarity   |
|----------------|---------------|--------|------------|
| PPI            | N/A           | 16     | Low level  |
|                | N/A           | 17     | Low level  |
|                | N/A           | 18     | Low level  |
|                | N/A           | 19     | Low level  |
|                | N/A           | 20     | Low level  |
|                | N/A           | 21     | Low level  |
|                | N/A           | 22     | Low level  |
|                | N/A           | 23     | Low level  |
|                | N/A           | 24     | Low level  |
|                | N/A           | 25     | Low level  |
|                | CNTHPIRQ      | 26     | Low level  |
|                | CNTVIRQ       | 27     | Low level  |
|                | LEGACYFIQ     | 28     | Low level  |
|                | CNTPSIRQ      | 29     | Low level  |
|                | CNTPNSIRQ     | 30     | Low level  |
|                | LEGACYIRQ     | 31     | Low level  |
| SPI            | GPIO0_0       | 32     | High level |
|                | GPIO0_1       | 33     | High level |
|                | GPIO0_2       | 34     | High level |
|                | GPIO0_3       | 35     | High level |
|                | GPIO1_0       | 36     | High level |
|                | GPIO1_1       | 37     | High level |
|                | GPIO1_2       | 38     | High level |
|                | GPIO1_3       | 39     | High level |
|                | GPIO2_0       | 40     | High level |
|                | GPIO2_1       | 41     | High level |
|                | GPIO2_2       | 42     | High level |
|                | GPIO2_3       | 43     | High level |
|                | GPIO3_0       | 44     | High level |
|                | GPIO3_1       | 45     | High level |
|                | GPIO3_2       | 46     | High level |
|                | GPIO3_3       | 47     | High level |
|                | GPIO4_0       | 48     | High level |
|                | GPIO4_1       | 49     | High level |
|                | GPIO4_2       | 50     | High level |
|                | GPIO4_3       | 51     | High level |
|                | TOUCH_KEY_POS | 52     | High level |
|                | TOUCH_KEY_NEG | 53     | High level |
|                | PWM0_CH0      | 54     | High level |
|                | PWM0_CH1      | 55     | High level |
|                | PWM0_CH2      | 56     | High level |
|                | PWM0_CH3      | 57     | High level |
|                | PWM1_CH0      | 58     | High level |
|                | PWM1_CH1      | 59     | High level |

|                        |     |            |
|------------------------|-----|------------|
| PWM1_CH2               | 60  | High level |
| PWM1_CH3               | 61  | High level |
| PWM1_CH4               | 62  | High level |
| PWM1_CH5               | 63  | High level |
| PWM1_CH6               | 64  | High level |
| PWM1_CH7               | 65  | High level |
| UART0                  | 66  | High level |
| UART1                  | 67  | High level |
| UART2                  | 68  | High level |
| UART3                  | 69  | High level |
| UART4                  | 70  | High level |
| UART5                  | 71  | High level |
| I2C0                   | 72  | High level |
| I2C1                   | 73  | High level |
| I2C2                   | 74  | High level |
| SPI0                   | 75  | High level |
| SPI1                   | 76  | High level |
| CAN0                   | 77  | High level |
| CAN1                   | 78  | High level |
| SPDIF_TX               | 79  | High level |
| SPDIF_RX               | 80  | High level |
| PDM                    | 81  | High level |
| SAI0                   | 82  | High level |
| SAI1                   | 83  | High level |
| SAI2                   | 84  | High level |
| SAI3                   | 85  | High level |
| SAI4                   | 86  | High level |
| ASRC0                  | 87  | High level |
| ASRC1                  | 88  | High level |
| SARADC                 | 89  | High level |
| TSADC                  | 90  | High level |
| VOP                    | 91  | High level |
| MIPI_DSIHOST           | 92  | High level |
| RGA                    | 93  | High level |
| OTPC_NS                | 94  | High level |
| OTPC_S                 | 95  | High level |
| KEY_READER             | 96  | High level |
| OTPC_MASK              | 97  | High level |
| MAC0_SBD               | 98  | High level |
| MAC0_SBD_TX            | 99  | High level |
| MAC0_SBD_RX            | 100 | High level |
| MAC0_PMT               | 101 | High level |
| MAC1_SBD               | 102 | High level |
| MAC1_SBD_TX            | 103 | High level |
| MAC1_SBD_RX            | 104 | High level |
| MAC1_PMT               | 105 | High level |
| USB2.0_OTG0            | 106 | High level |
| USB2.0_OTG0_BVALID     | 107 | High level |
| USB2.0_OTG0_ID         | 108 | High level |
| USB2.0_OTG0_LINESTATE  | 109 | High level |
| USB2.0_OTG0_DISCONNECT | 110 | High level |
| USB2.0_OTG1            | 111 | High level |

|                        |     |            |
|------------------------|-----|------------|
| USB2.0_OTG1_BVALID     | 112 | High level |
| USB2.0_OTG1_ID         | 113 | High level |
| USB2.0_OTG1_LINESTATE  | 114 | High level |
| USB2.0_OTG1_DISCONNECT | 115 | High level |
| SPI2                   | 116 | High level |
| FSPI                   | 117 | High level |
| SDMMC                  | 118 | High level |
| DDRC_AWPOISON[0]       | 119 | High level |
| DDRC_AWPOISON[1]       | 120 | High level |
| DDRC_ARPOISON[0]       | 121 | High level |
| DDRC_ARPOISON[1]       | 122 | High level |
| DDRC_DFI_ALERT_ERR     | 123 | High level |
| DDRMON                 | 124 | High level |
| DDRPHY                 | 125 | High level |
| TIMER0_0               | 126 | High level |
| TIMER0_1               | 127 | High level |
| TIMER0_2               | 128 | High level |
| TIMER0_3               | 129 | High level |
| TIMER0_4               | 130 | High level |
| TIMER0_5               | 131 | High level |
| TIMER1_0               | 132 | High level |
| TIMER1_1               | 133 | High level |
| TIMER1_2               | 134 | High level |
| TIMER1_3               | 135 | High level |
| TIMER1_4               | 136 | High level |
| TIMER1_5               | 137 | High level |
| HPTIMER                | 138 | High level |
| WDT0                   | 139 | High level |
| WDT1                   | 140 | High level |
| Reserved               | 141 | High level |
| Reserved               | 142 | High level |
| CRYPTO                 | 143 | High level |
| CRYPTO_KEYLAD          | 144 | High level |
| CRYPTO_SC              | 145 | High level |
| NS_RNG                 | 146 | High level |
| S_RNG                  | 147 | High level |
| DMAC0                  | 148 | High level |
| DMAC0_ABORT            | 149 | High level |
| DMAC1                  | 150 | High level |
| DMAC1_ABORT            | 151 | High level |
| SLAVE_DSMC             | 152 | High level |
| A7_PMUIRQ_0            | 153 | High level |
| A7_PMUIRQ_1            | 154 | High level |
| A7_PMUIRQ_2            | 155 | High level |
| A7_PMUIRQ_3            | 156 | High level |
| A7_AXIERRIRQ           | 157 | High level |
| DSMC                   | 158 | High level |
| FLEXBUS                | 159 | High level |
| PMU                    | 160 | High level |
| NPOR_POWERGOOD         | 161 | High level |
| GPIO1_SHADOW_0         | 162 | High level |
| GPIO1_SHADOW_1         | 163 | High level |

|                       |     |            |
|-----------------------|-----|------------|
| GPIO1_SHADOW_2        | 164 | High level |
| GPIO1_SHADOW_3        | 165 | High level |
| USB2.0_OTG0_VBUSVALID | 166 | High level |
| USB2.0_OTG1_VBUSVALID | 167 | High level |
| VOP_LB_INTR           | 168 | High level |
| DMA2DDR               | 169 | High level |
| MAILBOX_AP[0]         | 170 | High level |
| MAILBOX_AP[1]         | 171 | High level |
| MAILBOX_AP[2]         | 172 | High level |
| MAILBOX_AP[3]         | 173 | High level |
| MAILBOX_BB[0]         | 174 | High level |
| MAILBOX_BB[1]         | 175 | High level |
| MAILBOX_BB[2]         | 176 | High level |
| MAILBOX_BB[3]         | 177 | High level |
| MAC0_MCGR_REQ         | 178 | High level |
| MAC1_MCGR_REQ         | 179 | High level |
| DMAC0_MASK_IRQ0       | 180 | High level |
| DMAC0_MASK_IRQ1       | 181 | High level |
| DMAC0_MASK_IRQ2       | 182 | High level |
| DMAC1_MASK_IRQ0       | 183 | High level |
| DMAC1_MASK_IRQ1       | 184 | High level |
| DMAC1_MASK_IRQ2       | 185 | High level |

There is a Nested Vectored Interrupt Controller (NVIC) embedded in MCU, which has general interrupt sources for internal blocks or external devices. Each interrupt's triggered type is high level, not programmable. The detailed interrupt sources connection is in the following table.

Table 1-5 RK3506 MCU Interrupt Connection List

| Interrupt Type | Interrupt ID           | Source | Polarity   |
|----------------|------------------------|--------|------------|
| SPI            | GPIO0_1                | 0      | High level |
|                | GPIO0_2                | 1      | High level |
|                | GPIO0_3                | 2      | High level |
|                | GPIO1_1/GPIO1_SHADOW_1 | 3      | High level |
|                | GPIO1_2/GPIO1_SHADOW_2 | 4      | High level |
|                | GPIO1_3/GPIO1_SHADOW_3 | 5      | High level |
|                | GPIO2_3                | 6      | High level |
|                | GPIO3_3                | 7      | High level |
|                | TOUCH_KEY_POS          | 8      | High level |
|                | TOUCH_KEY_NEG          | 9      | High level |
|                | PWM1_CH6               | 10     | High level |
|                | PWM1_CH7               | 11     | High level |
|                | UART3                  | 12     | High level |
|                | UART4                  | 13     | High level |
|                | I2C2                   | 14     | High level |
|                | SPI1                   | 15     | High level |
|                | SARADC                 | 16     | High level |
|                | SDMMC                  | 17     | High level |
|                | TIMER0_4               | 18     | High level |
|                | TIMER0_5               | 19     | High level |
|                | TIMER1_4               | 20     | High level |
|                | TIMER1_5/DSMC          | 21     | High level |
|                | MAILBOX_8MUX1          | 22     | High level |

|             |    |            |
|-------------|----|------------|
| DMAC0       | 23 | High level |
| DMAC0_ABORT | 24 | High level |
| DMAC1       | 25 | High level |
| DMAC1_ABORT | 26 | High level |
| FLEXBUS     | 27 | High level |
| INTMUX0     | 28 | High level |
| INTMUX1     | 29 | High level |
| INTMUX2     | 30 | High level |
| INTMUX3     | 31 | High level |

The interrupt INTMUX0~3 in above table is from INTMUX which is a 128 to 4 interrupt arbitration controller. INTMUX source is connected to general interrupt sources for internal blocks or external devices. Each interrupts triggered type is high level, not programmable. The detailed interrupt sources connection is in the following table.

Table 1-6 INTMUX Interrupt Connection List

| Interrupt ID | INTMUX Source | INTMUX Output | Polarity   |
|--------------|---------------|---------------|------------|
| 0            | GPIO0_0       | INTMUX0       | High level |
| 1            | GPIO1_0       |               | High level |
| 2            | GPIO2_0       |               | High level |
| 3            | GPIO2_1       |               | High level |
| 4            | GPIO2_2       |               | High level |
| 5            | GPIO3_0       |               | High level |
| 6            | GPIO3_1       |               | High level |
| 7            | GPIO3_2       |               | High level |
| 8            | GPIO4_0       |               | High level |
| 9            | GPIO4_1       |               | High level |
| 10           | GPIO4_2       |               | High level |
| 11           | GPIO4_3       |               | High level |
| 12           | PWM0_CH0      |               | High level |
| 13           | PWM0_CH1      |               | High level |
| 14           | PWM0_CH2      |               | High level |
| 15           | PWM0_CH3      |               | High level |
| 16           | PWM1_CH0      |               | High level |
| 17           | PWM1_CH1      |               | High level |
| 18           | PWM1_CH2      |               | High level |
| 19           | PWM1_CH3      |               | High level |
| 20           | PWM1_CH4      |               | High level |
| 21           | PWM1_CH5      |               | High level |
| 22           | UART0         |               | High level |
| 23           | UART1         |               | High level |
| 24           | UART2         |               | High level |
| 25           | UART5         |               | High level |
| 26           | I2C0          |               | High level |
| 27           | I2C1          |               | High level |
| 28           | SPI0          |               | High level |
| 29           | CAN0          |               | High level |
| 30           | CAN1          |               | High level |
| 31           | SPDIF_TX      |               | High level |
| 32           | SPDIF_RX      | INTMUX1       | High level |
| 33           | PDM           |               | High level |
| 34           | SAI0          |               | High level |
| 35           | SAI1          |               | High level |
| 36           | SAI2          |               | High level |
| 37           | SAI3          |               | High level |
| 38           | SAI4          |               | High level |

|    |                    |         |            |
|----|--------------------|---------|------------|
| 39 | ASRC0              | INTMUX2 | High level |
| 40 | ASRC1              |         | High level |
| 41 | TSADC              |         | High level |
| 42 | VOP                |         | High level |
| 43 | MIPI_DSIHOST       |         | High level |
| 44 | RGA                |         | High level |
| 45 | OTPC_NS            |         | High level |
| 46 | OTPC_S             |         | High level |
| 47 | KEY_READER         |         | High level |
| 48 | OTPC_MASK          |         | High level |
| 49 | MAC0_SBD           |         | High level |
| 50 | MAC0_SBD_TX        |         | High level |
| 51 | MAC0_SBD_RX        |         | High level |
| 52 | MAC0_PMT           |         | High level |
| 53 | MAC1_SBD           |         | High level |
| 54 | MAC1_SBD_TX        |         | High level |
| 55 | MAC1_SBD_RX        |         | High level |
| 56 | MAC1_PMT           |         | High level |
| 57 | OTG0               |         | High level |
| 58 | OTG0_BVALID        |         | High level |
| 59 | OTG0_ID            |         | High level |
| 60 | OTG0_LINESTATE     |         | High level |
| 61 | OTG0_DISCONNECT    |         | High level |
| 62 | OTG1               |         | High level |
| 63 | OTG1_BVALID        |         | High level |
| 64 | OTG1_ID            |         | High level |
| 65 | OTG1_LINESTATE     |         | High level |
| 66 | OTG1_DISCONNECT    |         | High level |
| 67 | SPI2APB            |         | High level |
| 68 | FSPI               |         | High level |
| 69 | DDRC_AWPOISON[0]   |         | High level |
| 70 | DDRC_AWPOISON[1]   |         | High level |
| 71 | DDRC_ARPOISON[0]   |         | High level |
| 72 | DDRC_ARPOISON[1]   |         | High level |
| 73 | DDRC_DFI_ALERT_ERR |         | High level |
| 74 | DDR_MONITOR        |         | High level |
| 75 | DDRPHY             |         | High level |
| 76 | TIMER0_0           |         | High level |
| 77 | TIMER0_1           |         | High level |
| 78 | TIMER0_2           |         | High level |
| 79 | TIMER0_3           |         | High level |
| 80 | TIMER1_0           |         | High level |
| 81 | TIMER1_1           |         | High level |
| 82 | TIMER1_2           |         | High level |
| 83 | TIMER1_3           |         | High level |
| 84 | HPTIMER            |         | High level |
| 85 | WDT0               |         | High level |
| 86 | WDT1               |         | High level |
| 87 | Reserved           |         | High level |
| 88 | CRYPTO             |         | High level |
| 89 | CRYPTO_KLAD        |         | High level |
| 90 | CRYPTO_SC          |         | High level |
| 91 | NS_TRNG            |         | High level |
| 92 | S_TRNG             |         | High level |
| 93 | DSMC_SLAVE         |         | High level |

|     |                        |         |            |
|-----|------------------------|---------|------------|
| 94  | A7_PMUIRQ_0            | INTMUX3 | High level |
| 95  | A7_PMUIRQ_1            |         | High level |
| 96  | A7_PMUIRQ_2            |         | High level |
| 97  | A7_PMUIRQ_3            |         | High level |
| 98  | A7_AXIERRIRQ           |         | High level |
| 99  | DSMC/TIMER1_5          |         | High level |
| 100 | PMU                    |         | High level |
| 101 | NPOR_POWERGOOD         |         | High level |
| 102 | GPIO1_SHADOW_0         |         | High level |
| 103 | GPIO1_SHADOW_1/GPIO1_1 |         | High level |
| 104 | GPIO1_SHADOW_2/GPIO1_2 |         | High level |
| 105 | GPIO1_SHADOW_3/GPIO1_3 |         | High level |
| 106 | OTG0_VBUSVALID         |         | High level |
| 107 | OTG1_VBUSVALID         |         | High level |
| 108 | VOP_LB_INTR            |         | High level |
| 109 | DMA2DDR                |         | High level |
| 110 | MAILBOX_AP[0]          |         | High level |
| 111 | MAILBOX_AP[1]          |         | High level |
| 112 | MAILBOX_AP[2]          |         | High level |
| 113 | MAILBOX_AP[3]          |         | High level |
| 114 | MAILBOX_BB[0]          |         | High level |
| 115 | MAILBOX_BB[1]          |         | High level |
| 116 | MAILBOX_BB[2]          |         | High level |
| 117 | MAILBOX_BB[3]          |         | High level |
| 118 | MAC0_MCGR_REQ          |         | High level |
| 119 | MAC1_MCGR_REQ          |         | High level |
| 120 | DMAC0_MASK_IRQ0        |         | High level |
| 121 | DMAC0_MASK_IRQ1        |         | High level |
| 122 | DMAC0_MASK_IRQ2        |         | High level |
| 123 | DMAC1_MASK_IRQ0        |         | High level |
| 124 | DMAC1_MASK_IRQ1        |         | High level |
| 125 | DMAC1_MASK_IRQ2        |         | High level |
| 126 | Reserved               |         | High level |
| 127 | Reserved               |         | High level |

## 1.4 System DMA Hardware Request Connection

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

Some DMAC channels may receive multiple peripheral requests but can only receive one at the same time. For detailed configuration, please refer to GRF Chapter.

Table 1-7 RK3506 DMAC0 Hardware Request Connection List

| Req Number | Source                   | Polarity   |
|------------|--------------------------|------------|
| 0          | SPI0 TX/CAN0 RX/ASRC0 RX | High level |
| 1          | SPI0 RX/CAN1 RX/ASRC0 TX | High level |
| 2          | SPI1 TX/DSMC TX/ASRC1 RX | High level |
| 3          | SPI1 RX/DSMC RX/ASRC1 TX | High level |
| 4          | UART0 TX/CAN0 RX         | High level |
| 5          | UART0 RX/CAN1 RX/PDM RX  | High level |
| 6          | UART1 TX/SPDIF_TX        | High level |
| 7          | UART1 RX/SPDIF_RX        | High level |
| 8          | UART2 TX/DSMC TX/SAI0 RX | High level |
| 9          | UART2 RX/SAI0 TX         | High level |

| Req Number | Source                   | Polarity   |
|------------|--------------------------|------------|
| 10         | UART3 TX/DSMC RX/SAI1 RX | High level |
| 11         | UART3 RX/SAI1 TX         | High level |

Table 1-8 RK3506 DMAC1 Hardware Request Connection List

| Req Number | Source           | Polarity   |
|------------|------------------|------------|
| 0          | SAI0 RX          | High level |
| 1          | SAI0 TX          | High level |
| 2          | SAI1 RX          | High level |
| 3          | SAI1 TX          | High level |
| 4          | SAI2 RX          | High level |
| 5          | SAI2 TX          | High level |
| 6          | SAI3 TX          | High level |
| 7          | SAI3 RX          | High level |
| 8          | SAI4 RX          | High level |
| 9          | PDM RX           | High level |
| 10         | SPDIF_TX/CAN0 RX | High level |
| 11         | SPDIF_RX/CAN1 RX | High level |
| 12         | UART4 TX         | High level |
| 13         | UART4 RX         | High level |
| 14         | UART5 TX         | High level |
| 15         | UART5 RX         | High level |
| 16         | ASRC0 RX         | High level |
| 17         | ASRC0 TX         | High level |
| 18         | ASRC1 RX         | High level |
| 19         | ASRC1 TX         | High level |

## 1.5 Rockchip Matrix IO Function List

RK3506 support one Rockchip Matrix IO (RM\_IO) which are designed to let numerous functional signals share limited pin interfaces. Within the same matrix, any function signal can be mapped to any pin interface by software configurable.

RM\_IO support 98 function signals map to 32 pin interfaces (GPIO0\_A0~GPIO0\_C7, GPIO1\_B1, GPIO1\_B2, GPIO1\_B3, GPIO1\_C2, GPIO1\_C3, GPIO1\_D1, GPIO1\_D2, GPIO1\_D3).

Table 1-9 RK3506 Rockchip Matrix IO Function List

| Function Index | RM_IO      | Function Index | RM_IO     |
|----------------|------------|----------------|-----------|
| 1              | UART1_TX   | 51             | SAI0_MCLK |
| 2              | UART1_RX   | 52             | SAI0_SCLK |
| 3              | UART2_TX   | 53             | SAI0_LRCK |
| 4              | UART2_RX   | 54             | SAI0_SDIO |
| 5              | UART3_TX   | 55             | SAI0_SDII |
| 6              | UART3_RX   | 56             | SAI0_SDII |
| 7              | UART3_CTSN | 57             | SAI0_SDI3 |
| 8              | UART3_RTSN | 58             | SAI0_SDO  |
| 9              | UART4_TX   | 59             | SAI1_MCLK |
| 10             | UART4_RX   | 60             | SAI1_SCLK |
| 11             | UART4_CTSN | 61             | SAI1_LRCK |

**RK3506 TRM (Part 1)**

|    |                 |    |                   |
|----|-----------------|----|-------------------|
| 12 | UART4_RTSN      | 62 | SAI1_SDI          |
| 13 | MIPITE          | 63 | SAI1_SDO0         |
| 14 | CLK_32K         | 64 | SAI1_SDO1         |
| 15 | I2C0_SCL        | 65 | SAI1_SDO2         |
| 16 | I2C0_SDA        | 66 | SAI1_SDO3         |
| 17 | I2C1_SCL        | 67 | SPI0_CLK          |
| 18 | I2C1_SDA        | 68 | SPI0_MOSI         |
| 19 | I2C2_SCL        | 69 | SPI0_MISO         |
| 20 | I2C2_SDA        | 70 | SPI0_CSNO         |
| 21 | PDM_CLK0        | 71 | SPI0_CSNI         |
| 22 | PDM_SDI0        | 72 | SPI1_CLK          |
| 23 | PDM_SDI1        | 73 | SPI1_MOSI         |
| 24 | PDM_SDI2        | 74 | SPI1_MISO         |
| 25 | PDM_SDI3        | 75 | SPI1_CSNO         |
| 26 | CAN1_TX         | 76 | SPI1_CSNI         |
| 27 | CAN1_RX         | 77 | WDT_TSADC_SHUT    |
| 28 | CAN0_TX         | 78 | PMU_SLEEP         |
| 29 | CAN0_RX         | 79 | CORE_POWER_OFF    |
| 30 | PWM0_CH0        | 80 | SPDIF_TX          |
| 31 | PWM0_CH1        | 81 | SPDIF_RX          |
| 32 | PWM0_CH2        | 82 | PWM1_BIP_CNTR_A0  |
| 33 | PWM0_CH3        | 83 | PWM1_BIP_CNTR_A1  |
| 34 | PWM1_CH0        | 84 | PWM1_BIP_CNTR_A2  |
| 35 | PWM1_CH1        | 85 | PWM1_BIP_CNTR_A3  |
| 36 | PWM1_CH2        | 86 | PWM1_BIP_CNTR_A4  |
| 37 | PWM1_CH3        | 87 | PWM1_BIP_CNTR_A5  |
| 38 | PWM1_CH4        | 88 | PWM1_BIP_CNTR_B0  |
| 39 | PWM1_CH5        | 89 | PWM1_BIP_CNTR_B1  |
| 40 | PWM1_CH6        | 90 | PWM1_BIP_CNTR_B2  |
| 41 | PWM1_CH7        | 91 | PWM1_BIP_CNTR_B3  |
| 42 | TOUCH_KEY_DRIVE | 92 | PWM1_BIP_CNTR_B4  |
| 43 | TOUCH_KEY_IN0   | 93 | PWM1_BIP_CNTR_B5  |
| 44 | TOUCH_KEY_IN1   | 94 | PDM_CLK1          |
| 45 | TOUCH_KEY_IN2   | 95 | ETH_RMII0_PPSCLK  |
| 46 | TOUCH_KEY_IN3   | 96 | ETH_RMII0_PPSTRIG |
| 47 | TOUCH_KEY_IN4   | 97 | ETH_RMII1_PPSCLK  |
| 48 | TOUCH_KEY_IN5   | 98 | ETH_RMII1_PPSTRIG |

|    |               |  |  |
|----|---------------|--|--|
| 49 | TOUCH_KEY_IN6 |  |  |
| 50 | TOUCH_KEY_IN7 |  |  |

Rockchip Confidential

## Chapter 2 Clock & Reset Unit (CRU)

### 2.1 Overview

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

We design a sub module called CRU\_PMU inside CRU. Both CRU and CRU\_PMU APB slave address space are 64KB, we define higher 32KB as secure address space.

The CRU supports the following features:

- Compliance with AMBA APB interface
- Embedded with 3 fractional PLLs (GPLL, V0PLL and V1PLL)
- Flexible selection of clock source
- Use clock matrix scheme
- Support dividing clock separately
- Support gating clock separately
- Support software reset each module separately

### 2.2 Block Diagram

The CRU comprises with:

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



Fig. 2-1 CRU Block Diagram

### 2.3 Function Description

#### 2.3.1 PLL Introduction

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

Table 2-1 PLL Main Features

|           | FRACPLL(INT Mode) |      | FRACPLL(FRAC Mode) |       |
|-----------|-------------------|------|--------------------|-------|
| Parameter | Min               | Max  | Min                | Max   |
| FREF(MHz) | 1                 | 1200 | 10                 | 1200M |
| REFDIV    | 1                 | 63   | 1                  | 63    |
| FBDIV     | 16                | 3800 | 20                 | 380   |
| POSTDIV1  | 1                 | 7    | 1                  | 7     |

|                  |     |                 |     |                 |
|------------------|-----|-----------------|-----|-----------------|
| POSTDIV2         | 1   | 7               | 1   | 7               |
| PFD(MHz)         | 1   | FOUTVCO/16      | 1   | FOUTVCO /20     |
| FOUTVCO(MHz)     | 950 | 3800            | 950 | 3800            |
| FOUTPOSTDIV(MHz) | 19  | 3800            | 19  | 3800            |
| lock time(us)    |     | 500*REFDIV/FREF |     | 500*REFDIV/FREF |

PLL block diagram is shown below:



Fig. 2-2 PLL Block Diagram

### 2.3.2 System Clock Solution

There are 3 fractional PLLs in RK3506: GPLL, V0PLL and V1PLL. All PLLs can receive 24MHz oscillator as input reference clock. In addition, V0PLL and V1PLL supports reference clock from GPIO.

ALL PLLs can be set to three work modes: normal mode, slow mode and deep slow mode. Before power on or changing PLL setting, we must program PLL into slow mode or deep slow mode. To maximize the flexibility, some clocks can select divider source from multiple PLLs. To provide some specific frequency, another solution is integrated: fractional divider and Divfree50 divider are also provided for some modules. All clocks can be gated by software.

The basic units for clock generation are:

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

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

### 2.3.3 System Reset Solution

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



Fig. 2-3 Reset Architecture Diagram

Reset source of each reset signal includes:

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

## 2.4 CRU Register Description

### 2.4.1 Registers Summary

| Name                    | Offset | Size | Reset Value | Description                                   |
|-------------------------|--------|------|-------------|-----------------------------------------------|
| <u>CRU_MODE_CON00</u>   | 0x0280 | W    | 0x00000000  | Internal PLL mode select register 0           |
| <u>CRU_CLKSEL_CON00</u> | 0x0300 | W    | 0x000004C0  | Internal clock select and division register 0 |
| <u>CRU_CLKSEL_CON01</u> | 0x0304 | W    | 0x00000B67  | Internal clock select and division register 1 |
| <u>CRU_CLKSEL_CON02</u> | 0x0308 | W    | 0x000000229 | Internal clock select and division register 2 |
| <u>CRU_CLKSEL_CON03</u> | 0x030C | W    | 0x000002A00 | Internal clock select and division register 3 |
| <u>CRU_CLKSEL_CON04</u> | 0x0310 | W    | 0x000000055 | Internal clock select and division register 4 |
| <u>CRU_CLKSEL_CON05</u> | 0x0314 | W    | 0x00060019  | Internal clock select and division register 5 |
| <u>CRU_CLKSEL_CON06</u> | 0x0318 | W    | 0x01200C35  | Internal clock select and division register 6 |

| Name             | Offset | Size | Reset Value | Description                                    |
|------------------|--------|------|-------------|------------------------------------------------|
| CRU_CLKSEL_CON07 | 0x031C | W    | 0x00C00C35  | Internal clock select and division register 7  |
| CRU_CLKSEL_CON08 | 0x0320 | W    | 0x000003DE  | Internal clock select and division register 7  |
| CRU_CLKSEL_CON09 | 0x0324 | W    | 0x03723D09  | Internal clock select and division register 9  |
| CRU_CLKSEL_CON10 | 0x0328 | W    | 0x001403DE  | Internal clock select and division register 8  |
| CRU_CLKSEL_CON11 | 0x032C | W    | 0x00800C35  | Internal clock select and division register 11 |
| CRU_CLKSEL_CON12 | 0x0330 | W    | 0x00070064  | Internal clock select and division register 12 |
| CRU_CLKSEL_CON13 | 0x0334 | W    | 0x01290C80  | Internal clock select and division register 13 |
| CRU_CLKSEL_CON15 | 0x033C | W    | 0x000000240 | Internal clock select and division register 15 |
| CRU_CLKSEL_CON16 | 0x0340 | W    | 0x000000007 | Internal clock select and division register 16 |
| CRU_CLKSEL_CON18 | 0x0348 | W    | 0x000002182 | Internal clock select and division register 18 |
| CRU_CLKSEL_CON19 | 0x034C | W    | 0x000011A3  | Internal clock select and division register 19 |
| CRU_CLKSEL_CON21 | 0x0354 | W    | 0x00001000  | Internal clock select and division register 21 |
| CRU_CLKSEL_CON22 | 0x0358 | W    | 0x000000001 | Internal clock select and division register 22 |
| CRU_CLKSEL_CON23 | 0x035C | W    | 0x000000200 | Internal clock select and division register 23 |
| CRU_CLKSEL_CON29 | 0x0374 | W    | 0x000000001 | Internal clock select and division register 29 |
| CRU_CLKSEL_CON30 | 0x0378 | W    | 0x000000000 | Internal clock select and division register 30 |
| CRU_CLKSEL_CON31 | 0x037C | W    | 0x000000000 | Internal clock select and division register 31 |
| CRU_CLKSEL_CON32 | 0x0380 | W    | 0x000000410 | Internal clock select and division register 32 |
| CRU_CLKSEL_CON33 | 0x0384 | W    | 0x000000050 | Internal clock select and division register 33 |
| CRU_CLKSEL_CON34 | 0x0388 | W    | 0x00004100  | Internal clock select and division register 34 |
| CRU_CLKSEL_CON35 | 0x038C | W    | 0x000010C0  | Internal clock select and division register 35 |
| CRU_CLKSEL_CON36 | 0x0390 | W    | 0x000000043 | Internal clock select and division register 36 |

| Name             | Offset | Size | Reset Value | Description                                    |
|------------------|--------|------|-------------|------------------------------------------------|
| CRU_CLKSEL_CON37 | 0x0394 | W    | 0x00000020  | Internal clock select and division register 37 |
| CRU_CLKSEL_CON38 | 0x0398 | W    | 0x00000041F | Internal clock select and division register 38 |
| CRU_CLKSEL_CON39 | 0x039C | W    | 0x00004620  | Internal clock select and division register 39 |
| CRU_CLKSEL_CON40 | 0x03A0 | W    | 0x000000100 | Internal clock select and division register 40 |
| CRU_CLKSEL_CON41 | 0x03A4 | W    | 0x000000100 | Internal clock select and division register 41 |
| CRU_CLKSEL_CON42 | 0x03A8 | W    | 0x000011A3  | Internal clock select and division register 42 |
| CRU_CLKSEL_CON46 | 0x03B8 | W    | 0x00001111  | Internal clock select and division register 46 |
| CRU_CLKSEL_CON47 | 0x03BC | W    | 0x000000000 | Internal clock select and division register 47 |
| CRU_CLKSEL_CON49 | 0x03C4 | W    | 0x000041A0  | Internal clock select and division register 49 |
| CRU_CLKSEL_CON50 | 0x03C8 | W    | 0x0000007C9 | Internal clock select and division register 50 |
| CRU_CLKSEL_CON51 | 0x03CC | W    | 0x000000100 | Internal clock select and division register 51 |
| CRU_CLKSEL_CON52 | 0x03D0 | W    | 0x000000100 | Internal clock select and division register 52 |
| CRU_CLKSEL_CON53 | 0x03D4 | W    | 0x000000101 | Internal clock select and division register 53 |
| CRU_CLKSEL_CON54 | 0x03D8 | W    | 0x000000001 | Internal clock select and division register 54 |
| CRU_CLKSEL_CON55 | 0x03DC | W    | 0x000000007 | Internal clock select and division register 55 |
| CRU_CLKSEL_CON58 | 0x03E8 | W    | 0x0000000A3 | Internal clock select and division register 58 |
| CRU_CLKSEL_CON59 | 0x03EC | W    | 0x000000001 | Internal clock select and division register 59 |
| CRU_CLKSEL_CON60 | 0x03F0 | W    | 0x000000209 | Internal clock select and division register 60 |
| CRU_CLKSEL_CON61 | 0x03F4 | W    | 0x000000113 | Internal clock select and division register 61 |
| CRU_GATE_CON00   | 0x0800 | W    | 0x000000000 | Internal clock gate and division register 0    |
| CRU_GATE_CON01   | 0x0804 | W    | 0x000000000 | Internal clock gate and division register 1    |
| CRU_GATE_CON02   | 0x0808 | W    | 0x000000000 | Internal clock gate and division register 2    |

| Name               | Offset | Size | Reset Value | Description                                  |
|--------------------|--------|------|-------------|----------------------------------------------|
| CRU_GATE_CON03     | 0x080C | W    | 0x00000000  | Internal clock gate and division register 3  |
| CRU_GATE_CON04     | 0x0810 | W    | 0x00000000  | Internal clock gate and division register 4  |
| CRU_GATE_CON05     | 0x0814 | W    | 0x00000000  | Internal clock gate and division register 5  |
| CRU_GATE_CON06     | 0x0818 | W    | 0x00000000  | Internal clock gate and division register 6  |
| CRU_GATE_CON07     | 0x081C | W    | 0x00000000  | Internal clock gate and division register 7  |
| CRU_GATE_CON08     | 0x0820 | W    | 0x00000000  | Internal clock gate and division register 8  |
| CRU_GATE_CON10     | 0x0828 | W    | 0x00000000  | Internal clock gate and division register 10 |
| CRU_GATE_CON11     | 0x082C | W    | 0x00000000  | Internal clock gate and division register 11 |
| CRU_GATE_CON12     | 0x0830 | W    | 0x00000000  | Internal clock gate and division register 12 |
| CRU_GATE_CON13     | 0x0834 | W    | 0x00000000  | Internal clock gate and division register 13 |
| CRU_GATE_CON14     | 0x0838 | W    | 0x00000000  | Internal clock gate and division register 14 |
| CRU_GATE_CON16     | 0x0840 | W    | 0x00000000  | Internal clock gate and division register 16 |
| CRU_GATE_CON17     | 0x0844 | W    | 0x00000000  | Internal clock gate and division register 17 |
| CRU_GATE_CON18     | 0x0848 | W    | 0x00000000  | Internal clock gate and division register 18 |
| CRU_GATE_CON19     | 0x084C | W    | 0x00000000  | Internal clock gate and division register 19 |
| CRU_GATE_CON20     | 0x0850 | W    | 0x00000000  | Internal clock gate and division register 20 |
| CRU_GATE_CON21     | 0x0854 | W    | 0x00000000  | Internal clock gate and division register 21 |
| CRU_GATE_CON22     | 0x0858 | W    | 0x00000000  | Internal clock gate and division register 22 |
| CRU_SOFT_RST_CON00 | 0x0A00 | W    | 0x00000000  | Internal clock reset register 0              |
| CRU_SOFT_RST_CON02 | 0x0A08 | W    | 0x00000000  | Internal clock reset register 2              |
| CRU_SOFT_RST_CON03 | 0x0A0C | W    | 0x00000000  | Internal clock reset register 3              |
| CRU_SOFT_RST_CON04 | 0x0A10 | W    | 0x00000000  | Internal clock reset register 4              |
| CRU_SOFT_RST_CON05 | 0x0A14 | W    | 0x00000000  | Internal clock reset register 5              |
| CRU_SOFT_RST_CON06 | 0x0A18 | W    | 0x00000000  | Internal clock reset register 6              |
| CRU_SOFT_RST_CON07 | 0x0A1C | W    | 0x00000000  | Internal clock reset register 7              |
| CRU_SOFT_RST_CON08 | 0x0A20 | W    | 0x00000000  | Internal clock reset register 8              |

| Name                       | Offset | Size | Reset Value | Description                             |
|----------------------------|--------|------|-------------|-----------------------------------------|
| CRU_SOFT_RST_CON09         | 0x0A24 | W    | 0x00000000  | Internal clock reset register 9         |
| CRU_SOFT_RST_CON10         | 0x0A28 | W    | 0x00000000  | Internal clock reset register 10        |
| CRU_SOFT_RST_CON11         | 0x0A2C | W    | 0x00000000  | Internal clock reset register 11        |
| CRU_SOFT_RST_CON12         | 0x0A30 | W    | 0x00000000  | Internal clock reset register 12        |
| CRU_SOFT_RST_CON13         | 0x0A34 | W    | 0x00000000  | Internal clock reset register 13        |
| CRU_SOFT_RST_CON14         | 0x0A38 | W    | 0x00000000  | Internal clock reset register 14        |
| CRU_SOFT_RST_CON17         | 0x0A44 | W    | 0x00000000  | Internal clock reset register 17        |
| CRU_SOFT_RST_CON18         | 0x0A48 | W    | 0x00000000  | Internal clock reset register 18        |
| CRU_SOFT_RST_CON19         | 0x0A4C | W    | 0x00000000  | Internal clock reset register 19        |
| CRU_SOFT_RST_CON21         | 0x0A54 | W    | 0x00000000  | Internal clock reset register 21        |
| CRU_SOFT_RST_CON22         | 0x0A58 | W    | 0x00000000  | Internal clock reset register 22        |
| CRU_GLB_CNT_TH             | 0x0C00 | W    | 0x00000064  | Global reset counter threshold register |
| CRU_GLB_RST_ST             | 0x0C04 | W    | 0x00000000  | Global reset state register             |
| CRU_GLB_SRST_FST_VAL<br>UE | 0x0C08 | W    | 0x00000000  | Global software first reset register    |
| CRU_GLB_SRST_SND_VAL<br>UE | 0x0C0C | W    | 0x00000000  | Global software second reset register   |
| CRU_GLB_RST_CON            | 0x0C10 | W    | 0x00000000  | Global reset control register           |
| CRU_COREWFI_CON            | 0x0C2C | W    | 0x00000000  | Core WFI 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

## 2.4.2 Detail Registers Description

### CRU MODE CON00

Address: Operational Base(0xFF9A0000) + offset (0x0280)

| Bit   | Attr | Reset Value | Description                                                                                                                        |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| 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:4   | RW   | 0x0         | clk_v1pll_mode<br>clk_v1pll_mux clock mux.<br>2'b00: xin_osc0_func<br>2'b01: clk_v1pll<br>2'b10: clk_deepslow                      |
| 3:2   | RW   | 0x0         | clk_v0pll_mode<br>clk_v0pll_mux clock mux.<br>2'b00: xin_osc0_func<br>2'b01: clk_v0pll<br>2'b10: clk_deepslow                      |

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

### **CRU CLKSEL CON00**

Address: Operational Base(0xFF9A0000) + offset (0x0300)

| <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:14      | RO          | 0x0                | reserved                                                                                                                           |
| 13:10      | RW          | 0x1                | clk_gpll_div_100m_div<br>Divide clk_gpll_div_100m by (div_con + 1).                                                                |
| 9:6        | RW          | 0x3                | clk_gpll_div_div<br>Divide clk_gpll_div by (div_con + 1).                                                                          |
| 5:0        | RO          | 0x00               | reserved                                                                                                                           |

### **CRU CLKSEL CON01**

Address: Operational Base(0xFF9A0000) + offset (0x0304)

| <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:13      | RO          | 0x0                | reserved                                                                                                                           |
| 12:8       | RW          | 0x0b               | clk_int_voice_matrix0_div<br>DT50 division register.<br>Divide clk_int_voice_matrix0 by (div_con + 1).                             |
| 7:4        | RW          | 0x6                | clk_v1pll_div_div<br>Divide clk_v1pll_div by (div_con + 1).                                                                        |
| 3:0        | RW          | 0x7                | clk_v0pll_div_div<br>Divide clk_v0pll_div by (div_con + 1).                                                                        |

### **CRU CLKSEL CON02**

Address: Operational Base(0xFF9A0000) + offset (0x0308)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------|
| 9:5        | RW          | 0x11               | clk_int_voice_matrix2_div<br>DT50 division register.<br>Divide clk_int_voice_matrix2 by (div_con + 1). |
| 4:0        | RW          | 0x09               | clk_int_voice_matrix1_div<br>DT50 division register.<br>Divide clk_int_voice_matrix1 by (div_con + 1). |

**CRU CLKSEL CON03**

Address: Operational Base(0xFF9A0000) + offset (0x030C)

| <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         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                  |
| 14:13      | RW          | 0x1                | clk_frac_voice_matrix0_mux_sel<br>clk_frac_voice_matrix0_mux clock mux.<br>2'b00: xin_osc0_func_gate<br>2'b01: clk_gpll_mux_gate<br>2'b10: clk_v0pll_mux_gate<br>2'b11: clk_v1pll_mux_gate                                                                                                                                |
| 12:11      | RW          | 0x1                | clk_frac_uart_matrix1_mux_sel<br>clk_frac_uart_matrix1_mux clock mux.<br>2'b00: xin_osc0_func<br>2'b01: clk_gpll_mux_gate<br>2'b10: clk_v0pll_mux_gate<br>2'b11: clk_v1pll_mux_gate                                                                                                                                       |
| 10:9       | RW          | 0x1                | clk_frac_uart_matrix0_mux_sel<br>clk_frac_uart_matrix0_mux clock mux.<br>2'b00: xin_osc0_func<br>2'b01: clk_gpll_mux<br>2'b10: clk_v0pll_mux_gate<br>2'b11: clk_v1pll_mux_gate                                                                                                                                            |
| 8:5        | RW          | 0x0                | clk_testout_sel<br>clk_testout clock mux.<br>4'b0000: xin_osc0_func_gate<br>4'b0001: clk_gpll<br>4'b0010: clk_v0pll<br>4'b0011: clk_v1pll<br>4'b0100: clk_deepslow<br>4'b0101: clk_rc<br>4'b0110: clk_core_pvtpll_logic<br>4'b0111: clk_frac_uart_matrix0<br>4'b1000: clk_frac_voice_matrix0<br>4'b1001: clk_core_src_pre |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |             |                    | 4'b1010: clk_usbotg0_utmi_phy<br>4'b1011: clk_usbotg1_utmi_phy<br>4'b1100: dsi_lanebyte_clk_phy<br>4'b1101: dsi_rxclk_esc_phy<br>4'b1110: clk_spdifrx_to_asrc<br>4'b1111: Reserved |
| 4:0        | RW          | 0x00               | clk_testout_div<br>Divide clk_testout by (div_con + 1).                                                                                                                            |

### **CRU CLKSEL CON04**

Address: Operational Base(0xFF9A0000) + offset (0x0310)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                           |
| 15:8       | RO          | 0x00               | reserved                                                                                                                                                                                     |
| 7:6        | RW          | 0x1                | clk_frac_common_matrix2_mux_sel<br>clk_frac_common_matrix2_mux clock mux.<br>2'b00: xin_osc0_func_gate<br>2'b01: clk_gpll_mux_gate<br>2'b10: clk_v0pll_mux_gate<br>2'b11: clk_v1pll_mux_gate |
| 5:4        | RW          | 0x1                | clk_frac_common_matrix1_mux_sel<br>clk_frac_common_matrix1_mux clock mux.<br>2'b00: xin_osc0_func<br>2'b01: clk_gpll_mux_gate<br>2'b10: clk_v0pll_mux_gate<br>2'b11: clk_v1pll_mux_gate      |
| 3:2        | RW          | 0x1                | clk_frac_common_matrix0_mux_sel<br>clk_frac_common_matrix0_mux clock mux.<br>2'b00: xin_osc0_func_gate<br>2'b01: clk_gpll_mux_gate<br>2'b10: clk_v0pll_mux_gate<br>2'b11: clk_v1pll_mux_gate |
| 1:0        | RW          | 0x1                | clk_frac_voice_matrix1_mux_sel<br>clk_frac_voice_matrix1_mux clock mux.<br>2'b00: xin_osc0_func_gate<br>2'b01: clk_gpll_mux_gate<br>2'b10: clk_v0pll_mux_gate<br>2'b11: clk_v1pll_mux_gate   |

### **CRU CLKSEL CON05**

Address: Operational Base(0xFF9A0000) + offset (0x0314)

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

**CRU CLKSEL CON06**

Address: Operational Base(0xFF9A0000) + offset (0x0318)

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

**CRU CLKSEL CON07**

Address: Operational Base(0xFF9A0000) + offset (0x031C)

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

**CRU CLKSEL CON08**

Address: Operational Base(0xFF9A0000) + offset (0x0320)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x0000000          | clk_frac_voice_matrix0_div_high<br>clk_frac_voice_matrix0 fraction division high bits register.<br>bit23~16 for the bit23~16 of numerator<br>bit7~0 for the bit23~16 of denominator |

**CRU CLKSEL CON09**

Address: Operational Base(0xFF9A0000) + offset (0x0324)

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

**CRU CLKSEL CON10**

Address: Operational Base(0xFF9A0000) + offset (0x0328)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | clk_frac_voice_matrix1_div_high<br>clk_frac_voice_matrix1 fraction division high bits register.<br>bit23~16 for the bit23~16 of numerator<br>bit7~0 for the bit23~16 of denominator |

**CRU CLKSEL CON11**

Address: Operational Base(0xFF9A0000) + offset (0x032C)

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

**CRU CLKSEL CON12**

Address: Operational Base(0xFF9A0000) + offset (0x0330)

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

**CRU CLKSEL CON13**

Address: Operational Base(0xFF9A0000) + offset (0x0334)

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

**CRU CLKSEL CON15**

Address: Operational Base(0xFF9A0000) + offset (0x033C)

| <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:13      | RO          | 0x0                | reserved                                                                                                                           |
| 12:9       | RW          | 0x1                | ackl_core_root_div<br>Divide ackl_core_root by (div_con + 1).                                                                      |
| 8          | RW          | 0x0                | clk_core_src_pvtmux_sel<br>clk_core_src_pvtmux clock mux.<br>1'b0: clk_core_src_pre<br>1'b1: clk_core_pvtpll_src                   |
| 7          | RW          | 0x0                | clk_core_pvtpll_src_sel<br>clk_core_pvtpll_src clock mux.<br>1'b0: clk_deepslow<br>1'b1: clk_core_pvtpll                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 6:5        | RW          | 0x2                | clk_core_src_div_sel<br>clk_core_src_div clock mux.<br>2'b00: clk_gpll_mux_gate<br>2'b01: clk_v0pll_mux_gate<br>2'b10: clk_v1pll_mux_gate |
| 4:0        | RW          | 0x00               | clk_core_src_div_div<br>Divide clk_core_src_div by (div_con + 1).                                                                         |

### **CRU CLKSEL CON16**

Address: Operational Base(0xFF9A0000) + offset (0x0340)

| <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:0        | RW          | 0x7                | pclk_core_root_div<br>Divide pclk_core_root by (div_con + 1).                                                                      |

### **CRU CLKSEL CON18**

Address: Operational Base(0xFF9A0000) + offset (0x0348)

| <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:14      | RO          | 0x0                | reserved                                                                                                                                               |
| 13:12      | RW          | 0x2                | clk_dsmc_sel<br>clk_dsmc clock mux.<br>2'b00: xin_osc0_func_gate<br>2'b01: clk_gpll_mux_gate<br>2'b10: clk_v0pll_mux_gate<br>2'b11: clk_v1pll_mux_gate |
| 11:7       | RW          | 0x03               | clk_dsmc_div<br>DT50 division register.<br>Divide clk_dsmc by (div_con + 1).                                                                           |
| 6:5        | RW          | 0x0                | ackl_core_peri_root_sel<br>ackl_core_peri_root clock mux.<br>2'b00: clk_gpll_mux_gate<br>2'b01: clk_v0pll_mux_gate<br>2'b10: clk_v1pll_mux_gate        |
| 4:0        | RW          | 0x02               | ackl_core_peri_root_div<br>Divide ackl_core_peri_root by (div_con + 1).                                                                                |

### **CRU CLKSEL CON19**

## RK3506 TRM (Part 1)

Address: Operational Base(0xFF9A0000) + offset (0x034C)

| <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:14      | RO          | 0x0                | reserved                                                                                                                                                             |
| 13:12      | RW          | 0x1                | clk_flexport_rx_sel<br>clk_flexport_rx clock mux.<br>2'b00: xin_osc0_func_gate<br>2'b01: clk_gpll_mux_gate<br>2'b10: clk_v0pll_mux_gate<br>2'b11: clk_v1pll_mux_gate |
| 11:7       | RW          | 0x03               | clk_flexport_rx_div<br>DT50 division register.<br>Divide clk_flexport_rx by (div_con + 1).                                                                           |
| 6:5        | RW          | 0x1                | clk_flexport_tx_sel<br>clk_flexport_tx clock mux.<br>2'b00: xin_osc0_func_gate<br>2'b01: clk_gpll_mux_gate<br>2'b10: clk_v0pll_mux_gate<br>2'b11: clk_v1pll_mux_gate |
| 4:0        | RW          | 0x03               | clk_flexport_tx_div<br>DT50 division register.<br>Divide clk_flexport_tx by (div_con + 1).                                                                           |

## CRU CLKSEL CON21

Address: Operational Base(0xFF9A0000) + offset (0x0354)

| <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:14      | RO          | 0x0                | reserved                                                                                                                           |
| 13:12      | RW          | 0x1                | hclk_bus_root_sel<br>hclk_bus_root clock mux.<br>2'b00: clk_gpll_div<br>2'b01: clk_v0pll_div<br>2'b10: clk_v1pll_div               |
| 11:7       | RW          | 0x00               | hclk_bus_root_div<br>Divide hclk_bus_root by (div_con + 1).                                                                        |
| 6:5        | RW          | 0x0                | ackl_bus_root_sel<br>ackl_bus_root clock mux.<br>2'b00: clk_gpll_div<br>2'b01: clk_v0pll_div<br>2'b10: clk_v1pll_div               |

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

**CRU CLKSEL CON22**

Address: Operational Base(0xFF9A0000) + offset (0x0358)

| <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:13      | RW          | 0x0                | clk_timer0_ch2_sel<br>clk_timer0_ch2 clock mux.<br>3'b000: xin_osc0_func<br>3'b001: clk_gpll_div_100m<br>3'b010: clk_deepslow<br>3'b011: clk_core_pvtpll_logic<br>3'b100: sai2_mclk_io_in<br>3'b101: sai2_sclk_io_in |
| 12:10      | RW          | 0x0                | clk_timer0_ch1_sel<br>clk_timer0_ch1 clock mux.<br>3'b000: xin_osc0_func<br>3'b001: clk_gpll_div_100m<br>3'b010: clk_deepslow<br>3'b011: clk_core_pvtpll_logic<br>3'b100: sai1_mclk_io_in<br>3'b101: sai1_sclk_io_in |
| 9:7        | RW          | 0x0                | clk_timer0_ch0_sel<br>clk_timer0_ch0 clock mux.<br>3'b000: xin_osc0_func<br>3'b001: clk_gpll_div_100m<br>3'b010: clk_deepslow<br>3'b011: clk_core_pvtpll_logic<br>3'b100: sai0_mclk_io_in<br>3'b101: sai0_sclk_io_in |
| 6:5        | RW          | 0x0                | pclk_bus_root_sel<br>pclk_bus_root clock mux.<br>2'b00: clk_gpll_div<br>2'b01: clk_v0pll_div<br>2'b10: clk_v1pll_div                                                                                                 |
| 4:0        | RW          | 0x01               | pclk_bus_root_div<br>Divide pclk_bus_root by (div_con + 1).                                                                                                                                                          |

**CRU CLKSEL CON23**

Address: Operational Base(0xFF9A0000) + offset (0x035C)

| <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         | RO          | 0x0                | reserved                                                                                                                                                                                                             |
| 14:9       | RW          | 0x01               | stclk_m0_div<br>Divide stclk_m0 by (div_con + 1).                                                                                                                                                                    |
| 8:6        | RW          | 0x0                | clk_timer0_ch5_sel<br>clk_timer0_ch5 clock mux.<br>3'b000: xin_osc0_func<br>3'b001: clk_gpll_div_100m<br>3'b010: clk_deepslow<br>3'b011: clk_core_pvtpll_logic<br>3'b100: mclk_asrc1                                 |
| 5:3        | RW          | 0x0                | clk_timer0_ch4_sel<br>clk_timer0_ch4 clock mux.<br>3'b000: xin_osc0_func<br>3'b001: clk_gpll_div_100m<br>3'b010: clk_deepslow<br>3'b011: clk_core_pvtpll_logic<br>3'b100: mclk_asrc0                                 |
| 2:0        | RW          | 0x0                | clk_timer0_ch3_sel<br>clk_timer0_ch3 clock mux.<br>3'b000: xin_osc0_func<br>3'b001: clk_gpll_div_100m<br>3'b010: clk_deepslow<br>3'b011: clk_core_pvtpll_logic<br>3'b100: sai3_mclk_io_in<br>3'b101: sai3_sclk_io_in |

### **CRU CLKSEL CON29**

Address: Operational Base(0xFF9A0000) + offset (0x0374)

| <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         | RO          | 0x0                | reserved                                                                                                                                                                                      |
| 14:12      | RW          | 0x0                | sclk_uart0_sel<br>sclk_uart0 clock mux.<br>3'b000: xin_osc0_func<br>3'b001: clk_gpll_mux_gate<br>3'b010: clk_v0pll_mux_gate<br>3'b011: clk_frac_uart_matrix0<br>3'b100: clk_frac_uart_matrix1 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------|
|            |             |                    | 3'b101: clk_frac_common_matrix0<br>3'b110: clk_frac_common_matrix1<br>3'b111: clk_frac_common_matrix2                      |
| 11:7       | RW          | 0x00               | sclk_uart0_div<br>Divide sclk_uart0 by (div_con + 1).                                                                      |
| 6:5        | RW          | 0x0                | hclk_lsperi_root_sel<br>hclk_lsperi_root clock mux.<br>2'b00: clk_gpll_div<br>2'b01: clk_v0pll_div<br>2'b10: clk_v1pll_div |
| 4:0        | RW          | 0x01               | hclk_lsperi_root_div<br>Divide hclk_lsperi_root by (div_con + 1).                                                          |

**CRU CLKSEL CON30**

Address: Operational Base(0xFF9A0000) + offset (0x0378)

| <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:13      | RW          | 0x0                | sclk_uart2_sel<br>sclk_uart2 clock mux.<br>3'b000: xin_osc0_func<br>3'b001: clk_gpll_mux_gate<br>3'b010: clk_v0pll_mux_gate<br>3'b011: clk_frac_uart_matrix0<br>3'b100: clk_frac_uart_matrix1<br>3'b101: clk_frac_common_matrix0<br>3'b110: clk_frac_common_matrix1<br>3'b111: clk_frac_common_matrix2 |
| 12:8       | RW          | 0x00               | sclk_uart2_div<br>Divide sclk_uart2 by (div_con + 1).                                                                                                                                                                                                                                                  |
| 7:5        | RW          | 0x0                | sclk_uart1_sel<br>sclk_uart1 clock mux.<br>3'b000: xin_osc0_func<br>3'b001: clk_gpll_mux_gate<br>3'b010: clk_v0pll_mux_gate<br>3'b011: clk_frac_uart_matrix0<br>3'b100: clk_frac_uart_matrix1<br>3'b101: clk_frac_common_matrix0<br>3'b110: clk_frac_common_matrix1<br>3'b111: clk_frac_common_matrix2 |
| 4:0        | RW          | 0x00               | sclk_uart1_div<br>Divide sclk_uart1 by (div_con + 1).                                                                                                                                                                                                                                                  |

**CRU CLKSEL CON31**

Address: Operational Base(0xFF9A0000) + offset (0x037C)

| <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:13      | RW          | 0x0                | sclk_uart4_sel<br>sclk_uart4 clock mux.<br>3'b000: xin_osc0_func<br>3'b001: clk_gpll_mux_gate<br>3'b010: clk_v0pll_mux_gate<br>3'b011: clk_frac_uart_matrix0<br>3'b100: clk_frac_uart_matrix1<br>3'b101: clk_frac_common_matrix0<br>3'b110: clk_frac_common_matrix1<br>3'b111: clk_frac_common_matrix2 |
| 12:8       | RW          | 0x00               | sclk_uart4_div<br>Divide sclk_uart4 by (div_con + 1).                                                                                                                                                                                                                                                  |
| 7:5        | RW          | 0x0                | sclk_uart3_sel<br>sclk_uart3 clock mux.<br>3'b000: xin_osc0_func<br>3'b001: clk_gpll_mux_gate<br>3'b010: clk_v0pll_mux_gate<br>3'b011: clk_frac_uart_matrix0<br>3'b100: clk_frac_uart_matrix1<br>3'b101: clk_frac_common_matrix0<br>3'b110: clk_frac_common_matrix1<br>3'b111: clk_frac_common_matrix2 |
| 4:0        | RW          | 0x00               | sclk_uart3_div<br>Divide sclk_uart3 by (div_con + 1).                                                                                                                                                                                                                                                  |

**CRU CLKSEL CON32**

Address: Operational Base(0xFF9A0000) + 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 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          | 0x1                | clk_i2c1_sel<br>clk_i2c1 clock mux.<br>2'b00: xin_osc0_func_gate<br>2'b01: clk_gpll_div<br>2'b10: clk_v0pll_div<br>2'b11: clk_v1pll_div |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 9:6        | RW          | 0x0                | clk_i2c1_div<br>Divide clk_i2c1 by (div_con + 1).                                                                                       |
| 5:4        | RW          | 0x1                | clk_i2c0_sel<br>clk_i2c0 clock mux.<br>2'b00: xin_osc0_func_gate<br>2'b01: clk_gpll_div<br>2'b10: clk_v0pll_div<br>2'b11: clk_v1pll_div |
| 3:0        | RW          | 0x0                | clk_i2c0_div<br>Divide clk_i2c0 by (div_con + 1).                                                                                       |

**CRU CLKSEL CON33**

Address: Operational Base(0xFF9A0000) + offset (0x0384)

| <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      | RW          | 0x0                | clk_freq_pwm1_sel<br>clk_freq_pwm1 clock mux.<br>4'b0000: clk_rc<br>4'b0001: sai0_mclk_io_in<br>4'b0010: sai1_mclk_io_in<br>4'b0011: sai2_mclk_io_in<br>4'b0100: sai3_mclk_io_in<br>4'b0101: sai0_sclk_io_in<br>4'b0110: sai1_sclk_io_in<br>4'b0111: sai2_sclk_io_in<br>4'b1000: sai3_sclk_io_in<br>4'b1001: mclk_asrc0<br>4'b1010: mclk_asrc1 |
| 11:10      | RW          | 0x0                | clk_pwm1_sel<br>clk_pwm1 clock mux.<br>2'b00: clk_gpll_div<br>2'b01: clk_v0pll_div<br>2'b10: clk_v1pll_div                                                                                                                                                                                                                                     |
| 9:6        | RW          | 0x1                | clk_pwm1_div<br>Divide clk_pwm1 by (div_con + 1).                                                                                                                                                                                                                                                                                              |
| 5:4        | RW          | 0x1                | clk_i2c2_sel<br>clk_i2c2 clock mux.<br>2'b00: xin_osc0_func_gate<br>2'b01: clk_gpll_div<br>2'b10: clk_v0pll_div<br>2'b11: clk_v1pll_div                                                                                                                                                                                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                |
|------------|-------------|--------------------|---------------------------------------------------|
| 3:0        | RW          | 0x0                | clk_i2c2_div<br>Divide clk_i2c2 by (div_con + 1). |

### **CRU CLKSEL CON34**

Address: Operational Base(0xFF9A0000) + offset (0x0388)

| <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:14      | RW          | 0x1                | clk_spi1_sel<br>clk_spi1 clock mux.<br>2'b00: xin_osc0_func_gate<br>2'b01: clk_gpll_div<br>2'b10: clk_v0pll_div<br>2'b11: clk_v1pll_div                                                                                                                                                                                                              |
| 13:10      | RW          | 0x0                | clk_spi1_div<br>Divide clk_spi1 by (div_con + 1).                                                                                                                                                                                                                                                                                                    |
| 9:8        | RW          | 0x1                | clk_spi0_sel<br>clk_spi0 clock mux.<br>2'b00: xin_osc0_func_gate<br>2'b01: clk_gpll_div<br>2'b10: clk_v0pll_div<br>2'b11: clk_v1pll_div                                                                                                                                                                                                              |
| 7:4        | RW          | 0x0                | clk_spi0_div<br>Divide clk_spi0 by (div_con + 1).                                                                                                                                                                                                                                                                                                    |
| 3:0        | RW          | 0x0                | clk_counter_pwm1_sel<br>clk_counter_pwm1 clock mux.<br>4'b0000: clk_rc<br>4'b0001: sai0_mclk_io_in<br>4'b0010: sai1_mclk_io_in<br>4'b0011: sai2_mclk_io_in<br>4'b0100: sai3_mclk_io_in<br>4'b0101: sai0_sclk_io_in<br>4'b0110: sai1_sclk_io_in<br>4'b0111: sai2_sclk_io_in<br>4'b1000: sai3_sclk_io_in<br>4'b1001: mclk_asrc0<br>4'b1010: mclk_asrc1 |

### **CRU CLKSEL CON35**

Address: Operational Base(0xFF9A0000) + offset (0x038C)

| <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:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                    |
| 13:11      | RW          | 0x2                | clk_can0_sel<br>clk_can0 clock mux.<br>3'b000: xin_osc0_func<br>3'b001: clk_gpll_mux<br>3'b010: clk_v0pll_mux_gate<br>3'b011: clk_v1pll_mux_gate<br>3'b100: clk_frac_voice_matrix1<br>3'b101: clk_frac_common_matrix0<br>3'b110: clk_frac_common_matrix1<br>3'b111: clk_frac_common_matrix2 |
| 10:6       | RW          | 0x03               | clk_can0_div<br>Divide clk_can0 by (div_con + 1).                                                                                                                                                                                                                                           |
| 5:4        | RW          | 0x0                | dbclk_gpio4_sel<br>dbclk_gpio4 clock mux.<br>2'b00: xin_osc0_func<br>2'b01: clk_rc<br>2'b10: clk_deepslow                                                                                                                                                                                   |
| 3:2        | RW          | 0x0                | dbclk_gpio3_sel<br>dbclk_gpio3 clock mux.<br>2'b00: xin_osc0_func<br>2'b01: clk_rc<br>2'b10: clk_deepslow                                                                                                                                                                                   |
| 1:0        | RW          | 0x0                | dbclk_gpio2_sel<br>dbclk_gpio2 clock mux.<br>2'b00: xin_osc0_func<br>2'b01: clk_rc<br>2'b10: clk_deepslow                                                                                                                                                                                   |

### **CRU CLKSEL CON36**

Address: Operational Base(0xFF9A0000) + offset (0x0390)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                           |
| 7:5        | RW          | 0x2                | clk_can1_sel<br>clk_can1 clock mux.<br>3'b000: xin_osc0_func<br>3'b001: clk_gpll_mux                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |             |                    | 3'b010: clk_v0pll_mux_gate<br>3'b011: clk_v1pll_mux_gate<br>3'b100: clk_frac_voice_matrix1<br>3'b101: clk_frac_common_matrix0<br>3'b110: clk_frac_common_matrix1<br>3'b111: clk_frac_common_matrix2 |
| 4:0        | RW          | 0x03               | clk_can1_div<br>Divide clk_can1 by (div_con + 1).                                                                                                                                                   |

### **CRU CLKSEL CON37**

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                                                                                                                                                                                                                  |
| 15:9       | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 8:5        | RW          | 0x1                | mclk_pdm_sel<br>mclk_pdm clock mux.<br>4'b0000: xin_osc0_func_gate<br>4'b0001: clk_int_voice_matrix0<br>4'b0010: clk_int_voice_matrix1<br>4'b0011: clk_int_voice_matrix2<br>4'b0100: clk_frac_voice_matrix0<br>4'b0101: clk_frac_voice_matrix1<br>4'b0110: clk_frac_common_matrix0<br>4'b0111: clk_frac_common_matrix1<br>4'b1000: clk_frac_common_matrix2<br>4'b1001: sai0_mclk_io_in<br>4'b1010: sai1_mclk_io_in<br>4'b1011: sai2_mclk_io_in<br>4'b1100: sai3_mclk_io_in<br>4'b1101: clk_gpll_div |
| 4:0        | RW          | 0x00               | mclk_pdm_div<br>Divide mclk_pdm by (div_con + 1).                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

### **CRU CLKSEL CON38**

Address: Operational Base(0xFF9A0000) + offset (0x0398)

| <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:14      | RO          | 0x0                | reserved                                                                                                                           |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:10 | RW   | 0x1         | clkout_pdm_sel<br>clkout_pdm clock mux.<br>4'b0000: xin_osc0_func_gate<br>4'b0001: clk_int_voice_matrix0<br>4'b0010: clk_int_voice_matrix1<br>4'b0011: clk_int_voice_matrix2<br>4'b0100: clk_frac_voice_matrix0<br>4'b0101: clk_frac_voice_matrix1<br>4'b0110: clk_frac_common_matrix0<br>4'b0111: clk_frac_common_matrix1<br>4'b1000: clk_frac_common_matrix2<br>4'b1001: sai0_mclk_io_in<br>4'b1010: sai1_mclk_io_in<br>4'b1011: sai2_mclk_io_in<br>4'b1100: sai3_mclk_io_in<br>4'b1101: clk_gpll_div |
| 9:0   | RW   | 0x01f       | clkout_pdm_div<br>DT50 division register.<br>Divide clkout_pdm by (div_con + 1).                                                                                                                                                                                                                                                                                                                                                                                                                        |

**CRU CLKSEL CON39**

Address: Operational Base(0xFF9A0000) + offset (0x039C)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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:14 | RW   | 0x1         | mclk_spdifrx_sel<br>mclk_spdifrx clock mux.<br>2'b00: clk_gpll_mux_gate<br>2'b01: clk_v0pll_mux_gate<br>2'b10: clk_v1pll_mux_gate                                                                                                                                                                                                                                  |
| 13:9  | RW   | 0x03        | mclk_spdifrx_div<br>Divide mclk_spdifrx by (div_con + 1).                                                                                                                                                                                                                                                                                                          |
| 8:5   | RW   | 0x1         | mclk_spdiftx_sel<br>mclk_spdiftx clock mux.<br>4'b0000: xin_osc0_func_gate<br>4'b0001: clk_int_voice_matrix0<br>4'b0010: clk_int_voice_matrix1<br>4'b0011: clk_int_voice_matrix2<br>4'b0100: clk_frac_voice_matrix0<br>4'b0101: clk_frac_voice_matrix1<br>4'b0110: clk_frac_common_matrix0<br>4'b0111: clk_frac_common_matrix1<br>4'b1000: clk_frac_common_matrix2 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------|
|            |             |                    | 4'b1001: sai0_mclk_io_in<br>4'b1010: sai1_mclk_io_in<br>4'b1011: sai2_mclk_io_in<br>4'b1100: sai3_mclk_io_in |
| 4:0        | RW          | 0x00               | mclk_spdiftx_div<br>Divide mclk_spdiftx by (div_con + 1).                                                    |

**CRU CLKSEL CON40**

Address: Operational Base(0xFF9A0000) + offset (0x03A0)

| <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:8       | RW          | 0x1                | mclk_sai0_sel<br>mclk_sai0 clock mux.<br>4'b0000: xin_osc0_func_gate<br>4'b0001: clk_int_voice_matrix0<br>4'b0010: clk_int_voice_matrix1<br>4'b0011: clk_int_voice_matrix2<br>4'b0100: clk_frac_voice_matrix0<br>4'b0101: clk_frac_voice_matrix1<br>4'b0110: clk_frac_common_matrix0<br>4'b0111: clk_frac_common_matrix1<br>4'b1000: clk_frac_common_matrix2<br>4'b1001: sai0_mclk_io_in<br>4'b1010: sai1_mclk_io_in<br>4'b1011: sai2_mclk_io_in<br>4'b1100: sai3_mclk_io_in |
| 7:0        | RW          | 0x00               | mclk_sai0_div<br>Divide mclk_sai0 by (div_con + 1).                                                                                                                                                                                                                                                                                                                                                                                                                          |

**CRU CLKSEL CON41**

Address: Operational Base(0xFF9A0000) + offset (0x03A4)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:8       | RW          | 0x1                | mclk_sai1_sel<br>mclk_sai1 clock mux.<br>4'b0000: xin_osc0_func_gate<br>4'b0001: clk_int_voice_matrix0<br>4'b0010: clk_int_voice_matrix1<br>4'b0011: clk_int_voice_matrix2<br>4'b0100: clk_frac_voice_matrix0<br>4'b0101: clk_frac_voice_matrix1<br>4'b0110: clk_frac_common_matrix0<br>4'b0111: clk_frac_common_matrix1<br>4'b1000: clk_frac_common_matrix2<br>4'b1001: sai0_mclk_io_in<br>4'b1010: sai1_mclk_io_in<br>4'b1011: sai2_mclk_io_in<br>4'b1100: sai3_mclk_io_in |
| 7:0        | RW          | 0x00               | mclk_sai1_div<br>Divide mclk_sai1 by (div_con + 1).                                                                                                                                                                                                                                                                                                                                                                                                                          |

### **CRU CLKSEL CON42**

Address: Operational Base(0xFF9A0000) + offset (0x03A8)

| <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:14      | RO          | 0x0                | reserved                                                                                                                           |
| 13:12      | RW          | 0x1                | clk_asrc1_sel<br>clk_asrc1 clock mux.<br>2'b00: clk_gpll_mux_gate<br>2'b01: clk_v0pll_mux_gate<br>2'b10: clk_v1pll_mux_gate        |
| 11:7       | RW          | 0x03               | clk_asrc1_div<br>Divide clk_asrc1 by (div_con + 1).                                                                                |
| 6:5        | RW          | 0x1                | clk_asrc0_sel<br>clk_asrc0 clock mux.<br>2'b00: clk_gpll_mux_gate<br>2'b01: clk_v0pll_mux_gate<br>2'b10: clk_v1pll_mux_gate        |
| 4:0        | RW          | 0x03               | clk_asrc0_div<br>Divide clk_asrc0 by (div_con + 1).                                                                                |

### **CRU CLKSEL CON46**

Address: Operational Base(0xFF9A0000) + offset (0x03B8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_enable<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                                                                                                                                                                        |
| 15:12      | RW          | 0x1                | <p>mclk_asrc3_sel<br/>mclk_asrc1 clock mux.<br/>4'b0000: xin_osc0_func_gate<br/>4'b0001: clk_int_voice_matrix0<br/>4'b0010: clk_int_voice_matrix1<br/>4'b0011: clk_int_voice_matrix2<br/>4'b0100: clk_frac_voice_matrix0<br/>4'b0101: clk_frac_voice_matrix1<br/>4'b0110: clk_frac_common_matrix0<br/>4'b0111: clk_frac_common_matrix1<br/>4'b1000: clk_frac_common_matrix2<br/>4'b1001: sai0_mclk_io_in<br/>4'b1010: sai1_mclk_io_in<br/>4'b1011: sai2_mclk_io_in<br/>4'b1100: sai3_mclk_io_in</p> |
| 11:8       | RW          | 0x1                | <p>mclk_asrc2_sel<br/>mclk_asrc0 clock mux.<br/>4'b0000: xin_osc0_func_gate<br/>4'b0001: clk_int_voice_matrix0<br/>4'b0010: clk_int_voice_matrix1<br/>4'b0011: clk_int_voice_matrix2<br/>4'b0100: clk_frac_voice_matrix0<br/>4'b0101: clk_frac_voice_matrix1<br/>4'b0110: clk_frac_common_matrix0<br/>4'b0111: clk_frac_common_matrix1<br/>4'b1000: clk_frac_common_matrix2<br/>4'b1001: sai0_mclk_io_in<br/>4'b1010: sai1_mclk_io_in<br/>4'b1011: sai2_mclk_io_in<br/>4'b1100: sai3_mclk_io_in</p> |
| 7:4        | RW          | 0x1                | <p>mclk_asrc1_sel<br/>mclk_asrc1 clock mux.<br/>4'b0000: xin_osc0_func_gate<br/>4'b0001: clk_int_voice_matrix0<br/>4'b0010: clk_int_voice_matrix1<br/>4'b0011: clk_int_voice_matrix2<br/>4'b0100: clk_frac_voice_matrix0<br/>4'b0101: clk_frac_voice_matrix1<br/>4'b0110: clk_frac_common_matrix0<br/>4'b0111: clk_frac_common_matrix1<br/>4'b1000: clk_frac_common_matrix2<br/>4'b1001: sai0_mclk_io_in</p>                                                                                        |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 4'b1010: sai1_mclk_io_in<br>4'b1011: sai2_mclk_io_in<br>4'b1100: sai3_mclk_io_in                                                                                                                                                                                                                                                                                                                                                                                               |
| 3:0 | RW   | 0x1         | mclk_asrc0_sel<br>mclk_asrc0 clock mux.<br>4'b0000: xin_osc0_func_gate<br>4'b0001: clk_int_voice_matrix0<br>4'b0010: clk_int_voice_matrix1<br>4'b0011: clk_int_voice_matrix2<br>4'b0100: clk_frac_voice_matrix0<br>4'b0101: clk_frac_voice_matrix1<br>4'b0110: clk_frac_common_matrix0<br>4'b0111: clk_frac_common_matrix1<br>4'b1000: clk_frac_common_matrix2<br>4'b1001: sai0_mclk_io_in<br>4'b1010: sai1_mclk_io_in<br>4'b1011: sai2_mclk_io_in<br>4'b1100: sai3_mclk_io_in |

**CRU\_CLKSEL\_CON47**

Address: Operational Base(0xFF9A0000) + offset (0x03BC)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                     |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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 | RW   | 0x0         | lrck_asrc1_dst_sel<br>lrck_asrc1_dst clock mux.<br>4'b0000: mclk_asrc0<br>4'b0001: mclk_asrc1<br>4'b0010: mclk_asrc0<br>4'b0011: mclk_asrc1<br>4'b0100: mclk_spdiftx<br>4'b0101: clk_spdifrx_to_asrc<br>4'b0110: clkout_pdm<br>4'b0111: sai0_fs<br>4'b1000: sai1_fs<br>4'b1001: sai2_fs<br>4'b1010: sai3_fs<br>4'b1011: sai4_fs |

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                     |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:8 | RW   | 0x0         | lrck_asrc1_src_sel<br>lrck_asrc1_src clock mux.<br>4'b0000: mclk_asrc0<br>4'b0001: mclk_asrc1<br>4'b0010: mclk_asrc0<br>4'b0011: mclk_asrc1<br>4'b0100: mclk_spdiftx<br>4'b0101: clk_spdifrx_to_asrc<br>4'b0110: clkout_pdm<br>4'b0111: sai0_fs<br>4'b1000: sai1_fs<br>4'b1001: sai2_fs<br>4'b1010: sai3_fs<br>4'b1011: sai4_fs |
| 7:4  | RW   | 0x0         | lrck_asrc0_dst_sel<br>lrck_asrc0_dst clock mux.<br>4'b0000: mclk_asrc0<br>4'b0001: mclk_asrc1<br>4'b0010: mclk_asrc0<br>4'b0011: mclk_asrc1<br>4'b0100: mclk_spdiftx<br>4'b0101: clk_spdifrx_to_asrc<br>4'b0110: clkout_pdm<br>4'b0111: sai0_fs<br>4'b1000: sai1_fs<br>4'b1001: sai2_fs<br>4'b1010: sai3_fs<br>4'b1011: sai4_fs |
| 3:0  | RW   | 0x0         | lrck_asrc0_src_sel<br>lrck_asrc0_src clock mux.<br>4'b0000: mclk_asrc0<br>4'b0001: mclk_asrc1<br>4'b0010: mclk_asrc0<br>4'b0011: mclk_asrc1<br>4'b0100: mclk_spdiftx<br>4'b0101: clk_spdifrx_to_asrc<br>4'b0110: clkout_pdm<br>4'b0111: sai0_fs<br>4'b1000: sai1_fs<br>4'b1001: sai2_fs<br>4'b1010: sai3_fs<br>4'b1011: sai4_fs |

**CRU CLKSEL CON49**

Address: Operational Base(0xFF9A0000) + offset (0x03C4)

| <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         | RO          | 0x0                | reserved                                                                                                                                                      |
| 14:13      | RW          | 0x2                | cclk_src_sdmmc_sel<br>cclk_src_sdmmc clock mux.<br>2'b00: xin_osc0_func_gate<br>2'b01: clk_gpll_mux<br>2'b10: clk_v0pll_mux_gate<br>2'b11: clk_v1pll_mux_gate |
| 12:7       | RW          | 0x03               | cclk_src_sdmmc_div<br>DT50 division register.<br>Divide cclk_src_sdmmc by (div_con + 1).                                                                      |
| 6:5        | RW          | 0x1                | aclk_hsperi_root_sel<br>aclk_hsperi_root clock mux.<br>2'b00: clk_gpll_div<br>2'b01: clk_v0pll_div<br>2'b10: clk_v1pll_div                                    |
| 4:0        | RW          | 0x00               | aclk_hsperi_root_div<br>Divide aclk_hsperi_root by (div_con + 1).                                                                                             |

### **CRU CLKSEL CON50**

Address: Operational Base(0xFF9A0000) + offset (0x03C8)

| <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:7       | RW          | 0x0f               | clk_mac_root_div<br>DT50 division register.<br>Divide clk_mac_root by (div_con + 1).                                                                     |
| 6:5        | RW          | 0x2                | sclk_fspi_sel<br>sclk_fspi clock mux.<br>2'b00: xin_osc0_func_gate<br>2'b01: clk_gpll_mux_gate<br>2'b10: clk_v0pll_mux_gate<br>2'b11: clk_v1pll_mux_gate |
| 4:0        | RW          | 0x09               | sclk_fspi_div<br>DT50 division register.<br>Divide sclk_fspi by (div_con + 1).                                                                           |

### **CRU CLKSEL CON51**

Address: Operational Base(0xFF9A0000) + offset (0x03CC)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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:8  | RW   | 0x1         | mclk_sai2_sel<br>mclk_sai2 clock mux.<br>4'b0000: xin_osc0_func_gate<br>4'b0001: clk_int_voice_matrix0<br>4'b0010: clk_int_voice_matrix1<br>4'b0011: clk_int_voice_matrix2<br>4'b0100: clk_frac_voice_matrix0<br>4'b0101: clk_frac_voice_matrix1<br>4'b0110: clk_frac_common_matrix0<br>4'b0111: clk_frac_common_matrix1<br>4'b1000: clk_frac_common_matrix2<br>4'b1001: sai0_mclk_io_in<br>4'b1010: sai1_mclk_io_in<br>4'b1011: sai2_mclk_io_in<br>4'b1100: sai3_mclk_io_in |
| 7:0   | RW   | 0x00        | mclk_sai2_div<br>Divide mclk_sai2 by (div_con + 1).                                                                                                                                                                                                                                                                                                                                                                                                                          |

**CRU CLKSEL CON52**

Address: Operational Base(0xFF9A0000) + offset (0x03D0)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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:8  | RW   | 0x1         | mclk_sai3_src_sel<br>mclk_sai3_src clock mux.<br>4'b0000: xin_osc0_func_gate<br>4'b0001: clk_int_voice_matrix0<br>4'b0010: clk_int_voice_matrix1<br>4'b0011: clk_int_voice_matrix2<br>4'b0100: clk_frac_voice_matrix0<br>4'b0101: clk_frac_voice_matrix1<br>4'b0110: clk_frac_common_matrix0<br>4'b0111: clk_frac_common_matrix1<br>4'b1000: clk_frac_common_matrix2<br>4'b1001: sai0_mclk_io_in<br>4'b1010: sai1_mclk_io_in<br>4'b1011: sai2_mclk_io_in |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
|            |             |                    | 4'b1100: sai3_mclk_io_in                                    |
| 7:0        | RW          | 0x00               | mclk_sai3_src_div<br>Divide mclk_sai3_src by (div_con + 1). |

**CRU CLKSEL CON53**

Address: Operational Base(0xFF9A0000) + offset (0x03D4)

| <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:8       | RW          | 0x1                | mclk_sai4_src_sel<br>mclk_sai4_src clock mux.<br>4'b0000: xin_osc0_func_gate<br>4'b0001: clk_int_voice_matrix0<br>4'b0010: clk_int_voice_matrix1<br>4'b0011: clk_int_voice_matrix2<br>4'b0100: clk_frac_voice_matrix0<br>4'b0101: clk_frac_voice_matrix1<br>4'b0110: clk_frac_common_matrix0<br>4'b0111: clk_frac_common_matrix1<br>4'b1000: clk_frac_common_matrix2<br>4'b1001: sai0_mclk_io_in<br>4'b1010: sai1_mclk_io_in<br>4'b1011: sai2_mclk_io_in<br>4'b1100: sai3_mclk_io_in |
| 7:0        | RW          | 0x01               | mclk_sai4_src_div<br>Divide mclk_sai4_src by (div_con + 1).                                                                                                                                                                                                                                                                                                                                                                                                                          |

**CRU CLKSEL CON54**

Address: Operational Base(0xFF9A0000) + offset (0x03D8)

| <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:14      | RO          | 0x0                | reserved                                                                                                                                                                                      |
| 13:11      | RW          | 0x0                | sclk_uart5_sel<br>sclk_uart5 clock mux.<br>3'b000: xin_osc0_func<br>3'b001: clk_gpll_mux_gate<br>3'b010: clk_v0pll_mux_gate<br>3'b011: clk_frac_uart_matrix0<br>3'b100: clk_frac_uart_matrix1 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------|
|            |             |                    | 3'b101: clk_frac_common_matrix0<br>3'b110: clk_frac_common_matrix1<br>3'b111: clk_frac_common_matrix2   |
| 10:6       | RW          | 0x00               | sclk_uart5_div<br>Divide sclk_uart5 by (div_con + 1).                                                   |
| 5:4        | RW          | 0x0                | clk_saradc_sel<br>clk_saradc clock mux.<br>2'b00: xin_osc0_func<br>2'b01: clk_rc<br>2'b10: clk_deepslow |
| 3:0        | RW          | 0x1                | clk_saradc_div<br>Divide clk_saradc by (div_con + 1).                                                   |

**CRU CLKSEL CON55**

Address: Operational Base(0xFF9A0000) + offset (0x03DC)

| <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:7       | RO          | 0x000              | reserved                                                                                                                           |
| 6:5        | RW          | 0x0                | clk_mac_ptp_root_sel<br>clk_mac_ptp_root clock mux.<br>2'b00: clk_gpll_mux<br>2'b01: clk_v0pll_mux<br>2'b10: clk_v1pll_mux         |
| 4:0        | RW          | 0x07               | clk_mac_ptp_root_div<br>Divide clk_mac_ptp_root by (div_con + 1).                                                                  |

**CRU CLKSEL CON58**

Address: Operational Base(0xFF9A0000) + offset (0x03E8)

| <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:14      | RO          | 0x0                | reserved                                                                                                                           |
| 13:12      | RW          | 0x0                | hclk_vio_root_sel<br>hclk_vio_root clock mux.<br>2'b00: clk_gpll_div<br>2'b01: clk_v0pll_div<br>2'b10: clk_v1pll_div               |
| 11:7       | RW          | 0x01               | hclk_vio_root_div<br>Divide hclk_vio_root by (div_con + 1).                                                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 6:5        | RW          | 0x1                | aclk_vio_root_sel<br>aclk_vio_root clock mux.<br>2'b00: clk_gpll_mux_gate<br>2'b01: clk_v0pll_mux_gate<br>2'b10: clk_v1pll_mux_gate |
| 4:0        | RW          | 0x03               | aclk_vio_root_div<br>Divide aclk_vio_root by (div_con + 1).                                                                         |

**CRU CLKSEL CON59**

Address: Operational Base(0xFF9A0000) + offset (0x03EC)

| <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:7       | RO          | 0x000              | reserved                                                                                                                           |
| 6:5        | RW          | 0x0                | clk_core_rga_sel<br>clk_core_rga clock mux.<br>2'b00: clk_gpll_mux_gate<br>2'b01: clk_v0pll_mux_gate<br>2'b10: clk_v1pll_mux_gate  |
| 4:0        | RW          | 0x01               | clk_core_rga_div<br>Divide clk_core_rga by (div_con + 1).                                                                          |

**CRU CLKSEL CON60**

Address: Operational Base(0xFF9A0000) + offset (0x03F0)

| <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:8       | RW          | 0x2                | dclk_vop_sel<br>dclk_vop clock mux.<br>3'b000: xin_osc0_func_gate<br>3'b001: clk_gpll_mux_gate<br>3'b010: clk_v0pll_mux_gate<br>3'b011: clk_v1pll_mux_gate<br>3'b100: clk_frac_voice_matrix1<br>3'b101: clk_frac_common_matrix0<br>3'b110: clk_frac_common_matrix1<br>3'b111: clk_frac_common_matrix2 |
| 7:0        | RW          | 0x09               | dclk_vop_div<br>Divide dclk_vop by (div_con + 1).                                                                                                                                                                                                                                                     |

**CRU CLKSEL CON61**

Address: Operational Base(0xFF9A0000) + offset (0x03F4)

| <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:8       | RW          | 0x1                | clk_tsadc_tsen_div<br>Divide clk_tsadc_tsen by (div_con + 1).                                                                      |
| 7:0        | RW          | 0x13               | clk_tsadc_div<br>Divide clk_tsadc by (div_con + 1).                                                                                |

**CRU GATE CON00**

Address: Operational Base(0xFF9A0000) + offset (0x0800)

| <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                | clk_frac_voice_matrix0_en<br>clk_frac_voice_matrix0 clock gating control.<br>When high, disable clock                              |
| 14         | RW          | 0x0                | clk_frac_uart_matrix1_en<br>clk_frac_uart_matrix1 clock gating control.<br>When high, disable clock                                |
| 13         | RW          | 0x0                | clk_frac_uart_matrix0_en<br>clk_frac_uart_matrix0 clock gating control.<br>When high, disable clock                                |
| 12         | RW          | 0x0                | clk_testout_en<br>clk_testout clock gating control.<br>When high, disable clock                                                    |
| 11         | RW          | 0x0                | clk_int_voice_matrix2_en<br>clk_int_voice_matrix2 clock gating control.<br>When high, disable clock                                |
| 10         | RW          | 0x0                | clk_int_voice_matrix1_en<br>clk_int_voice_matrix1 clock gating control.<br>When high, disable clock                                |
| 9          | RW          | 0x0                | clk_int_voice_matrix0_en<br>clk_int_voice_matrix0 clock gating control.<br>When high, disable clock                                |
| 8          | RW          | 0x0                | clk_v1pll_div_en<br>clk_v1pll_div clock gating control.<br>When high, disable clock                                                |

| Bit | Attr | Reset Value | Description                                                                                 |
|-----|------|-------------|---------------------------------------------------------------------------------------------|
| 7   | RW   | 0x0         | clk_v0pll_div_en<br>clk_v0pll_div clock gating control.<br>When high, disable clock         |
| 6   | RW   | 0x0         | clk_gpll_div_100m_en<br>clk_gpll_div_100m clock gating control.<br>When high, disable clock |
| 5   | RW   | 0x0         | clk_gpll_div_en<br>clk_gpll_div clock gating control.<br>When high, disable clock           |
| 4   | RW   | 0x0         | clk_v1pll_mux_en<br>clk_v1pll_mux_gate clock gating control.<br>When high, disable clock    |
| 3   | RW   | 0x0         | clk_v0pll_mux_en<br>clk_v0pll_mux_gate clock gating control.<br>When high, disable clock    |
| 2   | RW   | 0x0         | clk_gpll_mux_en<br>clk_gpll_mux_gate clock gating control.<br>When high, disable clock      |
| 1   | RW   | 0x0         | xin_osc0_func_en<br>xin_osc0_func_gate clock gating control.<br>When high, disable clock    |
| 0   | RO   | 0x0         | reserved                                                                                    |

**CRU GATE CON01**

Address: Operational Base(0xFF9A0000) + offset (0x0804)

| Bit   | Attr | Reset Value | Description                                                                                                                        |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| 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         | clk_ref_src_dphy_en<br>clk_ref_dphy_top clock gating control.<br>When high, disable clock                                          |
| 4     | RW   | 0x0         | clk_ref_src_usbphy_en<br>clk_ref_usbphy_top clock gating control.<br>When high, disable clock                                      |
| 3     | RW   | 0x0         | clk_frac_common_matrix2_en<br>clk_frac_common_matrix2 clock gating control.<br>When high, disable clock                            |
| 2     | RW   | 0x0         | clk_frac_common_matrix1_en<br>clk_frac_common_matrix1 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_frac_common_matrix0_en<br>clk_frac_common_matrix0 clock gating control.<br>When high, disable clock |
| 0          | RW          | 0x0                | clk_frac_voice_matrix1_en<br>clk_frac_voice_matrix1 clock gating control.<br>When high, disable clock   |

### **CRU GATE CON02**

Address: Operational Base(0xFF9A0000) + offset (0x0808)

| <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         | RO          | 0x0                | reserved                                                                                                                           |
| 14         | RW          | 0x0                | pclk_core_biu_en<br>pclk_core_biu clock gating control.<br>When high, disable clock                                                |
| 13         | RW          | 0x0                | ackl_core_biu_en<br>ackl_core_biu clock gating control.<br>When high, disable clock                                                |
| 12         | RW          | 0x0                | pclk_core_root_en<br>pclk_core_root clock gating control.<br>When high, disable clock                                              |
| 11         | RW          | 0x0                | ackl_core_root_en<br>ackl_core_root clock gating control.<br>When high, disable clock                                              |
| 10:2       | RO          | 0x000              | reserved                                                                                                                           |
| 1          | RW          | 0x0                | clk_core_en<br>clk_core clock gating control.<br>When high, disable clock                                                          |
| 0          | RW          | 0x0                | clk_core_div_en<br>clk_core_src_div clock gating control.<br>When high, disable clock                                              |

### **CRU GATE CON03**

Address: Operational Base(0xFF9A0000) + offset (0x080C)

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

| Bit | Attr | Reset Value | Description                                                                                     |
|-----|------|-------------|-------------------------------------------------------------------------------------------------|
| 9   | RW   | 0x0         | dbclk_gpio1_en<br>dbclk_gpio1 clock gating control.<br>When high, disable clock                 |
| 8   | RW   | 0x0         | pclk_gpio1_en<br>pclk_gpio1 clock gating control.<br>When high, disable clock                   |
| 7   | RW   | 0x0         | clk_ref_pvtpll_core_en<br>clk_ref_pvtpll_core clock gating control.<br>When high, disable clock |
| 6   | RW   | 0x0         | clk_core_ema_detect_en<br>clk_core_ema_detect clock gating control.<br>When high, disable clock |
| 5   | RO   | 0x0         | reserved                                                                                        |
| 4   | RW   | 0x0         | pclk_core_grf_en<br>pclk_core_grf clock gating control.<br>When high, disable clock             |
| 3   | RO   | 0x0         | reserved                                                                                        |
| 2   | RW   | 0x0         | swclk_tck_en<br>swclk_tck clock gating control.<br>When high, disable clock                     |
| 1   | RW   | 0x0         | pclk_dbg_en<br>pclk_dbg clock gating control.<br>When high, disable clock                       |
| 0   | RO   | 0x0         | reserved                                                                                        |

**CRU GATE CON04**

Address: Operational Base(0xFF9A0000) + offset (0x0810)

| Bit   | Attr | Reset Value | Description                                                                                                                        |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| 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:13 | RO   | 0x0         | reserved                                                                                                                           |
| 12    | RW   | 0x0         | hclk_dsmc_slv_en<br>hclk_dsmc_slv clock gating control.<br>When high, disable clock                                                |
| 11    | RW   | 0x0         | aclk_dsmc_slv_en<br>aclk_dsmc_slv clock gating control.<br>When high, disable clock                                                |
| 10    | RW   | 0x0         | hclk_flexport_en<br>hclk_flexport clock gating control.<br>When high, disable clock                                                |
| 9     | RW   | 0x0         | aclk_flexport_en<br>aclk_flexport clock gating control.<br>When high, disable clock                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------|
| 8          | RW          | 0x0                | clk_flexport_rx_en<br>clk_flexport_rx clock gating control.<br>When high, disable clock         |
| 7          | RW          | 0x0                | clk_flexport_tx_en<br>clk_flexport_tx clock gating control.<br>When high, disable clock         |
| 6          | RW          | 0x0                | pclk_dsmc_en<br>pclk_dsmc clock gating control.<br>When high, disable clock                     |
| 5          | RW          | 0x0                | ack_dsmc_en<br>ack_dsmc clock gating control.<br>When high, disable clock                       |
| 4          | RW          | 0x0                | clk_dsmc_en<br>clk_dsmc clock gating control.<br>When high, disable clock                       |
| 3          | RW          | 0x0                | ack_core_peri_biu_en<br>ack_core_peri_biu clock gating control.<br>When high, disable clock     |
| 2          | RW          | 0x0                | pclk_core_peri_root_en<br>pclk_core_peri_root clock gating control.<br>When high, disable clock |
| 1          | RW          | 0x0                | hclk_core_peri_root_en<br>hclk_core_peri_root clock gating control.<br>When high, disable clock |
| 0          | RW          | 0x0                | ack_core_peri_root_en<br>ack_core_peri_root clock gating control.<br>When high, disable clock   |

**CRU GATE CON05**

Address: Operational Base(0xFF9A0000) + offset (0x0814)

| <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                | hclk_crypto_en<br>hclk_crypto clock gating control.<br>When high, disable clock                                                    |
| 14         | RW          | 0x0                | ack_crypto_ns_en<br>ack_crypto_ns clock gating control.<br>When high, disable clock                                                |
| 13         | RW          | 0x0                | clk_pka_crypto_ns_en<br>clk_pka_crypto_ns clock gating control.<br>When high, disable clock                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------|
| 12         | RW          | 0x0                | clk_core_crypto_ns_en<br>clk_core_crypto_ns clock gating control.<br>When high, disable clock |
| 11         | RW          | 0x0                | swclk_tck_m0_en<br>swclk_tck_m0 clock gating control.<br>When high, disable clock             |
| 10         | RW          | 0x0                | hclk_m0_en<br>hclk_m0 clock gating control.<br>When high, disable clock                       |
| 9          | RW          | 0x0                | ackl_dmac1_en<br>ackl_dmac1 clock gating control.<br>When high, disable clock                 |
| 8          | RW          | 0x0                | ackl_dmac0_en<br>ackl_dmac0 clock gating control.<br>When high, disable clock                 |
| 7          | RW          | 0x0                | hclk_sysram_en<br>hclk_sysram clock gating control.<br>When high, disable clock               |
| 6          | RW          | 0x0                | ackl_sysram_en<br>ackl_sysram clock gating control.<br>When high, disable clock               |
| 5          | RW          | 0x0                | pclk_bus_biu_en<br>pclk_bus_biu clock gating control.<br>When high, disable clock             |
| 4          | RW          | 0x0                | hclk_bus_biu_en<br>hclk_bus_biu clock gating control.<br>When high, disable clock             |
| 3          | RW          | 0x0                | ackl_bus_biu_en<br>ackl_bus_biu clock gating control.<br>When high, disable clock             |
| 2          | RW          | 0x0                | pclk_bus_root_en<br>pclk_bus_root clock gating control.<br>When high, disable clock           |
| 1          | RW          | 0x0                | hclk_bus_root_en<br>hclk_bus_root clock gating control.<br>When high, disable clock           |
| 0          | RW          | 0x0                | ackl_bus_root_en<br>ackl_bus_root clock gating control.<br>When high, disable clock           |

**CRU\_GATE\_CON06**

Address: Operational Base(0xFF9A0000) + offset (0x0818)

| <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                | pclk_spinlock_en<br>pclk_spinlock clock gating control.<br>When high, disable clock                                                |
| 14         | RW          | 0x0                | pclk_intmux_en<br>pclk_intmux clock gating control.<br>When high, disable clock                                                    |
| 13         | RW          | 0x0                | pclk_mailbox_en<br>pclk_mailbox clock gating control.<br>When high, disable clock                                                  |
| 12         | RW          | 0x0                | tclk_wdt1_en<br>tclk_wdt1 clock gating control.<br>When high, disable clock                                                        |
| 11         | RW          | 0x0                | pclk_wdt1_en<br>pclk_wdt1 clock gating control.<br>When high, disable clock                                                        |
| 10         | RW          | 0x0                | tclk_wdt0_en<br>tclk_wdt0 clock gating control.<br>When high, disable clock                                                        |
| 9          | RW          | 0x0                | pclk_wdt0_en<br>pclk_wdt0 clock gating control.<br>When high, disable clock                                                        |
| 8          | RW          | 0x0                | clk_timer0_ch5_en<br>clk_timer0_ch5 clock gating control.<br>When high, disable clock                                              |
| 7          | RW          | 0x0                | clk_timer0_ch4_en<br>clk_timer0_ch4 clock gating control.<br>When high, disable clock                                              |
| 6          | RW          | 0x0                | clk_timer0_ch3_en<br>clk_timer0_ch3 clock gating control.<br>When high, disable clock                                              |
| 5          | RW          | 0x0                | clk_timer0_ch2_en<br>clk_timer0_ch2 clock gating control.<br>When high, disable clock                                              |
| 4          | RW          | 0x0                | clk_timer0_ch1_en<br>clk_timer0_ch1 clock gating control.<br>When high, disable clock                                              |
| 3          | RW          | 0x0                | clk_timer0_ch0_en<br>clk_timer0_ch0 clock gating control.<br>When high, disable clock                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | pclk_timer0_en<br>pclk_timer clock gating control.<br>When high, disable clock    |
| 1          | RW          | 0x0                | pclk_bus_grf_en<br>pclk_bus_grf clock gating control.<br>When high, disable clock |
| 0          | RW          | 0x0                | hclk_rng_en<br>hclk_rng clock gating control.<br>When high, disable clock         |

**CRU GATE CON07**

Address: Operational Base(0xFF9A0000) + offset (0x081C)

| <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                | pclk_usbphy_en<br>pclk_usbphy clock gating control.<br>When high, disable clock                                                    |
| 10         | RW          | 0x0                | clk_usbotg1_adp_en<br>clk_usbotg1_adp clock gating control.<br>When high, disable clock                                            |
| 9          | RW          | 0x0                | hclk_usbotg1_pmu_en<br>hclk_usbotg1_pmu clock gating control.<br>When high, disable clock                                          |
| 8          | RW          | 0x0                | hclk_usbotg1_en<br>hclk_usbotg1 clock gating control.<br>When high, disable clock                                                  |
| 7          | RW          | 0x0                | clk_usbotg0_adp_en<br>clk_usbotg0_adp clock gating control.<br>When high, disable clock                                            |
| 6          | RW          | 0x0                | hclk_usbotg0_pmu_en<br>hclk_usbotg0_pmu clock gating control.<br>When high, disable clock                                          |
| 5          | RW          | 0x0                | hclk_usbotg0_en<br>hclk_usbotg0 clock gating control.<br>When high, disable clock                                                  |
| 4          | RW          | 0x0                | pclk_ddr_lpc_en<br>pclk_stby clock gating control.<br>When high, disable clock                                                     |
| 3          | RW          | 0x0                | clk_ddrmon_osc_en<br>clk_ddrmon_osc clock gating control.<br>When high, disable clock                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | pclk_ddrmon_en<br>pclk_ddrmon clock gating control.<br>When high, disable clock |
| 1          | RW          | 0x0                | hclk_ddrphy_en<br>hclk_ddrphy clock gating control.<br>When high, disable clock |
| 0          | RW          | 0x0                | pclk_ddrc_en<br>pclk_ddrc clock gating control.<br>When high, disable clock     |

### **CRU GATE CON08**

Address: Operational Base(0xFF9A0000) + offset (0x0820)

| <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                | stclk_m0_en<br>stclk_m0 clock gating control.<br>When high, disable clock                                                          |
| 1          | RW          | 0x0                | pclk_dma2ddr_en<br>pclk_dma2ddr clock gating control.<br>When high, disable clock                                                  |
| 0          | RW          | 0x0                | ackl_dma2ddr_en<br>ackl_dma2ddr clock gating control.<br>When high, disable clock                                                  |

### **CRU GATE CON10**

Address: Operational Base(0xFF9A0000) + offset (0x0828)

| <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                | clk_ddrmon_en<br>clk_ddrmon clock gating control.<br>When high, disable clock                                                      |
| 3          | RW          | 0x0                | clk_ddrc_en<br>clk_ddrc clock gating control.<br>When high, disable clock                                                          |
| 2          | RW          | 0x0                | ackl_ddr_biu_en<br>ackl_ddr_biu clock gating control.<br>When high, disable clock                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | aclk_ddrc_1_en<br>aclk_ddrc_1 clock gating control.<br>When high, disable clock |
| 0          | RW          | 0x0                | aclk_ddrc_0_en<br>aclk_ddrc_0 clock gating control.<br>When high, disable clock |

**CRU GATE CON11**

Address: Operational Base(0xFF9A0000) + offset (0x082C)

| <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                | clk_i2c0_en<br>clk_i2c0 clock gating control.<br>When high, disable clock                                                          |
| 14         | RW          | 0x0                | pclk_i2c0_en<br>pclk_i2c0 clock gating control.<br>When high, disable clock                                                        |
| 13         | RW          | 0x0                | sclk_uart4_src_en<br>sclk_uart4 clock gating control.<br>When high, disable clock                                                  |
| 12         | RW          | 0x0                | sclk_uart3_src_en<br>sclk_uart3 clock gating control.<br>When high, disable clock                                                  |
| 11         | RW          | 0x0                | sclk_uart2_src_en<br>sclk_uart2 clock gating control.<br>When high, disable clock                                                  |
| 10         | RW          | 0x0                | sclk_uart1_src_en<br>sclk_uart1 clock gating control.<br>When high, disable clock                                                  |
| 9          | RW          | 0x0                | sclk_uart0_src_en<br>sclk_uart0 clock gating control.<br>When high, disable clock                                                  |
| 8          | RW          | 0x0                | pclk_uart4_en<br>pclk_uart4 clock gating control.<br>When high, disable clock                                                      |
| 7          | RW          | 0x0                | pclk_uart3_en<br>pclk_uart3 clock gating control.<br>When high, disable clock                                                      |
| 6          | RW          | 0x0                | pclk_uart2_en<br>pclk_uart2 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_uart1_en<br>pclk_uart1 clock gating control.<br>When high, disable clock             |
| 4          | RW          | 0x0                | pclk_uart0_en<br>pclk_uart0 clock gating control.<br>When high, disable clock             |
| 3          | RO          | 0x0                | reserved                                                                                  |
| 2          | RW          | 0x0                | hclk_lsperi_biu_en<br>hclk_lsperi_biu clock gating control.<br>When high, disable clock   |
| 1          | RW          | 0x0                | pclk_lsperi_root_en<br>pclk_lsperi_root clock gating control.<br>When high, disable clock |
| 0          | RW          | 0x0                | hclk_lsperi_root_en<br>hclk_lsperi_root clock gating control.<br>When high, disable clock |

**CRU GATE CON12**

Address: Operational Base(0xFF9A0000) + offset (0x0830)

| <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                | dbclk_gpio2_en<br>dbclk_gpio2 clock gating control.<br>When high, disable clock                                                    |
| 14         | RW          | 0x0                | pclk_gpio2_en<br>pclk_gpio2 clock gating control.<br>When high, disable clock                                                      |
| 13         | RW          | 0x0                | clk_spi1_en<br>clk_spi1 clock gating control.<br>When high, disable clock                                                          |
| 12         | RW          | 0x0                | pclk_spi1_en<br>pclk_spi1 clock gating control.<br>When high, disable clock                                                        |
| 11         | RW          | 0x0                | clk_spi0_en<br>clk_spi0 clock gating control.<br>When high, disable clock                                                          |
| 10         | RW          | 0x0                | pclk_spi0_en<br>pclk_spi0 clock gating control.<br>When high, disable clock                                                        |
| 9          | RW          | 0x0                | clk_counter_pwm1_en<br>clk_counter_pwm1 clock gating control.<br>When high, disable clock                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 8          | RW          | 0x0                | clk_freq_pwm1_en<br>clk_freq_pwm1 clock gating control.<br>When high, disable clock |
| 7          | RW          | 0x0                | clk_rc_pwm1_en<br>clk_rc_pwm1 clock gating control.<br>When high, disable clock     |
| 6          | RW          | 0x0                | clk_osc_pwm1_en<br>clk_osc_pwm1 clock gating control.<br>When high, disable clock   |
| 5          | RW          | 0x0                | clk_pwm1_en<br>clk_pwm1 clock gating control.<br>When high, disable clock           |
| 4          | RW          | 0x0                | pclk_pwm1_en<br>pclk_pwm1 clock gating control.<br>When high, disable clock         |
| 3          | RW          | 0x0                | clk_i2c2_en<br>clk_i2c2 clock gating control.<br>When high, disable clock           |
| 2          | RW          | 0x0                | pclk_i2c2_en<br>pclk_i2c2 clock gating control.<br>When high, disable clock         |
| 1          | RW          | 0x0                | clk_i2c1_en<br>clk_i2c1 clock gating control.<br>When high, disable clock           |
| 0          | RW          | 0x0                | pclk_i2c1_en<br>pclk_i2c1 clock gating control.<br>When high, disable clock         |

**CRU GATE CON13**

Address: Operational Base(0xFF9A0000) + offset (0x0834)

| <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                | mclk_sai0_en<br>mclk_sai0 clock gating control.<br>When high, disable clock                                                        |
| 14         | RW          | 0x0                | mclk_spdifrx_en<br>mclk_spdifrx clock gating control.<br>When high, disable clock                                                  |
| 13         | RW          | 0x0                | hclk_spdifrx_en<br>hclk_spdifrx 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_spdiftx_en<br>hclk_spdiftx clock gating control.<br>When high, disable clock |
| 11         | RW          | 0x0                | mclk_spdiftx_en<br>mclk_spdiftx clock gating control.<br>When high, disable clock |
| 10         | RW          | 0x0                | clkout_pdm_en<br>clkout_pdm clock gating control.<br>When high, disable clock     |
| 9          | RW          | 0x0                | mclk_pdm_en<br>mclk_pdm clock gating control.<br>When high, disable clock         |
| 8          | RW          | 0x0                | hclk_pdm_en<br>hclk_pdm clock gating control.<br>When high, disable clock         |
| 7          | RW          | 0x0                | clk_can1_en<br>clk_can1 clock gating control.<br>When high, disable clock         |
| 6          | RW          | 0x0                | pclk_can1_en<br>hclk_can1 clock gating control.<br>When high, disable clock       |
| 5          | RW          | 0x0                | clk_can0_en<br>clk_can0 clock gating control.<br>When high, disable clock         |
| 4          | RW          | 0x0                | pclk_can0_en<br>hclk_can0 clock gating control.<br>When high, disable clock       |
| 3          | RW          | 0x0                | dbclk_gpio4_en<br>dbclk_gpio4 clock gating control.<br>When high, disable clock   |
| 2          | RW          | 0x0                | pclk_gpio4_en<br>pclk_gpio4 clock gating control.<br>When high, disable clock     |
| 1          | RW          | 0x0                | dbclk_gpio3_en<br>dbclk_gpio3 clock gating control.<br>When high, disable clock   |
| 0          | RW          | 0x0                | pclk_gpio3_en<br>pclk_gpio3 clock gating control.<br>When high, disable clock     |

**CRU\_GATE\_CON14**

Address: Operational Base(0xFF9A0000) + offset (0x0838)

| <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                | pclk_pmu_root_en<br>pclk_pmu_root clock gating control.<br>When high, disable clock                                                |
| 9          | RW          | 0x0                | pclk_cru_en<br>pclk_cru clock gating control.<br>When high, disable clock                                                          |
| 8          | RW          | 0x0                | clk_asrc1_en<br>clk_asrc1 clock gating control.<br>When high, disable clock                                                        |
| 7          | RW          | 0x0                | hclk_asrc1_en<br>hclk_asrc1 clock gating control.<br>When high, disable clock                                                      |
| 6          | RW          | 0x0                | clk_asrc0_en<br>clk_asrc0 clock gating control.<br>When high, disable clock                                                        |
| 5          | RW          | 0x0                | hclk_asrc0_en<br>hclk_asrc0 clock gating control.<br>When high, disable clock                                                      |
| 4          | RW          | 0x0                | mclk_out_sai1_en<br>mclk_out_sai1 clock gating control.<br>When high, disable clock                                                |
| 3          | RW          | 0x0                | hclk_sai1_en<br>hclk_sai1 clock gating control.<br>When high, disable clock                                                        |
| 2          | RW          | 0x0                | mclk_sai1_en<br>mclk_sai1 clock gating control.<br>When high, disable clock                                                        |
| 1          | RW          | 0x0                | mclk_out_sai0_en<br>mclk_out_sai0 clock gating control.<br>When high, disable clock                                                |
| 0          | RW          | 0x0                | hclk_sai0_en<br>hclk_sai0 clock gating control.<br>When high, disable clock                                                        |

### **CRU GATE CON16**

Address: Operational Base(0xFF9A0000) + offset (0x0840)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                           |
| 7          | RW          | 0x0                | Irck_asrc1_dst_en<br>Irck_asrc1_dst clock gating control.<br>When high, disable clock                                              |
| 6          | RW          | 0x0                | Irck_asrc1_src_en<br>Irck_asrc1_src clock gating control.<br>When high, disable clock                                              |
| 5          | RW          | 0x0                | Irck_asrc0_dst_en<br>Irck_asrc0_dst clock gating control.<br>When high, disable clock                                              |
| 4          | RW          | 0x0                | Irck_asrc0_src_en<br>Irck_asrc0_src clock gating control.<br>When high, disable clock                                              |
| 3          | RW          | 0x0                | mclk_asrc3_src_en<br>mclk_asrc1 clock gating control.<br>When high, disable clock                                                  |
| 2          | RW          | 0x0                | mclk_asrc2_src_en<br>mclk_asrc0 clock gating control.<br>When high, disable clock                                                  |
| 1          | RW          | 0x0                | mclk_asrc1_src_en<br>mclk_asrc1 clock gating control.<br>When high, disable clock                                                  |
| 0          | RW          | 0x0                | mclk_asrc0_src_en<br>mclk_asrc0 clock gating control.<br>When high, disable clock                                                  |

### **CRU GATE CON17**

Address: Operational Base(0xFF9A0000) + offset (0x0844)

| <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                | clk_mac_root_en<br>clk_mac_root clock gating control.<br>When high, disable clock                                                  |
| 14         | RW          | 0x0                | pclk_mac1_en<br>pclk_mac1 clock gating control.<br>When high, disable clock                                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------|
| 13         | RW          | 0x0                | pclk_mac0_en<br>pclk_mac0 clock gating control.<br>When high, disable clock               |
| 12         | RW          | 0x0                | ackl_mac1_en<br>ackl_mac1 clock gating control.<br>When high, disable clock               |
| 11         | RW          | 0x0                | ackl_mac0_en<br>ackl_mac0 clock gating control.<br>When high, disable clock               |
| 10         | RW          | 0x0                | pclk_spi2_en<br>pclk_spi2 clock gating control.<br>When high, disable clock               |
| 9          | RW          | 0x0                | sclk_fspi_en<br>sclk_fspi clock gating control.<br>When high, disable clock               |
| 8          | RW          | 0x0                | hclk_fspi_en<br>hclk_fspi clock gating control.<br>When high, disable clock               |
| 7          | RW          | 0x0                | hclk_sdmmc_en<br>hclk_sdmmc clock gating control.<br>When high, disable clock             |
| 6          | RW          | 0x0                | cclk_src_sdmmc_en<br>cclk_src_sdmmc clock gating control.<br>When high, disable clock     |
| 5          | RO          | 0x0                | reserved                                                                                  |
| 4          | RW          | 0x0                | hclk_hsperi_biu_en<br>hclk_hsperi_biu clock gating control.<br>When high, disable clock   |
| 3          | RO          | 0x0                | reserved                                                                                  |
| 2          | RW          | 0x0                | pclk_hsperi_root_en<br>pclk_hsperi_root clock gating control.<br>When high, disable clock |
| 1          | RW          | 0x0                | hclk_hsperi_root_en<br>hclk_hsperi_root clock gating control.<br>When high, disable clock |
| 0          | RW          | 0x0                | ackl_hsperiroot_en<br>ackl_hsperi_root clock gating control.<br>When high, disable clock  |

### **CRU GATE CON18**

Address: Operational Base(0xFF9A0000) + offset (0x0848)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------|
|            |             |                    | 1'b1: Write access enable                                                             |
| 15         | RW          | 0x0                | mclk_audio_adc_en<br>mclk_audio_adc clock gating control.<br>When high, disable clock |
| 14         | RW          | 0x0                | pclk_audio_adc_en<br>pclk_audio_adc clock gating control.<br>When high, disable clock |
| 13         | RW          | 0x0                | mclk_dsm_en<br>mclk_dsm clock gating control.<br>When high, disable clock             |
| 12         | RW          | 0x0                | hclk_dsm_en<br>hclk_dsm clock gating control.<br>When high, disable clock             |
| 11         | RW          | 0x0                | mclk_sai4_en<br>mclk_sai4 clock gating control.<br>When high, disable clock           |
| 10         | RW          | 0x0                | hclk_sai4_en<br>hclk_sai4 clock gating control.<br>When high, disable clock           |
| 9          | RW          | 0x0                | mclk_sai4_src_en<br>mclk_sai4_src clock gating control.<br>When high, disable clock   |
| 8          | RW          | 0x0                | mclk_out_sai3_en<br>mclk_out_sai3 clock gating control.<br>When high, disable clock   |
| 7          | RW          | 0x0                | mclk_sai3_en<br>mclk_sai3 clock gating control.<br>When high, disable clock           |
| 6          | RW          | 0x0                | hclk_sai3_en<br>hclk_sai3 clock gating control.<br>When high, disable clock           |
| 5          | RW          | 0x0                | mclk_sai3_src_en<br>mclk_sai3_src clock gating control.<br>When high, disable clock   |
| 4          | RW          | 0x0                | mclk_out_sai2_en<br>mclk_out_sai2 clock gating control.<br>When high, disable clock   |
| 3          | RW          | 0x0                | hclk_sai2_en<br>hclk_sai2 clock gating control.<br>When high, disable clock           |
| 2          | RW          | 0x0                | mclk_sai2_en<br>mclk_sai2 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_mac1_en<br>clk_mac1 clock gating control.<br>When high, disable clock |
| 0          | RW          | 0x0                | clk_mac0_en<br>clk_mac0 clock gating control.<br>When high, disable clock |

**CRU GATE CON19**

Address: Operational Base(0xFF9A0000) + offset (0x084C)

| <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                | clk_mac1_ptp_en<br>clk_mac1_ptp clock gating control.<br>When high, disable clock                                                  |
| 10         | RW          | 0x0                | clk_mac0_ptp_en<br>clk_mac0_ptp clock gating control.<br>When high, disable clock                                                  |
| 9          | RW          | 0x0                | clk_mac_ptp_root_en<br>clk_mac_ptp_root clock gating control.<br>When high, disable clock                                          |
| 8          | RW          | 0x0                | pclk_gpio234_ioc_en<br>pclk_gpio234_ioc clock gating control.<br>When high, disable clock                                          |
| 7          | RW          | 0x0                | sclk_uart5_en<br>sclk_uart5 clock gating control.<br>When high, disable clock                                                      |
| 6          | RW          | 0x0                | pclk_uart5_en<br>pclk_uart5 clock gating control.<br>When high, disable clock                                                      |
| 5          | RO          | 0x0                | reserved                                                                                                                           |
| 4          | RW          | 0x0                | clk_sbpi_otpc_ns_en<br>clk_sbpi_otpc_ns clock gating control.<br>When high, disable clock                                          |
| 3          | RW          | 0x0                | pclk_otpc_ns_en<br>pclk_otpc_ns clock gating control.<br>When high, disable clock                                                  |
| 2          | RO          | 0x0                | reserved                                                                                                                           |
| 1          | RW          | 0x0                | clk_saradc_en<br>clk_saradc clock gating control.<br>When high, disable clock                                                      |

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

### **CRU GATE CON20**

Address: Operational Base(0xFF9A0000) + offset (0x0850)

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

### **CRU GATE CON21**

Address: Operational Base(0xFF9A0000) + offset (0x0854)

| <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                | clk_tsadc_en<br>clk_tsadc clock gating control.<br>When high, disable clock                                                        |
| 14         | RW          | 0x0                | pclk_tsadc_en<br>pclk_tsadc clock gating control.<br>When high, disable clock                                                      |
| 13         | RW          | 0x0                | pclk_dsi_host_en<br>pclk_dsi_host clock gating control.<br>When high, disable clock                                                |
| 12         | RW          | 0x0                | pclk_dphy_en<br>pclk_dphy clock gating control.<br>When high, disable clock                                                        |
| 11         | RW          | 0x0                | dclk_vop_en<br>dclk_vop 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                | ack_vop_en<br>ack_vop clock gating control.<br>When high, disable clock                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 8          | RW          | 0x0                | clk_core_rga_en<br>clk_core_rga clock gating control.<br>When high, disable clock   |
| 7          | RW          | 0x0                | ackl_rga_en<br>ackl_rga clock gating control.<br>When high, disable clock           |
| 6          | RW          | 0x0                | hclk_rga_en<br>hclk_rga clock gating control.<br>When high, disable clock           |
| 5          | RO          | 0x0                | reserved                                                                            |
| 4          | RW          | 0x0                | hclk_vio_biu_en<br>hclk_vio_biu clock gating control.<br>When high, disable clock   |
| 3          | RW          | 0x0                | ackl_vio_biu_en<br>ackl_vio_biu clock gating control.<br>When high, disable clock   |
| 2          | RW          | 0x0                | pclk_vio_root_en<br>pclk_vio_root clock gating control.<br>When high, disable clock |
| 1          | RW          | 0x0                | hclk_vio_root_en<br>hclk_vio_root clock gating control.<br>When high, disable clock |
| 0          | RW          | 0x0                | ackl_vio_root_en<br>ackl_vio_root clock gating control.<br>When high, disable clock |

### **CRU GATE CON22**

Address: Operational Base(0xFF9A0000) + offset (0x0858)

| <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:2       | RO          | 0x0000             | reserved                                                                                                                           |
| 1          | RW          | 0x0                | pclk_gpio1_ioc_en<br>pclk_gpio1_ioc clock gating control.<br>When high, disable clock                                              |
| 0          | RW          | 0x0                | clk_tsadc_tsen_en<br>clk_tsadc_tsen clock gating control.<br>When high, disable clock                                              |

### **CRU SOFTRST CON00**

Address: Operational Base(0xFF9A0000) + offset (0x0A00)

| <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         | W1T         | 0x0                | hresetn_m0_ac<br>When high, reset relative logic                                                                                   |
| 9          | W1T         | 0x0                | aresetn_core_biu_ac<br>When high, reset relative logic                                                                             |
| 8          | W1T         | 0x0                | nl2reset_ac<br>When high, reset relative logic                                                                                     |
| 7          | RO          | 0x0                | reserved                                                                                                                           |
| 6          | W1T         | 0x0                | ncoreset2_ac<br>When high, reset relative logic                                                                                    |
| 5          | W1T         | 0x0                | ncoreset1_ac<br>When high, reset relative logic                                                                                    |
| 4          | W1T         | 0x0                | ncoreset0_ac<br>When high, reset relative logic                                                                                    |
| 3          | RO          | 0x0                | reserved                                                                                                                           |
| 2          | W1T         | 0x0                | ncoreporeset2_ac<br>When high, reset relative logic                                                                                |
| 1          | W1T         | 0x0                | ncoreporeset1_ac<br>When high, reset relative logic                                                                                |
| 0          | W1T         | 0x0                | ncoreporeset0_ac<br>When high, reset relative logic                                                                                |

### **CRU SOFTRST CON02**

Address: Operational Base(0xFF9A0000) + offset (0x0A08)

| <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                | resetn_pmu<br>When high, reset relative logic                                                                                      |
| 14         | RW          | 0x0                | presetn_core_biu<br>When high, reset relative logic                                                                                |
| 13:11      | RO          | 0x0                | reserved                                                                                                                           |
| 10         | RW          | 0x0                | ndbgreset<br>When high, reset relative logic                                                                                       |
| 9:0        | RO          | 0x000              | reserved                                                                                                                           |

### **CRU SOFTRST CON03**

Address: Operational Base(0xFF9A0000) + offset (0x0A0C)

| <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:10      | RO          | 0x00               | reserved                                                                                                                           |
| 9          | RW          | 0x0                | dbresetn_gpio1<br>When high, reset relative logic                                                                                  |
| 8          | RW          | 0x0                | presetn_gpio1<br>When high, reset relative logic                                                                                   |
| 7          | RW          | 0x0                | resetn_ref_pvtpll_core<br>When high, reset relative logic                                                                          |
| 6          | RW          | 0x0                | resetn_core_ema_detect<br>When high, reset relative logic                                                                          |
| 5          | RO          | 0x0                | reserved                                                                                                                           |
| 4          | RW          | 0x0                | presetn_core_grf<br>When high, reset relative logic                                                                                |
| 3          | RO          | 0x0                | reserved                                                                                                                           |
| 2          | RW          | 0x0                | potresetn_dbg<br>When high, reset relative logic                                                                                   |
| 1          | RW          | 0x0                | presetn_dbg<br>When high, reset relative logic                                                                                     |
| 0          | RO          | 0x0                | reserved                                                                                                                           |

**CRU SOFTRST CON04**

Address: Operational Base(0xFF9A0000) + offset (0x0A10)

| <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:14      | RO          | 0x0                | reserved                                                                                                                           |
| 13         | RW          | 0x0                | resetn_dsmc_slv<br>When high, reset relative logic                                                                                 |
| 12         | RW          | 0x0                | hresetn_dsmc_slv<br>When high, reset relative logic                                                                                |
| 11         | RW          | 0x0                | aresetn_dsmc_slv<br>When high, reset relative logic                                                                                |
| 10         | RW          | 0x0                | hresetn_flexport<br>When high, reset relative logic                                                                                |
| 9          | RW          | 0x0                | aresetn_flexport<br>When high, reset relative logic                                                                                |
| 8          | RO          | 0x0                | reserved                                                                                                                           |
| 7          | RW          | 0x0                | resetn_flexport<br>When high, reset relative logic                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 6          | RW          | 0x0                | presetn_dsmc<br>When high, reset relative logic          |
| 5          | RW          | 0x0                | aresetn_dsmc<br>When high, reset relative logic          |
| 4          | RO          | 0x0                | reserved                                                 |
| 3          | RW          | 0x0                | aresetn_core_peri_biu<br>When high, reset relative logic |
| 2:0        | RO          | 0x0                | reserved                                                 |

**CRU SOFTRST CON05**

Address: Operational Base(0xFF9A0000) + offset (0x0A14)

| <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                | hresetn_crypto<br>When high, reset relative logic                                                                                  |
| 14:12      | RO          | 0x0                | reserved                                                                                                                           |
| 11         | RW          | 0x0                | resetn_m0_jtag<br>When high, reset relative logic                                                                                  |
| 10         | RW          | 0x0                | hresetn_m0<br>When high, reset relative logic                                                                                      |
| 9          | RW          | 0x0                | aresetn_dmac1<br>When high, reset relative logic                                                                                   |
| 8          | RW          | 0x0                | aresetn_dmac0<br>When high, reset relative logic                                                                                   |
| 7          | RW          | 0x0                | hresetn_sysram<br>When high, reset relative logic                                                                                  |
| 6          | RW          | 0x0                | aresetn_sysram<br>When high, reset relative logic                                                                                  |
| 5          | RW          | 0x0                | presetn_bus_biu<br>When high, reset relative logic                                                                                 |
| 4          | RW          | 0x0                | hresetn_bus_biu<br>When high, reset relative logic                                                                                 |
| 3          | RW          | 0x0                | aresetn_bus_biu<br>When high, reset relative logic                                                                                 |
| 2:0        | RO          | 0x0                | reserved                                                                                                                           |

**CRU SOFTRST CON06**

Address: Operational Base(0xFF9A0000) + offset (0x0A18)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
|            |             |                    | 1'b1: Write access enable                            |
| 15         | RW          | 0x0                | presetn_spinlock<br>When high, reset relative logic  |
| 14         | RW          | 0x0                | presetn_intmux<br>When high, reset relative logic    |
| 13         | RW          | 0x0                | presetn_mailbox<br>When high, reset relative logic   |
| 12         | RW          | 0x0                | tresetn_wdt1<br>When high, reset relative logic      |
| 11         | RW          | 0x0                | presetn_wdt1<br>When high, reset relative logic      |
| 10         | RW          | 0x0                | tresetn_wdt0<br>When high, reset relative logic      |
| 9          | RW          | 0x0                | presetn_wdt0<br>When high, reset relative logic      |
| 8          | RW          | 0x0                | resetn_timer0_ch5<br>When high, reset relative logic |
| 7          | RW          | 0x0                | resetn_timer0_ch4<br>When high, reset relative logic |
| 6          | RW          | 0x0                | resetn_timer0_ch3<br>When high, reset relative logic |
| 5          | RW          | 0x0                | resetn_timer0_ch2<br>When high, reset relative logic |
| 4          | RW          | 0x0                | resetn_timer0_ch1<br>When high, reset relative logic |
| 3          | RW          | 0x0                | resetn_timer0_ch0<br>When high, reset relative logic |
| 2          | RW          | 0x0                | presetn_timer0<br>When high, reset relative logic    |
| 1          | RW          | 0x0                | presetn_bus_grf<br>When high, reset relative logic   |
| 0          | RW          | 0x0                | hresetn_rng<br>When high, reset relative logic       |

### **CRU SOFTRST CON07**

Address: Operational Base(0xFF9A0000) + offset (0x0A1C)

| <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         | RO          | 0x0                | reserved                                                                                                                           |
| 14         | RW          | 0x0                | resetn_usbphy_otg1<br>When high, reset relative logic                                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 13         | RW          | 0x0                | resetn_usbphy_otg0<br>When high, reset relative logic |
| 12         | RW          | 0x0                | resetn_usbphy_por<br>When high, reset relative logic  |
| 11         | RW          | 0x0                | presetn_usbphy<br>When high, reset relative logic     |
| 10         | RW          | 0x0                | resetn_usbotg1_adp<br>When high, reset relative logic |
| 9          | RO          | 0x0                | reserved                                              |
| 8          | RW          | 0x0                | hresetn_usbotg1<br>When high, reset relative logic    |
| 7          | RW          | 0x0                | resetn_usbotg0_adp<br>When high, reset relative logic |
| 6          | RO          | 0x0                | reserved                                              |
| 5          | RW          | 0x0                | hresetn_usbotg0<br>When high, reset relative logic    |
| 4          | RW          | 0x0                | presetn_ddr_lpc<br>When high, reset relative logic    |
| 3          | RW          | 0x0                | resetn_ddrmon_osc<br>When high, reset relative logic  |
| 2          | RW          | 0x0                | presetn_ddrmon<br>When high, reset relative logic     |
| 1          | RW          | 0x0                | hresetn_ddrphy<br>When high, reset relative logic     |
| 0          | RW          | 0x0                | presetn_ddrc<br>When high, reset relative logic       |

### **CRU SOFTRST CON08**

Address: Operational Base(0xFF9A0000) + offset (0x0A20)

| <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:2       | RO          | 0x0000             | reserved                                                                                                                           |
| 1          | RW          | 0x0                | presetn_dma2ddr<br>When high, reset relative logic                                                                                 |
| 0          | RW          | 0x0                | aresetn_dma2ddr<br>When high, reset relative logic                                                                                 |

### **CRU SOFTRST CON09**

Address: Operational Base(0xFF9A0000) + offset (0x0A24)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
|            |             |                    | 1'b0: Write access disable<br>1'b1: Write access enable |
| 15:2       | RO          | 0x0000             | reserved                                                |
| 1          | RW          | 0x0                | resetn_usbotg1_utm<br>When high, reset relative logic   |
| 0          | RW          | 0x0                | resetn_usbotg0_utm<br>When high, reset relative logic   |

**CRU SOFTRST CON10**

Address: Operational Base(0xFF9A0000) + offset (0x0A28)

| <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                | resetn_ddrmon<br>When high, reset relative logic                                                                                   |
| 3          | RW          | 0x0                | resetn_ddrc<br>When high, reset relative logic                                                                                     |
| 2          | RW          | 0x0                | aresetn_ddr_biu<br>When high, reset relative logic                                                                                 |
| 1          | RW          | 0x0                | aresetn_ddrc_1<br>When high, reset relative logic                                                                                  |
| 0          | RW          | 0x0                | aresetn_ddrc_0<br>When high, reset relative logic                                                                                  |

**CRU SOFTRST CON11**

Address: Operational Base(0xFF9A0000) + offset (0x0A2C)

| <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                | resetn_i2c0<br>When high, reset relative logic                                                                                     |
| 14         | RW          | 0x0                | presetn_i2c0<br>When high, reset relative logic                                                                                    |
| 13         | RW          | 0x0                | resetn_uart4<br>When high, reset relative logic                                                                                    |
| 12         | RW          | 0x0                | resetn_uart3<br>When high, reset relative logic                                                                                    |
| 11         | RW          | 0x0                | resetn_uart2<br>When high, reset relative logic                                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 10         | RW          | 0x0                | resetn_uart1<br>When high, reset relative logic       |
| 9          | RW          | 0x0                | resetn_uart0<br>When high, reset relative logic       |
| 8          | RW          | 0x0                | presetn_uart4<br>When high, reset relative logic      |
| 7          | RW          | 0x0                | presetn_uart3<br>When high, reset relative logic      |
| 6          | RW          | 0x0                | presetn_uart2<br>When high, reset relative logic      |
| 5          | RW          | 0x0                | presetn_uart1<br>When high, reset relative logic      |
| 4          | RW          | 0x0                | presetn_uart0<br>When high, reset relative logic      |
| 3          | RO          | 0x0                | reserved                                              |
| 2          | RW          | 0x0                | hresetn_lsperi_biu<br>When high, reset relative logic |
| 1:0        | RO          | 0x0                | reserved                                              |

### **CRU SOFTRST CON12**

Address: Operational Base(0xFF9A0000) + offset (0x0A30)

| <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                | dbresetn_gpio2<br>When high, reset relative logic                                                                                  |
| 14         | RW          | 0x0                | presetn_gpio2<br>When high, reset relative logic                                                                                   |
| 13         | RW          | 0x0                | resetn_spi1<br>When high, reset relative logic                                                                                     |
| 12         | RW          | 0x0                | presetn_spi1<br>When high, reset relative logic                                                                                    |
| 11         | RW          | 0x0                | resetn_spi0<br>When high, reset relative logic                                                                                     |
| 10         | RW          | 0x0                | presetn_spi0<br>When high, reset relative logic                                                                                    |
| 9:6        | RO          | 0x0                | reserved                                                                                                                           |
| 5          | RW          | 0x0                | resetn_pwm1<br>When high, reset relative logic                                                                                     |
| 4          | RW          | 0x0                | presetn_pwm1<br>When high, reset relative logic                                                                                    |
| 3          | RW          | 0x0                | resetn_i2c2<br>When high, reset relative logic                                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                              |
|------------|-------------|--------------------|-------------------------------------------------|
| 2          | RW          | 0x0                | presetn_i2c2<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 CON13**

Address: Operational Base(0xFF9A0000) + offset (0x0A34)

| <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                | mresetn_sai0<br>When high, reset relative logic                                                                                    |
| 14         | RW          | 0x0                | resetn_spdifrx<br>When high, reset relative logic                                                                                  |
| 13         | RW          | 0x0                | hresetn_spdifrx<br>When high, reset relative logic                                                                                 |
| 12         | RW          | 0x0                | hresetn_spdiftx<br>When high, reset relative logic                                                                                 |
| 11         | RW          | 0x0                | resetn_spdiftx<br>When high, reset relative logic                                                                                  |
| 10         | RW          | 0x0                | resetn_pdm<br>When high, reset relative logic                                                                                      |
| 9          | RW          | 0x0                | mresetn_pdm<br>When high, reset relative logic                                                                                     |
| 8          | RW          | 0x0                | hresetn_pdm<br>When high, reset relative logic                                                                                     |
| 7          | RW          | 0x0                | resetn_can1<br>When high, reset relative logic                                                                                     |
| 6          | RW          | 0x0                | hresetn_can1<br>When high, reset relative logic                                                                                    |
| 5          | RW          | 0x0                | resetn_can0<br>When high, reset relative logic                                                                                     |
| 4          | RW          | 0x0                | hresetn_can0<br>When high, reset relative logic                                                                                    |
| 3          | RW          | 0x0                | dbresetn_gpio4<br>When high, reset relative logic                                                                                  |
| 2          | RW          | 0x0                | presetn_gpio4<br>When high, reset relative logic                                                                                   |
| 1          | RW          | 0x0                | dbresetn_gpio3<br>When high, reset relative logic                                                                                  |

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

### **CRU SOFTRST CON14**

Address: Operational Base(0xFF9A0000) + offset (0xA38)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:9       | RO          | 0x00               | reserved                                                                                                                           |
| 8          | RW          | 0x0                | resetn_asrc1<br>When high, reset relative logic                                                                                    |
| 7          | RW          | 0x0                | hresetn_asrc1<br>When high, reset relative logic                                                                                   |
| 6          | RW          | 0x0                | resetn_asrc0<br>When high, reset relative logic                                                                                    |
| 5          | RW          | 0x0                | hresetn_asrc0<br>When high, reset relative logic                                                                                   |
| 4          | RO          | 0x0                | reserved                                                                                                                           |
| 3          | RW          | 0x0                | hresetn_sai1<br>When high, reset relative logic                                                                                    |
| 2          | RW          | 0x0                | mresetn_sai1<br>When high, reset relative logic                                                                                    |
| 1          | RO          | 0x0                | reserved                                                                                                                           |
| 0          | RW          | 0x0                | hresetn_sai0<br>When high, reset relative logic                                                                                    |

### **CRU SOFTRST CON17**

Address: Operational Base(0xFF9A0000) + offset (0xA44)

| <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:13      | RO          | 0x0                | reserved                                                                                                                           |
| 12         | RW          | 0x0                | aresetn_mac1<br>When high, reset relative logic                                                                                    |
| 11         | RW          | 0x0                | aresetn_mac0<br>When high, reset relative logic                                                                                    |
| 10         | RW          | 0x0                | presetn_spi2<br>When high, reset relative logic                                                                                    |
| 9          | RW          | 0x0                | sresetn_fspi<br>When high, reset relative logic                                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 8          | RW          | 0x0                | hresetn_fspi<br>When high, reset relative logic       |
| 7          | RW          | 0x0                | hresetn_sdmmc<br>When high, reset relative logic      |
| 6:5        | RO          | 0x0                | reserved                                              |
| 4          | RW          | 0x0                | hresetn_hsperi_biu<br>When high, reset relative logic |
| 3:0        | RO          | 0x0                | reserved                                              |

**CRU SOFTRST CON18**

Address: Operational Base(0xFF9A0000) + offset (0x0A48)

| <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                | mresetn_audio_adc<br>When high, reset relative logic                                                                               |
| 14         | RW          | 0x0                | presetn_audio_adc<br>When high, reset relative logic                                                                               |
| 13         | RW          | 0x0                | mresetn_dsm<br>When high, reset relative logic                                                                                     |
| 12         | RW          | 0x0                | hresetn_dsm<br>When high, reset relative logic                                                                                     |
| 11         | RW          | 0x0                | mresetn_sai4<br>When high, reset relative logic                                                                                    |
| 10         | RW          | 0x0                | hresetn_sai4<br>When high, reset relative logic                                                                                    |
| 9:8        | RO          | 0x0                | reserved                                                                                                                           |
| 7          | RW          | 0x0                | mresetn_sai3<br>When high, reset relative logic                                                                                    |
| 6          | RW          | 0x0                | hresetn_sai3<br>When high, reset relative logic                                                                                    |
| 5:4        | RO          | 0x0                | reserved                                                                                                                           |
| 3          | RW          | 0x0                | hresetn_sai2<br>When high, reset relative logic                                                                                    |
| 2          | RW          | 0x0                | mresetn_sai2<br>When high, reset relative logic                                                                                    |
| 1:0        | RO          | 0x0                | reserved                                                                                                                           |

**CRU SOFTRST CON19**

Address: Operational Base(0xFF9A0000) + offset (0x0A4C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:9       | RO          | 0x00               | reserved                                                                                                                           |
| 8          | RW          | 0x0                | presetn_gpio234_ioc<br>When high, reset relative logic                                                                             |
| 7          | RW          | 0x0                | resetn_uart5<br>When high, reset relative logic                                                                                    |
| 6          | RW          | 0x0                | presetn_uart5<br>When high, reset relative logic                                                                                   |
| 5          | RW          | 0x0                | resetn_user_otpc_ns<br>When high, reset relative logic                                                                             |
| 4          | RW          | 0x0                | resetn_sbpi_otpc_ns<br>When high, reset relative logic                                                                             |
| 3          | RW          | 0x0                | presetn_otpc_ns<br>When high, reset relative logic                                                                                 |
| 2          | RW          | 0x0                | resetn_saradc_phy<br>When high, reset relative logic                                                                               |
| 1          | RW          | 0x0                | resetn_saradc<br>When high, reset relative logic                                                                                   |
| 0          | RW          | 0x0                | presetn_saradc<br>When high, reset relative logic                                                                                  |

### **CRU SOFTRST CON21**

Address: Operational Base(0xFF9A0000) + offset (0x0A54)

| <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                | resetn_tsadc<br>When high, reset relative logic                                                                                    |
| 14         | RW          | 0x0                | presetn_tsadc<br>When high, reset relative logic                                                                                   |
| 13         | RW          | 0x0                | presetn_dsi_host<br>When high, reset relative logic                                                                                |
| 12         | RW          | 0x0                | presetn_dphy<br>When high, reset relative logic                                                                                    |
| 11         | RW          | 0x0                | resetn_vop<br>When high, reset relative logic                                                                                      |
| 10         | RW          | 0x0                | hresetn_vop<br>When high, reset relative logic                                                                                     |
| 9          | RW          | 0x0                | aresetn_vop<br>When high, reset relative logic                                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 8          | RW          | 0x0                | resetn_core_rga<br>When high, reset relative logic |
| 7          | RW          | 0x0                | aresetn_rga<br>When high, reset relative logic     |
| 6          | RW          | 0x0                | hresetn_rga<br>When high, reset relative logic     |
| 5          | RO          | 0x0                | reserved                                           |
| 4          | RW          | 0x0                | hresetn_vio_biu<br>When high, reset relative logic |
| 3          | RW          | 0x0                | aresetn_vio_biu<br>When high, reset relative logic |
| 2:0        | RO          | 0x0                | reserved                                           |

### **CRU SOFTRST CON22**

Address: Operational Base(0xFF9A0000) + offset (0x0A58)

| <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:2       | RO          | 0x0000             | reserved                                                                                                                           |
| 1          | RW          | 0x0                | presetn_gpio1_ioc<br>When high, reset relative logic                                                                               |
| 0          | RO          | 0x0                | reserved                                                                                                                           |

### **CRU GLB CNT TH**

Address: Operational Base(0xFF9A0000) + offset (0x0C00)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                                                          |
| 27:0       | RW          | 0x00000064         | 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(0xFF9A0000) + offset (0x0C04)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:13      | RO          | 0x00000            | reserved                                             |
| 12         | RW          | 0x0                | wdt1_s_src_st<br>If High, global reset by wdt1_s_src |
| 11         | RW          | 0x0                | wdt0_s_src_st<br>If High, global reset by wdt0_s_src |
| 10:8       | RO          | 0x0                | reserved                                             |
| 7          | RW          | 0x0                | glbrst_wdt1_RST_ST<br>If High, global reset by WDT1  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6          | RW          | 0x0                | glbrst_wdt0_rst_st<br>If High, global reset by WDT0                                                                                                                                                |
| 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    |
| 1          | RW          | 0x0                | snd_glb_RST_ST<br>Second global reset 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 reset 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(0xFF9A0000) + offset (0x0C08)

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

### **CRU GLB SRST SND VALUE**

Address: Operational Base(0xFF9A0000) + offset (0x0C0C)

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

### **CRU GLB RST CON**

Address: Operational Base(0xFF9A0000) + offset (0x0C10)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13      | RO          | 0x00000            | reserved                                                                                                                                                                 |
| 12         | RW          | 0x0                | cru_wdt1_con<br>1'b0: WDT1 trigger second global reset<br>1'b1: WDT1 trigger first global reset                                                                          |
| 11         | RW          | 0x0                | cru_wdt0_con<br>1'b0: WDT0 trigger second global reset<br>1'b1: WDT0 trigger first global reset                                                                          |
| 10:8       | RO          | 0x0                | reserved                                                                                                                                                                 |
| 7          | RW          | 0x0                | cru_wdt1_en<br>1'b0: WDT1 trigger global reset disable<br>1'b1: WDT1 trigger global reset enable                                                                         |
| 6          | RW          | 0x0                | cru_wdt0_en<br>1'b0: WDT0 trigger global reset disable<br>1'b1: WDT0 trigger global reset enable                                                                         |
| 5          | RW          | 0x0                | tsadc_wdt_glb_expend_en<br>TSADC and WDT trigger global reset expend enable                                                                                              |
| 4          | RW          | 0x0                | pmu_srst_wdt_en<br>1'b0: Disable WDT reset as PMU reset source<br>1'b1: Enable WDT reset as PMU reset source                                                             |
| 3          | RW          | 0x0                | pmu_srst_glb_en<br>1'b0: Global reset trigger PMU reset disable<br>1'b1: Global reset trigger PMU reset enable                                                           |
| 2          | RW          | 0x0                | pmu_srst_glb_ctrl<br>1'b0: Enable second global reset as PMU reset source<br>1'b1: Enable first global reset as PMU reset source<br>It active when glb_RST_CON[3] enable |
| 1          | RW          | 0x0                | tsadc_glb_srst_en<br>1'b0: TSADC trigger global reset disable<br>1'b1: TSADC trigger global reset enable                                                                 |
| 0          | RW          | 0x0                | tsadc_glb_srst_ctrl<br>1'b0: TSADC trigger second global reset<br>1'b1: TSADC trigger first global reset                                                                 |

### **CRU COREWFI CON**

Address: Operational Base(0xFF9A0000) + offset (0x0C2C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                           |
|------------|-------------|--------------------|--------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                     |
| 1          | RW          | 0x0                | corepo_srst_wfien<br>WFI enable for core power-on soft reset |
| 0          | RW          | 0x0                | core_srst_wfien<br>WFI enable for core soft reset            |

## **2.5 SCRU Register Description**

### **2.5.1 Registers Summary**

| Name                | Offset | Size | Reset Value | Description                                     |
|---------------------|--------|------|-------------|-------------------------------------------------|
| SCRU_CLKSEL_CON104  | 0x0010 | W    | 0x00001180  | Internal clock select and division register 104 |
| SCRU_CLKSEL_CON105  | 0x0014 | W    | 0x00000000  | Internal clock select and division register 105 |
| SCRU_CLKSEL_CON106  | 0x0018 | W    | 0x00000000  | Internal clock select and division register 106 |
| SCRU_GATE_CON60     | 0x0040 | W    | 0x00000000  | Internal clock gate and division register 60    |
| SCRU_GATE_CON62     | 0x0048 | W    | 0x00000000  | Internal clock gate and division register 62    |
| SCRU_SOFT_RST_CON60 | 0x0080 | W    | 0x00000000  | Internal clock reset register 60                |
| SCRU_SOFT_RST_CON62 | 0x0088 | W    | 0x00000000  | Internal clock reset register 62                |

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

## 2.5.2 Detail Registers Description

### SCRU\_CLKSEL\_CON104

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

| Bit   | Attr | Reset Value | Description                                                                                                                           |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 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:14 | RO   | 0x0         | reserved                                                                                                                              |
| 13:12 | RW   | 0x1         | clk_pka_crypto_sel<br>clk_pka_crypto clock mux.<br>2'b00: clk_gpll_mux_gate<br>2'b01: clk_v0pll_mux_gate<br>2'b10: clk_v1pll_mux_gate |
| 11:7  | RW   | 0x03        | clk_pka_crypto_div<br>Divide clk_pka_crypto by (div_con + 1).                                                                         |
| 6:5   | RW   | 0x0         | clk_core_crypto_sel<br>clk_core_crypto clock mux.<br>2'b00: clk_gpll_div<br>2'b01: clk_v0pll_div<br>2'b10: clk_v1pll_div              |
| 4:0   | RW   | 0x00        | clk_core_crypto_div<br>Divide clk_core_crypto by (div_con + 1).                                                                       |

### SCRU\_CLKSEL\_CON105

Address: Operational Base(0xFF9A8000) + offset (0x0014)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |             |                    | 1'b1: Write access enable                                                                                                                                                                                            |
| 15         | RO          | 0x0                | reserved                                                                                                                                                                                                             |
| 14:12      | RW          | 0x0                | clk_timer1_ch4_sel<br>clk_timer1_ch4 clock mux.<br>3'b000: xin_osc0_func<br>3'b001: clk_gpll_div_100m<br>3'b010: clk_deepslow<br>3'b011: clk_core_pvtpll_logic<br>3'b100: mclk_asrc0                                 |
| 11:9       | RW          | 0x0                | clk_timer1_ch3_sel<br>clk_timer1_ch3 clock mux.<br>3'b000: xin_osc0_func<br>3'b001: clk_gpll_div_100m<br>3'b010: clk_deepslow<br>3'b011: clk_core_pvtpll_logic<br>3'b100: sai3_mclk_io_in<br>3'b101: sai3_sclk_io_in |
| 8:6        | RW          | 0x0                | clk_timer1_ch2_sel<br>clk_timer1_ch2 clock mux.<br>3'b000: xin_osc0_func<br>3'b001: clk_gpll_div_100m<br>3'b010: clk_deepslow<br>3'b011: clk_core_pvtpll_logic<br>3'b100: sai2_mclk_io_in<br>3'b101: sai2_sclk_io_in |
| 5:3        | RW          | 0x0                | clk_timer1_ch1_sel<br>clk_timer1_ch1 clock mux.<br>3'b000: xin_osc0_func<br>3'b001: clk_gpll_div_100m<br>3'b010: clk_deepslow<br>3'b011: clk_core_pvtpll_logic<br>3'b100: sai1_mclk_io_in<br>3'b101: sai1_sclk_io_in |
| 2:0        | RW          | 0x0                | clk_timer1_ch0_sel<br>clk_timer1_ch0 clock mux.<br>3'b000: xin_osc0_func<br>3'b001: clk_gpll_div_100m<br>3'b010: clk_deepslow<br>3'b011: clk_core_pvtpll_logic<br>3'b100: sai0_mclk_io_in<br>3'b101: sai0_sclk_io_in |

### **SCRU CLKSEL CON106**

Address: Operational Base(0xFF9A8000) + offset (0x0018)

| <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:0        | RW          | 0x0                | clk_timer1_ch5_sel<br>clk_timer1_ch5 clock mux.<br>3'b000: xin_osc0_func<br>3'b001: clk_gpll_div_100m<br>3'b010: clk_deepslow<br>3'b011: clk_core_pvtpll_logic<br>3'b100: mclk_asrc1 |

### **SCRU GATE CON60**

Address: Operational Base(0xFF9A8000) + 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 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                | pclk_keyreader_en<br>pclk_keyreader clock gating control.<br>When high, disable clock                                              |
| 4          | RO          | 0x0                | reserved                                                                                                                           |
| 3          | RW          | 0x0                | pclk_otp_mask_en<br>pclk_otp_mask clock gating control.<br>When high, disable clock                                                |
| 2          | RO          | 0x0                | reserved                                                                                                                           |
| 1          | RW          | 0x0                | clk_sbpi_otpc_s_en<br>clk_sbpi_otpc_s clock gating control.<br>When high, disable clock                                            |
| 0          | RW          | 0x0                | pclk_otpc_s_en<br>pclk_otpc_s clock gating control.<br>When high, disable clock                                                    |

### **SCRU GATE CON62**

Address: Operational Base(0xFF9A8000) + 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 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_timer1_ch5_en<br>clk_timer1_ch5 clock gating control.<br>When high, disable clock       |
| 14         | RW          | 0x0                | clk_timer1_ch4_en<br>clk_timer1_ch4 clock gating control.<br>When high, disable clock       |
| 13         | RW          | 0x0                | clk_timer1_ch3_en<br>clk_timer1_ch3 clock gating control.<br>When high, disable clock       |
| 12         | RW          | 0x0                | clk_timer1_ch2_en<br>clk_timer1_ch2 clock gating control.<br>When high, disable clock       |
| 11         | RW          | 0x0                | clk_timer1_ch1_en<br>clk_timer1_ch1 clock gating control.<br>When high, disable clock       |
| 10         | RW          | 0x0                | pclk_timer1_en<br>pclk_stimer clock gating control.<br>When high, disable clock             |
| 9          | RW          | 0x0                | pclk_bus_sgrf_en<br>pclk_bus_sgrf clock gating control.<br>When high, disable clock         |
| 8          | RW          | 0x0                | hclk_rng_s_en<br>hclk_rng_s clock gating control.<br>When high, disable clock               |
| 7          | RW          | 0x0                | aclk_crypto_s_en<br>aclk_crypto_s clock gating control.<br>When high, disable clock         |
| 6          | RW          | 0x0                | clk_pka_crypto_s_en<br>clk_pka_crypto_s clock gating control.<br>When high, disable clock   |
| 5          | RW          | 0x0                | clk_core_crypto_s_en<br>clk_core_crypto_s clock gating control.<br>When high, disable clock |
| 4          | RW          | 0x0                | hclk_keylad_en<br>hclk_keylad clock gating control.<br>When high, disable clock             |
| 3          | RW          | 0x0                | hclk_crypto_s_en<br>hclk_crypto_s clock gating control.<br>When high, disable clock         |
| 2          | RW          | 0x0                | hclk_crypto_s_en<br>hclk_crypto_s clock gating control.<br>When high, disable clock         |
| 1          | RW          | 0x0                | pclk_ddr_service_en<br>pclk_ddr_service clock gating control.<br>When high, disable clock   |

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

### **SCRU SOFTRST CON60**

Address: Operational Base(0xFF9A8000) + offset (0x0080)

| <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                | presetn_otp_mask<br>When high, reset relative logic                                                                                |
| 2          | RW          | 0x0                | resetn_user_otpc_s<br>When high, reset relative logic                                                                              |
| 1          | RW          | 0x0                | resetn_sbpi_otpc_s<br>When high, reset relative logic                                                                              |
| 0          | RW          | 0x0                | presetn_otpc_s<br>When high, reset relative logic                                                                                  |

### **SCRU SOFTRST CON62**

Address: Operational Base(0xFF9A8000) + offset (0x0088)

| <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                | resetn_timer1_ch5<br>When high, reset relative logic                                                                               |
| 14         | RW          | 0x0                | resetn_timer1_ch4<br>When high, reset relative logic                                                                               |
| 13         | RW          | 0x0                | resetn_timer1_ch3<br>When high, reset relative logic                                                                               |
| 12         | RW          | 0x0                | resetn_timer1_ch2<br>When high, reset relative logic                                                                               |
| 11         | RW          | 0x0                | resetn_timer1_ch1<br>When high, reset relative logic                                                                               |
| 10         | RW          | 0x0                | resetn_timer1_ch0<br>When high, reset relative logic                                                                               |
| 9          | RW          | 0x0                | presetn_timer1<br>When high, reset relative logic                                                                                  |
| 8          | RO          | 0x0                | reserved                                                                                                                           |
| 7          | RW          | 0x0                | hresetn_rng_s<br>When high, reset relative logic                                                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 6          | RW          | 0x0                | aresetn_crypto<br>When high, reset relative logic      |
| 5          | RW          | 0x0                | resetn_pka_crypto<br>When high, reset relative logic   |
| 4          | RW          | 0x0                | resetn_core_crypto<br>When high, reset relative logic  |
| 3          | RW          | 0x0                | hresetn_keylad<br>When high, reset relative logic      |
| 2          | RW          | 0x0                | hresetn_crypto_s<br>When high, reset relative logic    |
| 1          | RW          | 0x0                | presetn_ddr_service<br>When high, reset relative logic |
| 0          | RW          | 0x0                | hresetn_bootrom<br>When high, reset relative logic     |

## 2.6 CRU\_PMU Register Description

### 2.6.1 Registers Summary

| <b>Name</b>         | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>            |
|---------------------|---------------|-------------|--------------------|-------------------------------|
| CRU_PMU_GPLL_CON0   | 0x0000        | W           | 0x000020C8         | GPLL configuration register0  |
| CRU_PMU_GPLL_CON1   | 0x0004        | W           | 0x00001043         | GPLL configuration register1  |
| CRU_PMU_GPLL_CON2   | 0x0008        | W           | 0x00000000         | GPLL configuration register2  |
| CRU_PMU_GPLL_CON3   | 0x000C        | W           | 0x00000007         | GPLL configuration register3  |
| CRU_PMU_GPLL_CON4   | 0x0010        | W           | 0x00007F00         | GPLL configuration register4  |
| CRU_PMU_VPLL0_CON0  | 0x0020        | W           | 0x00001031         | V0PLL configuration register0 |
| CRU_PMU_VPLL0_CON1  | 0x0024        | W           | 0x00000041         | V0PLL configuration register1 |
| CRU_PMU_VPLL0_CON2  | 0x0028        | W           | 0x00000000         | V0PLL configuration register2 |
| CRU_PMU_VPLL0_CON3  | 0x002C        | W           | 0x00000007         | V0PLL configuration register3 |
| CRU_PMU_VPLL0_CON4  | 0x0030        | W           | 0x00007F00         | V0PLL configuration register4 |
| CRU_PMU_VPLL1_CON0  | 0x0040        | W           | 0x0000204B         | V1PLL configuration register0 |
| CRU_PMU_VPLL1_CON1  | 0x0044        | W           | 0x00000041         | V1PLL configuration register1 |
| CRU_PMU_VPLL1_CON2  | 0x0048        | W           | 0x00000000         | V1PLL configuration register2 |
| CRU_PMU_VPLL1_CON3  | 0x004C        | W           | 0x00000007         | V1PLL configuration register3 |
| CRU_PMU_VPLL1_CON4  | 0x0050        | W           | 0x00007F00         | V1PLL configuration register4 |
| CRU_PMU_SSGTBL0_3   | 0x0140        | W           | 0x00000000         | External wave table register0 |
| CRU_PMU_SSGTBL4_7   | 0x0144        | W           | 0x00000000         | External wave table register1 |
| CRU_PMU_SSGTBL8_11  | 0x0148        | W           | 0x00000000         | External wave table register2 |
| CRU_PMU_SSGTBL12_15 | 0x014C        | W           | 0x00000000         | External wave table register3 |
| CRU_PMU_SSGTBL16_19 | 0x0150        | W           | 0x00000000         | External wave table register4 |
| CRU_PMU_SSGTBL20_23 | 0x0154        | W           | 0x00000000         | External wave table register5 |
| CRU_PMU_SSGTBL24_27 | 0x0158        | W           | 0x00000000         | External wave table register6 |
| CRU_PMU_SSGTBL28_31 | 0x015C        | W           | 0x00000000         | External wave table register7 |
| CRU_PMU_SSGTBL32_35 | 0x0160        | W           | 0x00000000         | External wave table register8 |

| Name                  | Offset | Size | Reset Value  | Description                                   |
|-----------------------|--------|------|--------------|-----------------------------------------------|
| CRU_PMU_SSGTBL36_39   | 0x0164 | W    | 0x00000000   | External wave table register9                 |
| CRU_PMU_SSGTBL40_43   | 0x0168 | W    | 0x00000000   | External wave table register10                |
| CRU_PMU_SSGTBL44_47   | 0x016C | W    | 0x00000000   | External wave table register11                |
| CRU_PMU_SSGTBL48_51   | 0x0170 | W    | 0x00000000   | External wave table register12                |
| CRU_PMU_SSGTBL52_55   | 0x0174 | W    | 0x00000000   | External wave table register13                |
| CRU_PMU_SSGTBL56_59   | 0x0178 | W    | 0x00000000   | External wave table register14                |
| CRU_PMU_SSGTBL60_63   | 0x017C | W    | 0x00000000   | External wave table register15                |
| CRU_PMU_SSGTBL64_67   | 0x0180 | W    | 0x00000000   | External wave table register16                |
| CRU_PMU_SSGTBL68_71   | 0x0184 | W    | 0x00000000   | External wave table register17                |
| CRU_PMU_SSGTBL72_75   | 0x0188 | W    | 0x00000000   | External wave table register18                |
| CRU_PMU_SSGTBL76_79   | 0x018C | W    | 0x00000000   | External wave table register19                |
| CRU_PMU_SSGTBL80_83   | 0x0190 | W    | 0x00000000   | External wave table register20                |
| CRU_PMU_SSGTBL84_87   | 0x0194 | W    | 0x00000000   | External wave table register21                |
| CRU_PMU_SSGTBL88_91   | 0x0198 | W    | 0x00000000   | External wave table register22                |
| CRU_PMU_SSGTBL92_95   | 0x019C | W    | 0x00000000   | External wave table register23                |
| CRU_PMU_SSGTBL96_99   | 0x01A0 | W    | 0x00000000   | External wave table register24                |
| CRU_PMU_SSGTBL100_103 | 0x01A4 | W    | 0x00000000   | External wave table register25                |
| CRU_PMU_SSGTBL104_107 | 0x01A8 | W    | 0x00000000   | External wave table register26                |
| CRU_PMU_SSGTBL108_111 | 0x01AC | W    | 0x00000000   | External wave table register27                |
| CRU_PMU_SSGTBL112_115 | 0x01B0 | W    | 0x00000000   | External wave table register28                |
| CRU_PMU_SSGTBL116_119 | 0x01B4 | W    | 0x00000000   | External wave table register29                |
| CRU_PMU_SSGTBL120_123 | 0x01B8 | W    | 0x00000000   | External wave table register30                |
| CRU_PMU_SSGTBL124_127 | 0x01BC | W    | 0x00000000   | External wave table register31                |
| CRU_PMU_CLKSEL_CONO0  | 0x0300 | W    | 0x00007C00   | Internal clock select and division register 0 |
| CRU_PMU_CLKSEL_CONO1  | 0x0304 | W    | 0x00000101   | Internal clock select and division register 1 |
| CRU_PMU_CLKSEL_CONO2  | 0x0308 | W    | 0x0040B71B   | Internal clock select and division register 2 |
| CRU_PMU_CLKSEL_CONO3  | 0x030C | W    | 0x000002B0   | Internal clock select and division register 3 |
| CRU_PMU_CLKSEL_CONO4  | 0x0310 | W    | 0x000000C80  | Internal clock select and division register 4 |
| CRU_PMU_CLKSEL_CONO6  | 0x0318 | W    | 0x0000000000 | Internal clock select and division register 6 |

| Name                  | Offset | Size | Reset Value | Description                                 |
|-----------------------|--------|------|-------------|---------------------------------------------|
| CRU PMU GATE CON00    | 0x0800 | W    | 0x00000000  | Internal clock gate and division register 0 |
| CRU PMU GATE CON01    | 0x0804 | W    | 0x00000000  | Internal clock gate and division register 1 |
| CRU PMU GATE CON02    | 0x0808 | W    | 0x00000000  | Internal clock gate and division register 2 |
| CRU PMU SOFTRST CON00 | 0x0A00 | W    | 0x00000000  | Internal clock reset register 0             |
| CRU PMU SOFTRST CON01 | 0x0A04 | W    | 0x00000000  | Internal clock reset register 1             |

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

Double WORD (64 bits) access

## 2.6.2 Detail Registers Description

### CRU PMU GPLLE CON0

Address: Operational Base(0xFF9B0000) + 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, (1-7)<br>Should obey the rule: postdiv1 > = postdiv2                                                               |
| 11:0  | RW   | 0x0c8       | 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 GPLLE CON1

Address: Operational Base(0xFF9B0000) + 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:14 | RO   | 0x0         | reserved                                                                                                                           |

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

**CRU PMU GPLL CON2**

Address: Operational Base(0xFF9B0000) + offset (0x0008)

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

**CRU PMU GPLL CON3**

Address: Operational Base(0xFF9B0000) + 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>Set modulation depth (spread percentage) of SSMOD<br>5'h0: 0%<br>5'h1: 0.1%<br>5'h2: 0.2%<br>...<br>5'h1e: 3%<br>5'h1f: 3.1% |
| 7:4        | RW          | 0x0                | ssmod_divval<br>Divider required to set the modulation frequency                                                                             |
| 3          | RW          | 0x0                | ssmod_downspread<br>Selects center spread or down spread<br>1'b0: Center spread<br>1'b1: Down 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(0xFF9B0000) + 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, (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 PMU VPLL0 CON0**

Address: Operational Base(0xFF9B0000) + offset (0x0020)

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

Address: Operational Base(0xFF9B0000) + 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:14      | RO          | 0x0                | reserved                                                                                                                           |
| 13         | RW          | 0x0                | pllpd<br>PLL global power down request<br>1'b0: No power down<br>1'b1: Power down                                                  |
| 12         | RW          | 0x0                | dsmpd<br>PLL delta sigma modulator enable<br>1'b0: Modulator is enable<br>1'b1: Modulator is disabled                              |
| 11         | RO          | 0x0                | reserved                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 10         | RW          | 0x0                | pll_lock<br>PLL lock status<br>1'b0: Unlock<br>1'b1: Lock |
| 9          | RO          | 0x0                | reserved                                                  |
| 8:6        | RW          | 0x1                | postdiv2<br>Second Post Divide Value, (1-7)               |
| 5:0        | RW          | 0x01               | refdiv<br>Reference Clock Divide Value, (1-63)            |

**CRU PMU VPLL0 CON2**

Address: Operational Base(0xFF9B0000) + offset (0x0028)

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

**CRU PMU VPLL0 CON3**

Address: Operational Base(0xFF9B0000) + 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>Set modulation depth (spread percentage) of SSMOD<br>5'h0: 0%                                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------|
|            |             |                    | 5'h1: 0.1%<br>5'h2: 0.2%<br>...<br>5'h1e: 3%<br>5'h1f: 3.1%                                           |
| 7:4        | RW          | 0x0                | ssmod_divval<br>Divider required to set the modulation frequency                                      |
| 3          | RW          | 0x0                | ssmod_downspread<br>Selects center spread or downs spread<br>1'b0: Center spread<br>1'b1: Down 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 VPLL0 CON4**

Address: Operational Base(0xFF9B0000) + 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, (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 VPLL1 CON0**

Address: Operational Base(0xFF9B0000) + 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 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |             |                    | 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, (1-7)<br>Should obey the rule: postdiv1 > = postdiv2                                                               |
| 11:0       | RW          | 0x04b              | 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 VPLL1 CON1**

Address: Operational Base(0xFF9B0000) + 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:14      | RO          | 0x0                | reserved                                                                                                                           |
| 13         | RW          | 0x0                | pllpd<br>PLL global power down request<br>1'b0: No power down<br>1'b1: Power down                                                  |
| 12         | RW          | 0x0                | dsmpd<br>PLL delta sigma modulator enable<br>1'b0: Modulator is enable<br>1'b1: Modulator is disabled                              |
| 11         | RO          | 0x0                | reserved                                                                                                                           |
| 10         | RW          | 0x0                | pll_lock<br>PLL lock status<br>1'b0: Unlock<br>1'b1: Lock                                                                          |
| 9          | RO          | 0x0                | reserved                                                                                                                           |
| 8:6        | RW          | 0x1                | postdiv2<br>Second Post Divide Value, (1-7)                                                                                        |
| 5:0        | RW          | 0x01               | refdiv<br>Reference Clock Divide Value, (1-63)                                                                                     |

### **CRU PMU VPLL1 CON2**

Address: Operational Base(0xFF9B0000) + offset (0x0048)

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

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

**CRU PMU VPLL1 CON3**

Address: Operational Base(0xFF9B0000) + 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>Set modulation depth (spread percentage) of SSMOD<br>5'h0: 0%<br>5'h1: 0.1%<br>5'h2: 0.2%<br>...<br>5'h1e: 3%<br>5'h1f: 3.1% |
| 7:4        | RW          | 0x0                | ssmod_divval<br>Divider required to set the modulation frequency                                                                             |
| 3          | RW          | 0x0                | ssmod_downspread<br>Selects center spread or down spread<br>1'b0: Center spread<br>1'b1: Down spread                                         |
| 2          | RW          | 0x1                | ssmod_reset<br>Reset modulator state<br>1'b0: No reset                                                                                       |

**RK3506 TRM (Part 1)**

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

Address: Operational Base(0xFF9B0000) + offset (0x0050)

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

**CRU PMU SSGTBL0\_3**

Address: Operational Base(0xFF9B0000) + offset (0x0140)

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

**CRU PMU SSGTBL4\_7**

Address: Operational Base(0xFF9B0000) + offset (0x0144)

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

**CRU PMU SSGTBL8 11**

Address: Operational Base(0xFF9B0000) + offset (0x0148)

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

**CRU PMU SSGTBL12 15**

Address: Operational Base(0xFF9B0000) + offset (0x014C)

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

**CRU PMU SSGTBL16 19**

Address: Operational Base(0xFF9B0000) + offset (0x0150)

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

**CRU PMU SSGTBL20 23**

Address: Operational Base(0xFF9B0000) + offset (0x0154)

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

**CRU PMU SSGTBL24 27**

Address: Operational Base(0xFF9B0000) + offset (0x0158)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl24_27<br>Extern wave table 24-27<br>7-0: table24 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                |
|------------|-------------|--------------------|---------------------------------------------------|
|            |             |                    | 15-8: table25<br>23-16: table26<br>31-24: table27 |

**CRU PMU SSGTBL28 31**

Address: Operational Base(0xFF9B0000) + offset (0x015C)

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

**CRU PMU SSGTBL32 35**

Address: Operational Base(0xFF9B0000) + offset (0x0160)

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

**CRU PMU SSGTBL36 39**

Address: Operational Base(0xFF9B0000) + offset (0x0164)

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

**CRU PMU SSGTBL40 43**

Address: Operational Base(0xFF9B0000) + offset (0x0168)

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

**CRU PMU SSGTBL44 47**

## **RK3506 TRM (Part 1)**

Address: Operational Base(0xFF9B0000) + offset (0x016C)

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

## **CRU PMU SSGTBL48 51**

Address: Operational Base(0xFF9B0000) + offset (0x0170)

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

## **CRU PMU SSGTBL52 55**

Address: Operational Base(0xFF9B0000) + offset (0x0174)

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

## **CRU PMU SSGTBL56 59**

Address: Operational Base(0xFF9B0000) + offset (0x0178)

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

## **CRU PMU SSGTBL60 63**

Address: Operational Base(0xFF9B0000) + offset (0x017C)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>               |
|------------|-------------|--------------------|----------------------------------|
|            |             |                    | 23-16: table62<br>31-24: table63 |

**CRU PMU SSGTBL64 67**

Address: Operational Base(0xFF9B0000) + offset (0x0180)

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

**CRU PMU SSGTBL68 71**

Address: Operational Base(0xFF9B0000) + offset (0x0184)

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

**CRU PMU SSGTBL72 75**

Address: Operational Base(0xFF9B0000) + offset (0x0188)

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

**CRU PMU SSGTBL76 79**

Address: Operational Base(0xFF9B0000) + offset (0x018C)

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

**CRU PMU SSGTBL80 83**

Address: Operational Base(0xFF9B0000) + offset (0x0190)

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

**CRU PMU SSGTBL84 87**

Address: Operational Base(0xFF9B0000) + offset (0x0194)

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

**CRU PMU SSGTBL88 91**

Address: Operational Base(0xFF9B0000) + offset (0x0198)

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

**CRU PMU SSGTBL92 95**

Address: Operational Base(0xFF9B0000) + offset (0x019C)

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

**CRU PMU SSGTBL96 99**

Address: Operational Base(0xFF9B0000) + offset (0x01A0)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
|            |             |                    | 31-24: table99     |

**CRU PMU SSGTBL100 103**

Address: Operational Base(0xFF9B0000) + offset (0x01A4)

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

**CRU PMU SSGTBL104 107**

Address: Operational Base(0xFF9B0000) + offset (0x01A8)

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

**CRU PMU SSGTBL108 111**

Address: Operational Base(0xFF9B0000) + offset (0x01AC)

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

**CRU PMU SSGTBL112 115**

Address: Operational Base(0xFF9B0000) + offset (0x01B0)

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

**CRU PMU SSGTBL116 119**

Address: Operational Base(0xFF9B0000) + offset (0x01B4)

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

**CRU PMU SSGTBL120 123**

Address: Operational Base(0xFF9B0000) + offset (0x01B8)

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

**CRU PMU SSGTBL124 127**

Address: Operational Base(0xFF9B0000) + offset (0x01BC)

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

**CRU PMU CLKSEL CON00**

Address: Operational Base(0xFF9B0000) + offset (0x0300)

| <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:10      | RW          | 0x1f               | clk_mac_out_div<br>DT50 division register.<br>Divide clk_mac_out by (div_con + 1).                                                      |
| 9:6        | RW          | 0x0                | clk_pwm0_div<br>Divide clk_pwm0 by (div_con + 1).                                                                                       |
| 5:4        | RW          | 0x0                | clk_pmu_hp_timer_sel<br>clk_pmu_hp_timer clock mux.<br>2'b00: xin_osc0_func<br>2'b01: clk_gpll_div_100m<br>2'b10: clk_core_pvtpll_logic |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------|
| 3:2        | RW          | 0x0                | dbclk_gpio1_shadow_sel<br>dbclk_gpio1_shadow clock mux.<br>2'b00: xin_osc0_func<br>2'b01: clk_rc<br>2'b10: clk_deepslow_pmu |
| 1:0        | RW          | 0x0                | dbclk_gpio0_sel<br>dbclk_pmu_gpio clock mux.<br>2'b00: xin_osc0_func<br>2'b01: clk_rc<br>2'b10: clk_deepslow_pmu            |

**CRU PMU CLKSEL CON01**

Address: Operational Base(0xFF9B0000) + offset (0x0304)

| <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:14      | RW          | 0x0                | clk_ref_out1_sel<br>clk_ref_out1 clock mux.<br>2'b00: xin_osc0_func<br>2'b01: clk_gpII<br>2'b10: clk_v0pll<br>2'b11: clk_v1pll     |
| 13:8       | RW          | 0x01               | clk_ref_out1_div<br>DT50 division register.<br>Divide clk_ref_out1 by (div_con + 1).                                               |
| 7:6        | RW          | 0x0                | clk_ref_out0_sel<br>clk_ref_out0 clock mux.<br>2'b00: xin_osc0_func<br>2'b01: clk_gpII<br>2'b10: clk_v0pll<br>2'b11: clk_v1pll     |
| 5:0        | RW          | 0x01               | clk_ref_out0_div<br>DT50 division register.<br>Divide clk_ref_out0 by (div_con + 1).                                               |

**CRU PMU CLKSEL CON02**

Address: Operational Base(0xFF9B0000) + offset (0x0308)

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

**CRU PMU CLKSEL CON03**

Address: Operational Base(0xFF9B0000) + offset (0x030C)

| <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:9       | RW          | 0x1                | clk_deepslow_pmu_sel<br>clk_deepslow_pmu clock mux.<br>2'b00: clk_RTC_deepslow_io<br>2'b01: clk_deepslow_rc<br>2'b10: clk_deepslow_frac |
| 8:7        | RW          | 0x1                | clk_deepslow_sel<br>clk_deepslow clock mux.<br>2'b00: clk_RTC_deepslow_io<br>2'b01: clk_deepslow_rc<br>2'b10: clk_deepslow_frac         |
| 6:2        | RW          | 0x0c               | clk_deepslow_rc_div<br>Divide clk_deepslow_rc by (div_con + 1).                                                                         |
| 1:0        | RW          | 0x0                | clk_deepslow_frac_sel<br>clk_deepslow_frac clock mux.<br>2'b00: xin_osc0_func<br>2'b01: clk_v0pll<br>2'b10: clk_v1pll<br>2'b11: clk_rc  |

**CRU PMU CLKSEL CON04**

Address: Operational Base(0xFF9B0000) + offset (0x0310)

| <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                | clk_ref_phy_pmu_mux_sel<br>clk_ref_usbphy_pmu_mux clock mux.<br>1'b0: xin_osc0_func_phy<br>1'b1: clk_ref_phy_pll                   |
| 14:13      | RW          | 0x0                | clk_ref_phy_pll_sel<br>clk_ref_phy_pll clock mux.<br>2'b00: clk_gpll<br>2'b01: clk_v0pll<br>2'b10: clk_v1pll                       |
| 12:6       | RW          | 0x32               | clk_ref_phy_pll_div<br>clk_ref_phy_pll interge division register.                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------|
| 5:4        | RW          | 0x0                | clk_ddrphy_sel<br>clk_ddrphy clock mux.<br>2'b00: clk_gpll<br>2'b01: clk_v0pll<br>2'b10: clk_v1pll |
| 3:0        | RW          | 0x0                | clk_ddrphy_div<br>DT50 division register.<br>Divide clk_ddrphy by (div_con + 1).                   |

**CRU PMU CLKSEL CON06**

Address: Operational Base(0xFF9B0000) + offset (0x0318)

| <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:2       | RO          | 0x0000             | reserved                                                                                                                           |
| 1          | RW          | 0x0                | clk_v1pll_ref_sel<br>clk_v1pll_ref clock mux.<br>1'b0: xin_osc0_func<br>1'b1: clk_pll_ref_io                                       |
| 0          | RW          | 0x0                | clk_v0pll_ref_sel<br>clk_v0pll_ref clock mux.<br>1'b0: xin_osc0_func<br>1'b1: clk_pll_ref_io                                       |

**CRU PMU GATE CON00**

Address: Operational Base(0xFF9B0000) + offset (0x0800)

| <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                | pclk_pwm0_en<br>pclk_pwm0 clock gating control.<br>When high, disable clock                                                        |
| 14         | RW          | 0x0                | clk_pmu_hp_timer_deepslow_en<br>clk_pmu_hp_timer_deepslow clock gating control.<br>When high, disable clock                        |
| 13         | RW          | 0x0                | clk_pmu_hp_timer_en<br>clk_pmu_hp_timer_ls clock gating control.<br>When high, disable clock                                       |
| 12         | RW          | 0x0                | pclk_pmu_hp_timer_en<br>pclk_pmu_hp_timer clock gating control.<br>When high, disable clock                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------|
| 11         | RW          | 0x0                | dbclk_gpio1_shadow_en<br>dbclk_gpio1_shadow clock gating control.<br>When high, disable clock |
| 10         | RW          | 0x0                | pclk_gpio1_shadow_en<br>pclk_gpio1_shadow clock gating control.<br>When high, disable clock   |
| 9          | RW          | 0x0                | dbclk_gpio0_en<br>dbclk_gpio0 clock gating control.<br>When high, disable clock               |
| 8          | RW          | 0x0                | pclk_gpio0_en<br>pclk_gpio0 clock gating control.<br>When high, disable clock                 |
| 7          | RW          | 0x0                | pclk_gpio0_ioc_en<br>pclk_pmu_ioc clock gating control.<br>When high, disable clock           |
| 6          | RO          | 0x0                | reserved                                                                                      |
| 5          | RW          | 0x0                | pclk_pmu_grf_en<br>pclk_pmu_grf clock gating control.<br>When high, disable clock             |
| 4          | RW          | 0x0                | pclk_pmu_cru_en<br>pclk_pmu_cru clock gating control.<br>When high, disable clock             |
| 3          | RW          | 0x0                | clk_pmu_deepslow_en<br>clk_pmu_deepslow clock gating control.<br>When high, disable clock     |
| 2          | RW          | 0x0                | pclk_pmu_en<br>pclk_pmu clock gating control.<br>When high, disable clock                     |
| 1          | RW          | 0x0                | clk_pmu_en<br>clk_pmu clock gating control.<br>When high, disable clock                       |
| 0          | RO          | 0x0                | reserved                                                                                      |

### **CRU PMU GATE CON01**

Address: Operational Base(0xFF9B0000) + offset (0x0804)

| <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         | RO          | 0x0                | reserved                                                                                                                           |
| 14         | RW          | 0x0                | clk_ref_phy_pll_en<br>clk_ref_phy_pll clock gating control.<br>When high, disable clock                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------|
| 13         | RW          | 0x0                | clk_touch_key_en<br>clk_touch_key clock gating control.<br>When high, disable clock             |
| 12         | RW          | 0x0                | pclk_touch_key_en<br>pclk_touch_key clock gating control.<br>When high, disable clock           |
| 11         | RW          | 0x0                | clk_ddrphy_en<br>clk_ddrphy clock gating control.<br>When high, disable clock                   |
| 10         | RW          | 0x0                | clk_uart_jtag_en<br>clk_uart_jtag clock gating control.<br>When high, disable clock             |
| 9          | RW          | 0x0                | clk_deepslow_pmu_en<br>clk_deepslow_pmu clock gating control.<br>When high, disable clock       |
| 8          | RW          | 0x0                | clk_deepslow_en<br>clk_deepslow clock gating control.<br>When high, disable clock               |
| 7          | RW          | 0x0                | clk_deepslow_rc_en<br>clk_deepslow_rc clock gating control.<br>When high, disable clock         |
| 6          | RW          | 0x0                | clk_deepslow_frac_div_en<br>clk_deepslow_frac clock gating control.<br>When high, disable clock |
| 5          | RW          | 0x0                | clk_ref_out1_en<br>clk_ref_out1 clock gating control.<br>When high, disable clock               |
| 4          | RW          | 0x0                | clk_ref_out0_en<br>clk_ref_out0 clock gating control.<br>When high, disable clock               |
| 3          | RW          | 0x0                | clk_mac_out_en<br>clk_mac_out clock gating control.<br>When high, disable clock                 |
| 2          | RW          | 0x0                | clk_rc_pwm0_en<br>clk_rc_pwm0 clock gating control.<br>When high, disable clock                 |
| 1          | RW          | 0x0                | clk_osc_pwm0_en<br>clk_osc_pwm0 clock gating control.<br>When high, disable clock               |
| 0          | RW          | 0x0                | clk_pwm0_en<br>clk_pwm0 clock gating control.<br>When high, disable clock                       |

### **CRU PMU GATE CON02**

Address: Operational Base(0xFF9B0000) + offset (0x0808)

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

**CRU PMU SOFTRST CON00**

Address: Operational Base(0xFF9B0000) + offset (0x0A00)

| <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                | presetn_pwm0<br>When high, reset relative logic                                                                                    |
| 14         | RW          | 0x0                | resetn_pmu_hp_timer_deepslow<br>When high, reset relative logic                                                                    |
| 13         | RW          | 0x0                | resetn_pmu_hp_timer<br>When high, reset relative logic                                                                             |
| 12         | RW          | 0x0                | presetn_pmu_hp_timer<br>When high, reset relative logic                                                                            |
| 11         | RW          | 0x0                | dbresetn_gpio1_shadow<br>When high, reset relative logic                                                                           |
| 10         | RW          | 0x0                | presetn_gpio1_shadow<br>When high, reset relative logic                                                                            |
| 9          | RW          | 0x0                | dbresetn_gpio0<br>When high, reset relative logic                                                                                  |
| 8          | RW          | 0x0                | presetn_gpio0<br>When high, reset relative logic                                                                                   |
| 7          | RW          | 0x0                | presetn_gpio0_ioc<br>When high, reset relative logic                                                                               |
| 6          | RO          | 0x0                | reserved                                                                                                                           |
| 5          | RW          | 0x0                | presetn_pmu_grf<br>When high, reset relative logic                                                                                 |
| 4:0        | RO          | 0x00               | reserved                                                                                                                           |

**CRU PMU SOFTRST CON01**

Address: Operational Base(0xFF9B0000) + offset (0x0A04)

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

| Bit   | Attr | Reset Value | Description                                          |
|-------|------|-------------|------------------------------------------------------|
|       |      |             | 1'b1: Write access enable                            |
| 15:14 | RO   | 0x0         | reserved                                             |
| 13    | RW   | 0x0         | resetn_touch_key<br>When high, reset relative logic  |
| 12    | RW   | 0x0         | presetn_touch_key<br>When high, reset relative logic |
| 11    | RW   | 0x0         | resetn_ddrphy<br>When high, reset relative logic     |
| 10:1  | RO   | 0x000       | reserved                                             |
| 0     | RW   | 0x0         | resetn_pwm0<br>When high, reset relative logic       |

## 2.7 SCRU PMU Register Description

### 2.7.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

### 2.7.2 Registers Summary

| Name                | Offset | Size | Reset Value | Description                                  |
|---------------------|--------|------|-------------|----------------------------------------------|
| SCRU PMU GATE CON60 | 0x0040 | W    | 0x00000000  | Internal clock gate and division register 60 |

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

### 2.7.3 Detail Registers Description

#### SCRU PMU GATE CON60

Address: Operational Base(0xFF9B8000) + offset (0x0040)

| Bit   | Attr | Reset Value | Description                                                                                                                        |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| 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         | pclk_pmu_sgrf_en<br>pclk_pmu_sgrf clock gating control.<br>When high, disable clock                                                |

## 2.8 Application Notes

### 2.8.1 PLL Usage

#### 2.8.1.1 PLL Frequency Configuration

FBDIV, POSTDIV1, BYPASS can be configured by programming CRU\_xPLL\_CON0. DSMPD, REFDIV, POSTDIV2 can be configured by programming CRU\_xPLL\_CON1. FRAC can be configured by programming CRU\_xPLL\_CON2(x= D, G).

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

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

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

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

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

And then

$$\text{FOUTVCO} = (\text{FREF} / \text{REFDIV}) * \text{FBDIV} = 24/6*200=800$$
$$\text{FOUTPOSTDIV} = \text{FOUTVCO} / (\text{POSTDIV1} * \text{POSTDIV2}) = 800/1/1=800$$

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

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

And then

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

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

### **2.8.1.2 PLL Setting Consideration**

- For lowest power operation, the minimum VCO and FREF frequencies should be used. For minimum jitter operation, the highest VCO and FREF frequencies should be used.
- The supply rejection will be worse at the low end of the VCO range so care should be taken to keep the supply clean for low power applications.
- 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.

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

For normal applications, user should configure as following steps to change the PLL output frequency.

- Change PLL from normal to slow mode by programming CRU\_MODE\_CON00.
- Power down PLL
- Change PLL setting.
- Power up PLL after delay 1us
- Wait until PLL is lock state by checking CRU\_xPLL\_CON1[10] register (The max lock time is 500\*REFDIV/FREF) or just delay about 500 REF\_CLK cycles
- Change PLL into normal mode

For special applications, user can use on-the-fly mode. User can change FBDIV and FRAC slightly and don't need to follow above normal changing setups, PLL will simply slew to the new frequency.

### **2.8.2 Divider Usage**

CRU supports multi-dividers for different clock requirement.

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

#### **2.8.2.1 DivFree Divider Usage**

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

#### **2.8.2.2 Fractional Divider Usage**

To get specific frequency, matrix array clocks of clk\_frac\_uart\_matrix0/1, clk\_frac\_voice\_matrix0/1, clk\_frac\_common\_matrix0/1/2 can be generated by fractional

divider. Generally you should ensure that denominator is 20 times larger than numerator to generate precise clock frequency. So the fractional divider applies only to generate low frequency clock.

### **2.8.2.3 DivfreeDT50 Divider Usage**

Some modules like SDMMC, FLEXBUS, MAC, PDM and FSPI need clock of 50% duty cycle, divfreeDT50 can generate clock of 50% duty cycle even when divisor value is odd.

### **2.8.3 Global Software Reset**

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

- CRU\_GLB\_SRST\_FST\_VALUE[15:0] = 0xfdb9 to assert the first global software reset glb\_srstn\_1
  - CRU\_GLB\_SRST\_SND\_VALUE[15:0] = 0xecab to assert the second global software reset glb\_srstn\_2
  - glb\_srstn\_1 resets almost all logic except some registers just supporting hardware reset
  - glb\_srstn\_2 resets almost all logic except GPIOs, IOCs, SPINLOCK and KEYREADER.
- Reset for IP in PD\_PMU can be held if its reset\_hold\_enable in GRF\_PMU\_SOC\_CON3 is high even if glb\_srstn\_1 or glb\_srstn\_2 active.

### **2.8.4 SSCG Usage**

There are some scenes where SSCG should be enabled. One scene is in communication where a fixed frequency is required. Another scene is that the system requires a clock with low long-term jitter. When SSCG is used, the PLL should be configured to fractional mode first for spread spectrum capability.

#### **2.8.4.1 SSCG Use InternalPoint Table**

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

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

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

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

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

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

- ssmod\_downspread = 1'b1, down spread mode is used. If ssmod\_spread = 5'd29, the maximum PLL frequency is the nominally programmed value  $F_{NOM}$ , and the minimum value is given by  $F_{NOM} * (1 - 0.029)$ .
- ssmod\_downspread = 1'b0, center spread mode is used. If ssmod\_spread = 5'd29, the maximum PLL frequency would be determined by  $F_{NOM} * (1 + 0.029)$  and the minimum frequency by  $F_{NOM} * (1 - 0.029)$ .

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

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

When use internal point table, the frequency will change as following during 128 point:

- Change from minimum value to maximum value uniformly within 64 points
- Change from maximum value to minimum value uniformly within 64 points

Spread spectrum modulator is implemented by repeating as above.

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

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

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

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

### 2.8.4.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\_PMU\_SSGTBL0\_3 ~ CRU\_PMU\_SSGTBL124\_127.

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

- Setting ssmod\_spread (CRU\_XPLL\_CON3[12:8]) and ssmod\_downspread (CRU\_XPLL\_CON3[3]), same with internal point table usage.
- Setting ssmod\_sel\_ext\_wave (CRU\_XPLL\_CON4[0])=1'b1
- Setting ssmod\_ext\_maxaddr (CRU\_XPLL\_CON4[15:8]) and table0 ~ table127 (CRU\_PMU\_SSGTBL0\_3 ~ CRU\_PMU\_SSGTBL124\_127)

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

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

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

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

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

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

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

### 2.8.5 Others

Based on special requirements, the frequency of aclk\_bus\_root must be greater than or equal to twice the frequency of pclk\_bus\_root.

## Chapter 3 Cortex-A7

### 3.1 Overview

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

The key features of the Cortex-A7 include:

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

### 3.2 Block Diagram



Fig. 3-1 Core Subsystem Architecture

### 3.3 Function Description

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

### 3.4 Register Description

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

## Chapter 4 Cortex-M0

### 4.1 Overview

The Cortex-M0 processor is a very low gate count, highly energy efficient processor that is intended for micro-controller and deeply embedded applications that require an area optimized processor.

#### 4.1.1 Cortex-M0

The following features may or may not be present in the actual product. Please contact Rockchip for the actual feature configurations and the third-party licensing requirements.

The processor features and benefits are:

- A low gate count processor that features
  - The ARMv6-M Thumb instruction set
  - Thumb-2 technology
  - Load/store-multiples and multi cycle-multiplies that can be abandoned and restarted to facilitate rapid interrupt handling
  - Low power sleep-mode entry using Wait For Interrupt (WFI), Wait For Event (WFE) instructions, or the return from interrupt sleep-on-exit feature
- NVIC that features
  - 32 external interrupt inputs, each with four levels of priority
  - Dedicated Non-Maskable Interrupt (NMI) input
  - Optional Wake-up Interrupt Controller (WIC), providing ultra-low power sleep mode support
- Optional debug support
  - Two hardware breakpoints
  - One watch points
  - Support Serial Wire debug connection
  - single 32-bit AMBA-3 AHB-Lite system interface
- Integrated Interrupt Controller for APB bus, up to 128 IRQ lines with 128to4 INTMUX

### 4.2 Block Diagram

Cortex-M0 Integration architecture is shown below.



Fig. 4-1 Cortex-M0 Integration Architecture

### 4.3 Function Description

Please refer to the document [Cortex-M0\\_TechnicalReferenceManualRevC\\_DDI0432\\_r0p0-02rel0.pdf](#) and [DUI0497A\\_cortex\\_m0\\_r0p0\\_generic\\_ug.pdf](#) for the detail description.

#### 4.3.1 Interrupt Multiplexer(INTMUX)

The Interrupt Multiplexer will select 4 interrupts from 125 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.

## 4.4 Register Description

Please refer to the document Cortex-M0\_TechnicalReferenceManualRevC\_DDI0432\_r0p0-02rel0.pdf and [DUI0497A cortex\\_m0\\_r0p0\\_generic\\_ug.pdf](#) for the detail description.

### 4.4.1 INTMUX Registers Summary

#### Operational Base

| Name                   | Base Address |
|------------------------|--------------|
| M0 INTMUX base address | 0xFF2A0000   |

| Name             | Offset | Size | Reset Value | Description                          |
|------------------|--------|------|-------------|--------------------------------------|
| INTMUX IRQ MASK0 | 0x0000 | W    | 0x00000000  | IRQ interrupt source mask0 register. |
| INTMUX IRQ MASK1 | 0x0004 | W    | 0x00000000  | IRQ interrupt source mask1 register. |
| INTMUX IRQ MASK2 | 0x0008 | W    | 0x00000000  | IRQ interrupt source mask2 register. |
| INTMUX IRQ MASK3 | 0x000C | W    | 0x00000000  | IRQ interrupt source mask3 register. |
| INTMUX IRQ FLAG0 | 0x0080 | W    | 0x00000000  | IRQ flag0 register.                  |
| INTMUX IRQ FLAG1 | 0x0084 | W    | 0x00000000  | IRQ flag1 register.                  |
| INTMUX IRQ FLAG2 | 0x0088 | W    | 0x00000000  | IRQ flag2 register.                  |
| INTMUX IRQ FLAG3 | 0x008C | W    | 0x00000000  | IRQ flag3 register.                  |

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

### 4.4.2 Detail Registers Description

#### INTMUX IRQ MASK0

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                           |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | mask0<br>Interrupt mask bits for the IRQ0~IRQ31 (see <a href="#">Table 1-5</a> ) interrupt sources. Set 1 in any bit position unmasks the corresponding interrupt. By default, all bits are masked.<br>1'b1: unmask interrupt<br>1'b0: mask interrupt |

#### INTMUX IRQ MASK1

Address: Operational Base + offset (0x0004)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                            |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | Mask1<br>Interrupt mask bits for the IRQ32~IRQ63 (see <a href="#">Table 1-5</a> ) interrupt sources. Set 1 in any bit position unmasks the corresponding interrupt. By default, all bits are masked.<br>1'b1: unmask interrupt<br>1'b0: mask interrupt |

#### INTMUX IRQ MASK2

Address: Operational Base + offset (0x0008)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                            |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | Mask2<br>Interrupt mask bits for the IRQ64~IRQ95 (see <a href="#">Table 1-5</a> ) interrupt sources. Set 1 in any bit position unmasks the corresponding interrupt. By default, all bits are masked.<br>1'b1: unmask interrupt<br>1'b0: mask interrupt |

#### INTMUX IRQ MASK3

Address: Operational Base + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                |
| 29:0       | RO          | 0x00000000         | Mask3<br>Interrupt mask bits for the IRQ96~IRQ125 (see <a href="#">Table 1-5</a> ) interrupt sources. Set 1 in any bit position unmasks the corresponding interrupt. By default, all bits are masked.<br>1'b1: unmask interrupt<br>1'b0: mask interrupt |

**INTMUX IRQ FLAG0**

Address: Operational Base + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | int_flag0<br>Interrupt status after the masking stage. These are the interrupt status signals for the IRQ0~IRQ31 (see <a href="#">Table 1-5</a> ) interrupt sources. |

**INTMUX IRQ FLAG1**

Address: Operational Base + offset (0x0084)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | int_flag1<br>Interrupt status after the masking stage. These are the interrupt status signals for the IRQ32~IRQ63 (see <a href="#">Table 1-5</a> ) interrupt sources. |

**INTMUX IRQ FLAG2**

Address: Operational Base + offset (0x0088)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | int_flag2<br>Interrupt status after the masking stage. These are the interrupt status signals for the IRQ64~IRQ95 (see <a href="#">Table 1-5</a> ) interrupt sources. |

**INTMUX IRQ FLAG3**

Address: Operational Base + offset (0x008C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                               |
| 29:0       | RO          | 0x00000000         | int_flag3<br>Interrupt status after the masking stage. These are the interrupt status signals for the IRQ96~IRQ125 (see <a href="#">Table 1-5</a> ) interrupt sources. |

## 4.5 Interface Description

Table 4-1 Cortex-M0 Interface Description

| <b>Module Pin</b> | <b>Direction</b> | <b>Pin Name</b>                         | <b>IOMUX Setting</b>                                       |
|-------------------|------------------|-----------------------------------------|------------------------------------------------------------|
| m0jtag_tck_m0     | I                | SDMMC_D2/JTAG_TCK_M0/GPIO3_A4_d         | GPIO3A_IOMUX_SEL_1[3:0] = 4'h2<br>GRF_SOC_CON0[4] = 1'b1   |
| m0jtag_tms_m0     | I/O              | SDMMC_D3/JTAG_TMS_M0/GPIO3_A5_d         | GPIO3A_IOMUX_SEL_1[7:4] = 4'h2<br>GRF_SOC_CON0[4] = 1'b1   |
| m0jtag_tck_m1     | I                | UART0_TX/JTAG_TCK_M1/RM_IO22/GPIO0_C6_u | GPIO0C_IOMUX_SEL_1[11:8] = 4'h2<br>GRF_SOC_CON0[5] = 1'b1  |
| m0jtag_tms_m1     | I/O              | UART0_RX/JTAG_TMS_M1/RM_IO23/GPIO0_C7_u | GPIO0C_IOMUX_SEL_1[15:12] = 4'h2<br>GRF_SOC_CON0[5] = 1'b1 |

Notes: I=input, O=output, I/O=input/output, bidirectional

## 4.6 Application Notes

### 4.6.1 Clock and Reset Generation

Please refer to "Chapter CRU" for more detailed information.

### 4.6.2 Miscellaneous Signals for M0

#### M0 System Configure Signals

Table 4-2 M0 System Configure Signals

| Signal Name                 | Default | Description                                                                                                                                                                                                                                                                                  |
|-----------------------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| grf_con_mcu_irqlatency[7:0] | 0       | Minimum number of cycles between an interrupt that becomes pended in the NVIC, and the vector fetch for that interrupt being issued                                                                                                                                                          |
| grf_con_mcu_nmi             | 0       | Non-maskable interrupt                                                                                                                                                                                                                                                                       |
| grf_con_mcu_dbgrestart      | 0       | External restart request.                                                                                                                                                                                                                                                                    |
| grf_con_mcu_edbgrq          | 0       | External debug request.                                                                                                                                                                                                                                                                      |
| grf_con_mcu_stcalib[25:0]   | 0       | Systick timer counter                                                                                                                                                                                                                                                                        |
| grf_con_mcu_rxev            | 0       | A HIGH level on this input causes the architecture defined Event Register to be set in the Cortex-M0 processor. This causes a WFE instruction to complete. It also awakens the processor if it is sleeping as the result of encountering a WFE instruction when the Event Register is clear. |
| grf_con_mcu_dbgen           | 0       | SerialWire Debug enable.<br>0: disable<br>1: enable                                                                                                                                                                                                                                          |
| grf_con_mcu_sleepholdreqn   | 1       | Request to extend the processor sleeping state regardless of wake-up events. If the processor acknowledges this request driving SLEEPHOLDACKn Low, this guarantees the processor remains idle even on receipt of a wake-up event                                                             |

#### M0 System Status Signals

Table 4-3 M0 System Status Signals

| Signal Name           | Default | Description                                                                                                                  |
|-----------------------|---------|------------------------------------------------------------------------------------------------------------------------------|
| grf_mcu_dbgrestarterd | 1       | Handshake for DBGRESTART                                                                                                     |
| grf_mcu_halted        | 0       | Indicates that the processor is in debug state. HALTED remains asserted for as long as the processor remains in debug state. |
| grf_mcu_txev          | 0       | M0 transform a event                                                                                                         |
| grf_mcu_lockup        | 0       | Indicates that m0 is locked up                                                                                               |
| grf_mcu_hclk_gate     | 0       | Indicates that hclk can be gated.                                                                                            |
| grf_mcu_wakeup        | 0       | Indicates M0 wakeup                                                                                                          |
| grf_mcu_sleepdeep     | 0       | Indicates the processor is idle, waiting for an interrupt on either the IRQ, NMI, or HIGH level on RXEV.                     |
| grf_mcu_sleeping      | 0       | Active only when SLEEPING is HIGH. Indicates that the SLEEPDEEP bit in the NVIC is set to 1.                                 |
| grf_mcu_sleepholdack  | 1       | Indicates M0 sleepholdack                                                                                                    |

### 4.6.3 Interrupt for M0

Table 4-4 M0 Interrupt

| IRQ ID | IRQ Source | IRQ ID | IRQ Source   |
|--------|------------|--------|--------------|
| 0      | PMUGPIO_1  | 16     | SARADC       |
| 1      | PMUGPIO_2  | 17     | SDMMC_EMMC   |
| 2      | PMUGPIO_3  | 18     | RKTIMER4     |
| 3      | GPIO1_1    | 19     | RKTIMERS5    |
| 4      | GPIO1_2    | 20     | STIMER4      |
| 5      | GPIO1_3    | 21     | STIMER5_DSMC |
| 6      | GPIO2_3    | 22     | MAILBOX_BB   |
| 7      | GPIO3_3    | 23     | DMAC0        |
| 8      | TOUCH_POS  | 24     | DMAC0_ABORT  |
| 9      | TOUCH_NEG  | 25     | DMAC1        |

|    |        |    |             |
|----|--------|----|-------------|
| 10 | PWM1_6 | 26 | DMAC1_ABORT |
| 11 | PWM1_7 | 27 | FLEXBUS     |
| 12 | UART3  | 28 | INTMUX0     |
| 13 | UART4  | 29 | INTMUX1     |
| 14 | I2C2   | 30 | INTMUX2     |
| 15 | SPI1   | 31 | INTMUX3     |

Table 4-5 INTMUX Interrupt Source

| <b>IRQ ID</b> | <b>IRQ Source</b> |
|---------------|-------------------|
| 0             | PMUGPIO_0         |
| 1             | GPIO1_0           |
| 2             | GPIO2_0           |
| 3             | GPIO2_1           |
| 4             | GPIO2_2           |
| 5             | GPIO3_0           |
| 6             | GPIO3_1           |
| 7             | GPIO3_2           |
| 8             | GPIO4_0           |
| 9             | GPIO4_1           |
| 10            | GPIO4_2           |
| 11            | GPIO4_3           |
| 12            | PWM0_0            |
| 13            | PWM0_1            |
| 14            | PWM0_2            |
| 15            | PWM0_3            |
| 16            | PWM1_0            |
| 17            | PWM1_1            |
| 18            | PWM1_2            |
| 19            | PWM1_3            |
| 20            | PWM1_4            |
| 21            | PWM1_5            |
| 22            | UART0             |
| 23            | UART1             |
| 24            | UART2             |
| 25            | UART5             |
| 26            | I2C0              |
| 27            | I2C1              |
| 28            | SPI0              |
| 29            | CAN0              |
| 30            | CAN1              |
| 31            | SPDIF_TX          |
| 32            | SPDIF_RX          |
| 33            | PDM               |
| 34            | SAI0              |
| 35            | SAI1              |
| 36            | SAI2              |

|    |                    |
|----|--------------------|
| 37 | SAI3               |
| 38 | SAI4               |
| 39 | ASRC0              |
| 40 | ASRC1              |
| 41 | TSADC              |
| 42 | VOP                |
| 43 | MIPI_DSIHOST       |
| 44 | RGA                |
| 45 | OTPC_NS            |
| 46 | OTPC_S             |
| 47 | KEYREADER          |
| 48 | OTPC_MASK          |
| 49 | GMAC0_SBD          |
| 50 | GMAC0_SBD_PERCH_TX |
| 51 | GMAC0_SBD_PERCH_RX |
| 52 | GMAC0_PMT          |
| 53 | GMAC1_SBD          |
| 54 | GMAC1_SBD_PERCH_TX |
| 55 | GMAC1_SBD_PERCH_RX |
| 56 | GMAC1_PMT          |
| 57 | USB2OTG            |
| 58 | OTG0_BVALID        |
| 59 | OTG0_ID            |
| 60 | OTG0_LINESTATE     |
| 61 | OTG0_DISCONNECT    |
| 62 | USB2OTG1           |
| 63 | OTG1_BVALID        |
| 64 | OTG1_ID            |
| 65 | OTG1_LINESTATE     |
| 66 | OTG1_DISCONNECT    |
| 67 | SPI2APB            |
| 68 | SFC                |
| 69 | DDRC_AWPOISON_0    |
| 70 | DDRC_AWPOISON_1    |
| 71 | DDRC_ARPOISON_0    |
| 72 | DDRC_ARPOISON_1    |
| 73 | DDRC_DFI_ALERT_ERR |
| 74 | DDR_MONITOR        |
| 75 | DDRPHY             |
| 76 | RKTIMERO           |
| 77 | RKTIMER1           |
| 78 | RKTIMER2           |
| 79 | RKTIMER3           |
| 80 | STIMERO            |
| 81 | STIMER1            |

|     |                   |
|-----|-------------------|
| 82  | STIMER2           |
| 83  | STIMER3           |
| 84  | HPTIMER           |
| 85  | WDT0              |
| 86  | WDT1              |
| 87  | MAILBOX_AP        |
| 88  | CRYPTO            |
| 89  | CRYPTO_KLAD       |
| 90  | CRYPTO_SC         |
| 91  | NSTRNG            |
| 92  | STRNG             |
| 93  | DSMC_SLV          |
| 94  | SYSCORE_0         |
| 95  | SYSCORE_1         |
| 96  | SYSCORE_2         |
| 97  | SYSCORE_3         |
| 98  | SYSCORE_4         |
| 99  | STRIMER_DSMC_MUX  |
| 100 | PMU               |
| 101 | RKNPOR_POWERNGOOD |
| 102 | GPIO1_SHADOW_0    |
| 103 | GPIO1_1           |
| 104 | GPIO1_2           |
| 105 | GPIO1_3           |
| 106 | OTG0_VBUSVALID    |
| 107 | OTG1_VBUSVALID    |
| 108 | VOP_POST_LB       |
| 109 | DMA2DDR           |
| 110 | MAILBOX_AP_0      |
| 111 | MAILBOX_AP_1      |
| 112 | MAILBOX_AP_2      |
| 113 | MAILBOX_AP_3      |
| 114 | MAILBOX_BB_0      |
| 115 | MAILBOX_BB_1      |
| 116 | MAILBOX_BB_2      |
| 117 | MAILBOX_BB_3      |
| 118 | GMAC0_MCGR_DMA    |
| 119 | GMAC1_MCGR_DMA    |
| 120 | DMAC0_MASK0       |
| 121 | DMAC0_MASK1       |
| 122 | DMAC0_MASK2       |
| 123 | DMAC1_MASK0       |
| 124 | DMAC2_MASK1       |
| 125 | DMAC3_MASK2       |

Rockchip Confidential

## Chapter 5 General Register Files (GRF)

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

### 5.2 Function Description

The function of general register file is:

- Common system control
- Record the system state

### 5.3 GRF Register Description

#### 5.3.1 Registers Summary

| Name          | Offset | Size | Reset Value | Description                |
|---------------|--------|------|-------------|----------------------------|
| GRF_SOC_CON0  | 0x0000 | W    | 0x00000444  | 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_CON3  | 0x000C | W    | 0x00000000  | System control register 3  |
| GRF_SOC_CON4  | 0x0010 | W    | 0x00000000  | System control register 4  |
| GRF_SOC_CON5  | 0x0014 | W    | 0x00000000  | System control register 5  |
| GRF_SOC_CON6  | 0x0018 | W    | 0x00000000  | System control register 6  |
| GRF_SOC_CON7  | 0x001C | W    | 0x00000000  | System control register 7  |
| GRF_SOC_CON8  | 0x0020 | W    | 0x00000000  | System control register 8  |
| GRF_SOC_CON9  | 0x0024 | W    | 0x00000000  | System control register 9  |
| GRF_SOC_CON10 | 0x0028 | W    | 0x00000000  | System control register 10 |
| GRF_SOC_CON11 | 0x002C | W    | 0x00000000  | System control register 11 |
| GRF_SOC_CON13 | 0x0034 | W    | 0x00000000  | System control register 12 |
| GRF_SOC_CON14 | 0x0038 | W    | 0x00001FDF  | System control register 14 |
| GRF_SOC_CON15 | 0x003C | W    | 0x00000000  | System control register 15 |
| GRF_SOC_CON16 | 0x0040 | W    | 0x000000600 | System control register 16 |
| GRF_SOC_CON17 | 0x0044 | W    | 0x00000000  | System control register 17 |
| GRF_SOC_CON18 | 0x0048 | W    | 0x00000000  | System control register 18 |
| GRF_SOC_CON19 | 0x004C | W    | 0x00000000  | System control register 19 |
| GRF_SOC_CON20 | 0x0050 | W    | 0x00000000  | System control register 20 |
| GRF_SOC_CON21 | 0x0054 | W    | 0x00000021  | System control register 21 |
| GRF_SOC_CON22 | 0x0058 | W    | 0x00000000  | System control register 22 |
| GRF_SOC_CON23 | 0x005C | W    | 0x00000155  | System control register 23 |
| GRF_SOC_CON24 | 0x0060 | W    | 0x00008C52  | System control register 24 |
| GRF_SOC_CON25 | 0x0064 | W    | 0x00000080  | System control register 25 |
| GRF_SOC_CON26 | 0x0068 | W    | 0x00000000  | System control register 26 |
| GRF_SOC_CON27 | 0x006C | W    | 0x00000000  | System control register 27 |
| GRF_SOC_CON28 | 0x0070 | W    | 0x00008452  | System control register 28 |
| GRF_SOC_CON29 | 0x0074 | W    | 0x00000080  | System control register 29 |
| GRF_SOC_CON30 | 0x0078 | W    | 0x00000000  | System control register 30 |
| GRF_SOC_CON31 | 0x007C | W    | 0x00000000  | System control register 31 |
| GRF_SOC_CON32 | 0x0080 | W    | 0x00000000  | System control register 32 |
| GRF_SOC_CON33 | 0x0084 | W    | 0x00000000  | System control register 33 |
| GRF_SOC_CON35 | 0x008C | W    | 0x00000000  | System control register 35 |
| GRF_SOC_CON36 | 0x0090 | W    | 0x00000000  | System control register 36 |
| GRF_SOC_CON37 | 0x0094 | W    | 0x00000010  | System control register 37 |
| GRF_SOC_CON38 | 0x0098 | W    | 0x00000000  | System control register 38 |
| GRF_SOC_CON39 | 0x009C | W    | 0x00000000  | System control register 39 |

| Name                              | Offset | Size | Reset Value | Description                          |
|-----------------------------------|--------|------|-------------|--------------------------------------|
| GRF_SOC_CON40                     | 0x00A0 | W    | 0x00000000  | System control register 40           |
| GRF_SOC_CON41                     | 0x00A4 | W    | 0x00000000  | System control register 41           |
| GRF_SOC_CON42                     | 0x00A8 | W    | 0x00000000  | System control register 48           |
| GRF_SOC_CON43                     | 0x00AC | W    | 0x00000000  | System control register 43           |
| GRF_SOC_STATUS0                   | 0x0100 | W    | 0x00000000  | System status register 0             |
| GRF_SOC_STATUS1                   | 0x0104 | W    | 0x00000000  | System status register 1             |
| GRF_SOC_STATUS2                   | 0x0108 | W    | 0x00000000  | System status register 2             |
| GRF_DDR_STATUS0                   | 0x0110 | W    | 0x00000000  | DDR status register 0                |
| GRF_DDR_STATUS1                   | 0x0114 | W    | 0x00000000  | DDR status register 1                |
| GRF_USBPHY_STATUS                 | 0x0118 | W    | 0x00000708  | USB PHY status register              |
| GRF_USBOTG0_SIG_DETECT_CON        | 0x0150 | W    | 0x00000000  | USB OTG0 detection control register  |
| GRF_USBOTG0_SIG_DETECT_STATUS     | 0x0154 | W    | 0x00000000  | USB OTG0 detection status register   |
| GRF_USBOTG0_SIG_DETECT_CLR        | 0x0158 | W    | 0x00000000  | USB OTG0 detection clear register    |
| GRF_USBOTG0_VBUSVALID_DETECT_CON  | 0x015C | W    | 0x00030100  | USB OTG0 vbusvalid control register  |
| GRF_USBOTG0_LINESTATE_DETECT_CON  | 0x0160 | W    | 0x00030100  | USB OTG0 linestate control register  |
| GRF_USBOTG0_DISCONNECT_DETECT_CON | 0x0164 | W    | 0x00030100  | USB OTG0 disconnect control register |
| GRF_USBOTG0_BVALID_DETECT_CON     | 0x0168 | W    | 0x00030100  | USB OTG0 bvalid control register     |
| GRF_USBOTG0_ID_DETECT_CON         | 0x016C | W    | 0x00030100  | USB OTG0 id control register         |
| GRF_USBOTG1_SIG_DETECT_CON        | 0x0170 | W    | 0x00000000  | USB OTG1 detection control register  |
| GRF_USBOTG1_SIG_DETECT_STATUS     | 0x0174 | W    | 0x00000000  | USB OTG1 detection status register   |
| GRF_USBOTG1_SIG_DETECT_CLR        | 0x0178 | W    | 0x00000000  | USB OTG1 detection clear register    |
| GRF_USBOTG1_VBUSVALID_DETECT_CON  | 0x017C | W    | 0x00030100  | USB OTG1 vbusvalid control register  |
| GRF_USBOTG1_LINESTATE_DETECT_CON  | 0x0180 | W    | 0x00030100  | USB OTG1 linestate control register  |
| GRF_USBOTG1_DISCONNECT_DETECT_CON | 0x0184 | W    | 0x00030100  | USB OTG1 disconnect control register |
| GRF_USBOTG1_BVALID_DETECT_CON     | 0x0188 | W    | 0x00030100  | USB OTG1 bvalid control register     |
| GRF_USBOTG1_ID_DETECT_CON         | 0x018C | W    | 0x00030100  | USB OTG1 id control register         |
| GRF_MAC0_MGCR_ACK                 | 0x01A0 | W    | 0x00000000  | MAC0 MGCR ACK register               |
| GRF_MAC1_MGCR_ACK                 | 0x01A4 | W    | 0x00000000  | MAC1 MGCR ACK register               |
| GRF_OS_REG0                       | 0x0200 | W    | 0x00000000  | OS register 0                        |
| GRF_OS_REG1                       | 0x0204 | W    | 0x00000000  | OS register 1                        |
| GRF_OS_REG2                       | 0x0208 | W    | 0x00000000  | OS register 2                        |
| GRF_OS_REG3                       | 0x020C | W    | 0x00000000  | OS register 3                        |
| GRF_OS_REG4                       | 0x0210 | W    | 0x00000000  | OS register 4                        |
| GRF_OS_REG5                       | 0x0214 | W    | 0x00000000  | OS register 5                        |
| GRF_OS_REG6                       | 0x0218 | W    | 0x00000000  | OS register 6                        |
| GRF_OS_REG7                       | 0x021C | W    | 0x00000000  | OS register 7                        |
| GRF_OS_REG8                       | 0x0220 | W    | 0x00000000  | OS register 8                        |

| Name            | Offset | Size | Reset Value | Description          |
|-----------------|--------|------|-------------|----------------------|
| GRF OS REG9     | 0x0224 | W    | 0x00000000  | OS register 9        |
| GRF OS REG10    | 0x0228 | W    | 0x00000000  | OS register 10       |
| GRF OS REG11    | 0x022C | W    | 0x00000000  | OS register 11       |
| GRF SOC VERSION | 0x0300 | W    | 0x00003506  | SOC version register |

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

### 5.3.2 Detail Registers Description

#### GRF SOC CON0

Address: Operational Base(0xFF288000) + 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         | sddmmc_hprot_bufferable<br>AHB master write bufferable<br>1'b0: Non bufferable<br>1'b1: Bufferable                                 |
| 14    | RW   | 0x0         | otg1_hprot_bufferable<br>AHB master write bufferable<br>1'b0: Non bufferable<br>1'b1: Bufferable                                   |
| 13    | RW   | 0x0         | otg0_hprot_bufferable<br>AHB master write bufferable<br>1'b0: Non bufferable<br>1'b1: Bufferable                                   |
| 12    | RW   | 0x0         | mcu_hprot_bufferable<br>AHB master write bufferable<br>1'b0: Non bufferable<br>1'b1: Bufferable                                    |
| 11    | RO   | 0x0         | reserved                                                                                                                           |
| 10    | RW   | 0x1         | grf_con_dsm_sel<br>1'b0: Audio DSM SCLK/LRCK from IO when in slave mode<br>1'b1: Audio DSM SCLK/LRCK from SAI3 when in slave mode  |
| 9     | RW   | 0x0         | grf_con_sai3_sel<br>1'b0: SAI3 SCLK/LRCK from IO when in slave mode<br>1'b1: SAI3 SCLK/LRCK from AudiDSM when in slave mode        |
| 8     | RW   | 0x0         | grf_spdif_rx_loopback_tx<br>SPDIF RX loop to SPDIF TX<br>1'b1: RX loop back to TX<br>1'b0: Normal mode                             |
| 7     | RW   | 0x0         | ddrmonitor_external_trigger_en<br>1'b0: Disable<br>1'b1: Enable                                                                    |
| 6     | RW   | 0x1         | vop_dcf_idle<br>1'b0: Un-idle<br>1'b1: Idle                                                                                        |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:4 | RW   | 0x0         | <p>grf_jtag_sel<br/>JTAG select.<br/>2'b00:<br/>When port M0 enable, port M1 enable: port M0 for MCU, port M1 for A7<br/>When port M0 enable, port M1 disable: port M0 for A7<br/>When port M0 disable, port M1 enable: port M1 for A7<br/>2'b01:<br/>When port M0 enable, port M1 enable: port M0 for MCU, port M1 for A7<br/>When port M0 enable, port M1 disable: port M0 for MCU<br/>When port M0 disable, port M1 enable: port M1 for A7<br/>2'b10:<br/>When port M0 enable, port M1 enable: port M0 for A7, port M1 for MCU<br/>When port M0 enable, port M1 disable: port M0 for A7<br/>When port M0 disable, port M1 enable: port M1 for MCU<br/>2'b11: Reserved<br/>Note: User can set IOMUX GPIO3_GPIO3A_IOMUX_SEL_1[7:0] = 8'h22 to enable JTAG port M0 and set GPIO0_GPIO0C_IOMUX_SEL_1[15:8] = 8'h22 to enable JTAG port M1.</p> |
| 3   | RW   | 0x0         | <p>grf_saradc_pd_sel<br/>1'b1: SARADC PHY power down controlled by grf_saradc_pd<br/>1'b0: SARADC PHY power down controlled by SARADC controller</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 2   | RW   | 0x1         | <p>grf_saradc_pd<br/>1'b0: SARADC PHY power up<br/>1'b1: SARADC PHY power down</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 1:0 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

**GRF SOC CON1**

Address: Operational Base(0xFF288000) + offset (0x0004)

| Bit   | Attr | Reset Value | Description                                                                                                                                                              |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | <p>write_enable<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                             |
| 15:6  | RO   | 0x000       | reserved                                                                                                                                                                 |
| 5     | RW   | 0x0         | <p>dsmc_slave_rdyn_mode<br/>DSMC_SLV_RDYN output mode<br/>1'b0: Open drain output mode<br/>1'b1: Normal mode, user can set gpio1d3_od=1 to enable open drain output.</p> |
| 4     | RW   | 0x0         | <p>dsmc_slave_enable<br/>DSMC slave enable<br/>When DSMC slave is enable, the FLEXBUS can not be used.</p>                                                               |
| 3     | RW   | 0x0         | <p>grf_sai3_mclk_oen<br/>SAI3 MCLK output enable<br/>1'b0: Disable<br/>1'b1: Enable</p>                                                                                  |
| 2     | RW   | 0x0         | <p>grf_sai2_mclk_oen<br/>SAI2 MCLK output enable<br/>1'b0: Disable<br/>1'b1: Enable</p>                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0        | RW          | 0x0                | <p>grf_flexport1_con<br/>grf_flexport1_con[0]</p> <p>1'b0: FLEXBUS1 input clock invert disable<br/>1'b1: FLEXBUS1 input clock invert enable</p> <p>grf_flexport1_con[1]</p> <p>1'b0: FLEXBUS1 input data two flip-flop pipe bypass disable<br/>1'b1: FLEXBUS1 input data two flip-flop pipe bypass</p> |

**GRF SOC CON2**

Address: Operational Base(0xFF288000) + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | <p>write_enable<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p> |
| 15:11      | RO          | 0x00               | reserved                                                                                                                                     |
| 10:4       | RW          | 0x00               | <p>grf_vop_ddl_sel<br/>Delayline element select</p>                                                                                          |
| 3          | RO          | 0x0                | reserved                                                                                                                                     |
| 2          | RW          | 0x0                | <p>grf_vop_data_bypass<br/>1'b0: Use two flip-flop pipe in VOP LCD IO<br/>1'b1: Bypass two flip-flop pipe in VOP LCD IO</p>                  |
| 1          | RW          | 0x0                | <p>grf_vop_dclk_bypass<br/>1'b0: Use two flip-flop pipe in VOP LCD IO<br/>1'b1: Bypass two flip-flop pipe in VOP LCD IO</p>                  |
| 0          | RW          | 0x0                | <p>grf_vop_dclk_inv<br/>VOP DCLK invert selection<br/>1'b0: Bypass invert<br/>1'b1: Select invert</p>                                        |

**GRF SOC CON3**

Address: Operational Base(0xFF288000) + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | <p>write_enable<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p> |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                     |
| 13         | RW          | 0x0                | <p>uart5_rts_inv<br/>Polarity selection for uart5_rts.<br/>1'b0: Low active<br/>1'b1: High active</p>                                        |
| 12         | RW          | 0x0                | <p>uart4_rts_inv<br/>Polarity selection for uart4_rts.<br/>1'b0: Low active<br/>1'b1: High active</p>                                        |
| 11         | RW          | 0x0                | <p>uart3_rts_inv<br/>Polarity selection for uart3_rts.<br/>1'b0: Low active<br/>1'b1: High active</p>                                        |
| 10:6       | RO          | 0x00               | reserved                                                                                                                                     |
| 5          | RW          | 0x0                | <p>uart5_cts_inv<br/>Polarity selection for uart5_cts.<br/>1'b0: Low active<br/>1'b1: High active</p>                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------|
| 4          | RW          | 0x0                | uart4_cts_inv<br>Polarity selection for uart4_cts.<br>1'b0: Low active<br>1'b1: High active |
| 3          | RW          | 0x0                | uart3_cts_inv<br>Polarity selection for uart3_cts.<br>1'b0: Low active<br>1'b1: High active |
| 2:0        | RO          | 0x0                | reserved                                                                                    |

**GRF SOC CON4**

Address: Operational Base(0xFF288000) + 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:11      | RO          | 0x00               | reserved                                                                                                                               |
| 10         | RW          | 0x0                | tsadc_phy_pd_sel<br>1'b1: TSADC PHY power down controlled by grf_tsadc_pd<br>1'b0: TSADC PHY power down controlled by TSADC controller |
| 9          | RW          | 0x0                | tsadc_phy_pd<br>1'b1: TSADC PHY power up<br>1'b0: TSADC PHY power down                                                                 |
| 8          | RW          | 0x0                | tsadc_tsen_en<br>TSADC enable register.<br>1'b1: Enable<br>1'b0: Disable                                                               |
| 7:0        | RW          | 0x00               | tsadc_ana_reg<br>TSADC configure registers.                                                                                            |

**GRF SOC CON5**

Address: Operational Base(0xFF288000) + 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 |
| 15:4       | RO          | 0x000              | reserved                                                                                                                           |
| 3          | RW          | 0x0                | grf_io_mipi_te_sel<br>VOP MIPI TE selection<br>1'b0: From DSI controller<br>1'b1: From IO                                          |
| 2          | RW          | 0x0                | grf_dsi_dpiupdatacfg<br>DSI dpi update configuration                                                                               |
| 1          | RW          | 0x0                | grf_dsi_dpicolorm<br>DSI dpi colorm                                                                                                |
| 0          | RW          | 0x0                | grf_dsi_dpishutdn<br>DSI dpi shut down                                                                                             |

**GRF SOC CON6**

Address: Operational Base(0xFF288000) + 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         | RW          | 0x0                | grf_dsiphy_txskewcalhs_3<br>Request to transmit skew calibration on lane3.<br>1'b1: Request<br>1'b0: Idle                          |
| 14         | RW          | 0x0                | grf_dsiphy_txskewcalhs_2<br>Request to transmit skew calibration on lane2.<br>1'b1: Request<br>1'b0: Idle                          |
| 13         | RW          | 0x0                | grf_dsiphy_txskewcalhs_1<br>Request to transmit skew calibration on lane1.<br>1'b1: Request<br>1'b0: Idle                          |
| 12         | RW          | 0x0                | grf_dsiphy_txskewcalhs_0<br>Request to transmit skew calibration on lane0.<br>1'b1: Request<br>1'b0: Idle                          |
| 11         | RW          | 0x0                | grf_dsiphy_txskewcalhs_ck<br>Request to transmit skew calibration on clock lane.<br>1'b1: Request<br>1'b4: Idle                    |
| 10         | RO          | 0x0                | reserved                                                                                                                           |
| 9          | RW          | 0x0                | grf_dsiphy_phyenable_1<br>DSI TX PHY enable of lane1.<br>1'b0: Disable<br>1'b1: Enable                                             |
| 8          | RW          | 0x0                | grf_dsiphy_phyenable_0<br>DSI TX PHY enable of lane0.<br>1'b0: Disable<br>1'b1: Enable                                             |
| 7          | RW          | 0x0                | grf_dsiphy_lane3_frctxstopm<br>Force DSI TX PHY lane3 into transmit mode and generate stop state<br>1'b0: Disable<br>1'b1: Enable  |
| 6          | RW          | 0x0                | grf_dsiphy_lane2_frctxstopm<br>Force DSI TX PHY lane2 into transmit mode and generate stop state<br>1'b0: Disable<br>1'b1: Enable  |
| 5          | RW          | 0x0                | grf_dsiphy_lane1_frctxstopm<br>Force DSI TX PHY lane1 into transmit mode and generate stop state<br>1'b0: Disable<br>1'b1: Enable  |
| 4          | RW          | 0x0                | grf_dsiphy_lane0_frctxstopm<br>Force DSI TX PHY lane0 into transmit mode and generate stop state<br>1'b0: Disable<br>1'b1: Enable  |
| 3          | RO          | 0x0                | reserved                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | grf_dsiphy_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          | RO          | 0x0                | reserved                                                                                                                                                                             |
| 0          | RW          | 0x0                | grf_dsiphy_forcerxmode<br>Force DSI TX PHY lane module into Receive mode, wait for stop state<br>1'b0: Disable<br>1'b1: Enable                                                       |

### **GRF SOC CON7**

Address: Operational Base(0xFF288000) + 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:7       | RO          | 0x000              | reserved                                                                                                                           |
| 6          | RW          | 0x0                | otg1_dbnce_fltr_bypass<br>USB OTG1 debounce filter bypass                                                                          |
| 5:4        | RW          | 0x0                | otg1_scaledown_mode<br>USB OTG1 scale down mode                                                                                    |
| 3          | RO          | 0x0                | reserved                                                                                                                           |
| 2          | RW          | 0x0                | otg0_dbnce_fltr_bypass<br>USB OTG0 debounce filter bypass                                                                          |
| 1:0        | RW          | 0x0                | otg0_scaledown_mode<br>USB OTG0 scale down mode                                                                                    |

### **GRF SOC CON8**

Address: Operational Base(0xFF288000) + 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:9       | RO          | 0x00               | reserved                                                                                                                                                                                                                                        |
| 8          | RW          | 0x0                | mac0_ptp_aux_ts_trig<br>Auxiliary Time Stamp Trigger.<br>This signal is asserted to take an auxiliary snapshot of the time and store it in the auxiliary time stamp FIFO. A rising edge on this port is used to trigger the auxiliary snapshot. |
| 7          | RW          | 0x0                | mac0_mcg_pst_trig<br>Trigger Input to the DUT to capture presentation time.                                                                                                                                                                     |
| 6          | RW          | 0x0                | mac0_mcg_pst_trig_sel<br>Trigger Input to the DUT to capture presentation time. From IO or software.<br>1'b1: From IO<br>1'b0: From mac_mcg_pst_trig.                                                                                           |
| 5          | RW          | 0x0                | mac0_extclk_sel<br>1'b0: select TX clock from CRU<br>1'b1: select TX clock from IO                                                                                                                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------|
| 4:3        | RW          | 0x0                | mac0_rmii_txclk_sel<br>Mac clock divide sel.<br>2'b00: 2.5Mhz<br>2'b01: 25Mhz<br>Others: Reserved |
| 2          | RW          | 0x0                | mac0_rmii_gate_en<br>If this bit set to 1'b1, this bit will gate RMII clk.                        |
| 1          | RW          | 0x0                | mac0_rmii_mode<br>If using RMII mode, set this bit to 1'b1, otherwise set this bit to 1'b0.       |
| 0          | RW          | 0x0                | mac0_sbd_flowctrl<br>Sideband signal to transmit control packet or active backpressure.           |

**GRF SOC CON9**

Address: Operational Base(0xFF288000) + 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:0       | RW          | 0x0000             | saradc_ana_reg<br>SARADC analog register configuration                                                                             |

**GRF SOC CON10**

Address: Operational Base(0xFF288000) + 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:10      | RO          | 0x00               | reserved                                                                                                                           |
| 9          | RW          | 0x0                | grf_con_wdt1_reset_to_io_en<br>WDT1 timeout reset to io<br>1'b0: Disable<br>1'b1: Enable                                           |
| 8          | RW          | 0x0                | grf_con_wdt0_reset_to_io_en<br>WDT0 timeout reset to io<br>1'b0: Disable<br>1'b1: Enable                                           |
| 7:4        | RO          | 0x0                | reserved                                                                                                                           |
| 3          | RW          | 0x0                | wdt1_speedup<br>WDT1 speed up enable.<br>1'b0: Disable<br>1'b1: Enable                                                             |
| 2          | RW          | 0x0                | wdt1_pause_en<br>WDT1 pause enable.<br>1'b0: Disable<br>1'b1: Enable                                                               |
| 1          | RW          | 0x0                | wdt0_speedup<br>WDT0 speed up 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                | wdt0_pause_en<br>WDT0 pause enable.<br>1'b0: Disable<br>1'b1: Enable |

**GRF SOC CON11**

Address: Operational Base(0xFF288000) + 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:9       | RO          | 0x00               | reserved                                                                                                                                                                                                                                        |
| 8          | RW          | 0x0                | mac1_ptp_aux_ts_trig<br>Auxiliary Time Stamp Trigger.<br>This signal is asserted to take an auxiliary snapshot of the time and store it in the auxiliary time stamp FIFO. A rising edge on this port is used to trigger the auxiliary snapshot. |
| 7          | RW          | 0x0                | mac1_mcg_pst_trig<br>Trigger Input to the DUT to capture presentation time.                                                                                                                                                                     |
| 6          | RW          | 0x0                | mac1_mcg_pst_trig_sel<br>Trigger Input to the DUT to capture presentation time. From IO or software.<br>1'b1: From IO<br>1'b0: From mac_mcg_pst_trig.                                                                                           |
| 5          | RW          | 0x0                | mac1_extclk_sel<br>1'b0: select TX clock from CRU<br>1'b1: select TX clock from IO                                                                                                                                                              |
| 4:3        | RW          | 0x0                | mac1_rmii_txclk_sel<br>Mac clock divide sel.<br>2'b00: 2.5Mhz<br>2'b01: 25Mhz<br>Others: Reserved                                                                                                                                               |
| 2          | RW          | 0x0                | mac1_rmii_gate_en<br>If this bit set to 1'b1, this bit will gate RMII clk.                                                                                                                                                                      |
| 1          | RW          | 0x0                | mac1_rmii_mode<br>If using RMII mode, set this bit to 1'b1, otherwise set this bit to 1'b0.                                                                                                                                                     |
| 0          | RW          | 0x0                | mac1_sbd_flowctrl<br>Sideband signal to transmit control packet or active backpressure.                                                                                                                                                         |

**GRF SOC CON13**

Address: Operational Base(0xFF288000) + 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:8       | RO          | 0x00               | reserved                                                                                                                           |
| 7          | RW          | 0x0                | timer1ch5_dsmc_intr_intmux_sel<br>TIMER1_CH5 and DSMC interrupt to INTMUX selection<br>1'b0: DSMC<br>1'b1: TIMER1_CH5              |

| Bit | Attr | Reset Value | Description                                                                                                     |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------|
| 6   | RW   | 0x0         | timer1ch5_dsmc_intr_mcu_sel<br>TIMER1_CH5 and DSMC interrupt to MCU selection<br>1'b0: DSMC<br>1'b1: TIMER1_CH5 |
| 5   | RW   | 0x0         | gpio1_3_intr_intmux_sel<br>GPIO1_3 interrupt to INTMUX selection<br>1'b0: GPIO1<br>1'b1: GPIO1_SHADOW           |
| 4   | RW   | 0x0         | gpio1_2_intr_intmux_sel<br>GPIO1_2 interrupt to INTMUX selection<br>1'b0: GPIO1<br>1'b1: GPIO1_SHADOW           |
| 3   | RW   | 0x0         | gpio1_1_intr_intmux_sel<br>GPIO1_1 interrupt to INTMUX selection<br>1'b0: GPIO1<br>1'b1: GPIO1_SHADOW           |
| 2   | RW   | 0x0         | gpio1_3_intr_mcu_sel<br>GPIO1_3 interrupt to MCU selection<br>1'b0: GPIO1<br>1'b1: GPIO1_SHADOW                 |
| 1   | RW   | 0x0         | gpio1_2_intr_mcu_sel<br>GPIO1_2 interrupt to MCU selection<br>1'b0: GPIO1<br>1'b1: GPIO1_SHADOW                 |
| 0   | RW   | 0x0         | gpio1_1_intr_mcu_sel<br>GPIO1_1 interrupt to MCU selection<br>1'b0: GPIO1<br>1'b1: GPIO1_SHADOW                 |

**GRF SOC CON14**

Address: Operational Base(0xFF288000) + offset (0x0038)

| 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         | ddr_probe_suspend<br>DDR probe suspend<br>1'b0: Not suspend<br>1'b1: Suspend                                                                                                                                            |
| 11    | RW   | 0x1         | corep_to_core_stall<br>Response type when BIU_CORE or BIU_DSMC_FLEXBUS in idle state and DSMC_FLEXBUS access CORE.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted |
| 10    | RW   | 0x1         | core_to_corep_stall<br>Response type when BIU_CORE or BIU_DSMC_FLEXBUS in idle state and CORE access DSMC_FLEXBUS.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9          | RW          | 0x1                | core_to_ddr_stall<br>Response type when BIU_CORE or BIU_DDR in idle state and CORE access DDR.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted       |
| 8          | RW          | 0x1                | core_to_bus_stall<br>Response type when BIU_CORE or BIU_BUS in idle state and CORE access BUS.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted       |
| 7          | RW          | 0x1                | hsperi_to_bus_stall<br>Response type when BIU_HSPERI or BIU_BUS in idle state and HSPERI access BUS.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted |
| 6          | RW          | 0x1                | vio_to_ddr_stall<br>Response type when BIU_VIO or BIU_DDR in idle state and VIO access DDR.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted          |
| 5          | RO          | 0x0                | reserved                                                                                                                                                                                                  |
| 4          | RW          | 0x1                | bus_to_vio_stall<br>Response type when BIU_BUS or BIU_VIO in idle state and BUS access VIO.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted          |
| 3          | RW          | 0x1                | bus_to_lsperi_stall<br>Response type when BIU_BUS or BIU_LSPERI in idle state and BUS access LSPERI.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted |
| 2          | RW          | 0x1                | bus_to_hsperi_stall<br>Response type when BIU_BUS or BIU_HSPERI in idle state and BUS access HSPERI.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted |
| 1          | RW          | 0x1                | bus_to_ddr_stall<br>Response type when BIU_BUS or BIU_DDR in idle state and BUS access DDR.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted          |
| 0          | RW          | 0x1                | mcu_to_core_stall<br>Response type when BIU_MCU or BIU_CORE in idle state and MCU access CORE.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted       |

**GRF SOC CON15**

Address: Operational Base(0xFF288000) + offset (0x003C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<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                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13         | RW          | 0x0                | grf_con_ddrc_wr_mask_by_hpr<br>1'b0: The DDRCTL write commands will go to critical state according to write urgent and ignores the number of HPR credits.<br>1'b1: The DDRCTL write commands will go to critical state according to write urgent and when the HPR credits is equal to hpr_entry_num. |
| 12:7       | RW          | 0x00               | grf_con_ddrc_hpr_entry_num<br>The HPR entry numbers that used to make write command go to critical when wr_mask_by_hpr is set to 1'b1. If wr_mask_by_hpr is set to 1'b0, hpr_entry_num is not used.                                                                                                  |
| 6          | RW          | 0x0                | grf_con_ddrc_rrbtoken_empty2critical<br>1'b0: The DDRCTL read commands will go to critical state controlled by read urgent.<br>1'b1: The DDRCTL read commands will go to critical state controlled by read urgent and when reorder buffer read token is empty.                                       |
| 5          | RW          | 0x0                | grf_con_ddrc_wr_full2critical<br>1'b0: The DDRCTL write commands will go to critical state controlled by write urgent.<br>1'b1: The DDRCTL write commands will go to critical state controlled by write urgent and when write credits are empty.                                                     |
| 4          | RW          | 0x0                | grf_con_ddrc_hpr_full2critical<br>1'b0: The DDRCTL read commands will go to critical state controlled by read urgent.<br>1'b1: The DDRCTL read commands will go to critical state controlled by read urgent and when HPR credits are empty.                                                          |
| 3          | RW          | 0x0                | grf_con_ddrc_lpr_full2critical<br>1'b0: The DDRCTL read commands will go to critical state controlled by read urgent.<br>1'b1: The DDRCTL read commands will go to critical state controlled by read urgent and when LPR credits are empty.                                                          |
| 2:0        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                             |

**GRF SOC CON16**

Address: Operational Base(0xFF288000) + 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:13      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                            |
| 12         | RW          | 0x0                | grf_con_selfref_type2_en<br>1'b0: Only allowed core clock of DDRCTL to be gated when SDRAM's self-refresh is caused by automatic self-refresh.<br>1'b1: Allowed core clock of DDRCTL to be gated when SDRAM's self-refresh is not caused by automatic self-refresh. |
| 11:8       | RW          | 0x6                | grf_con_ddrc_auto_sr_dly<br>When SDRAM is in self-refresh state whose type is indicated by grf_con_selfref_type2_en, the core clock of DDRCTL will be gated after grf_con_ddrc_auto_sr_dly clocks.                                                                  |
| 7          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6          | RW          | 0x0                | grf_con_ddrctl_sysreq_cg_en<br>1'b0: Core clock of DDRCTL is allowed to be gated when<br>csysreq_ddrc^csysack_ddrc==1.<br>1'b1: Core clock of DDRCTL would not be gated when<br>csysreq_ddrc^csysack_ddrc==1.                                                                                                |
| 5          | RW          | 0x0                | grf_con_ddrctl_core_cg_en<br>1'b0: Do not gate core clock of DDRCTL<br>1'b1: Gate core clock of DDRCTL unless following two case:<br>Case1: grf_con_ddrctl_apb_cg_en==1'b1 and the APB slave<br>select of DDRCTL is asserted<br>Case2: grf_con_ddrctl_sysreq_cg_en==1'b1 and<br>csysreq_ddrc^csysack_ddrc==1 |
| 4          | RW          | 0x0                | grf_con_ddrctl_apb_cg_en1<br>1'b0: Axi1 clock and core clock of DDRCTL is allowed to be gated<br>when APB slave select of DDRCTL is asserted.<br>1'b1: Axi1 clock and core clock of DDRCTL would not be gated<br>when APB slave select of DDRCTL is asserted.                                                |
| 3          | RW          | 0x0                | grf_con_ddrctl_apb_cg_en0<br>1'b0: Axi0 clock and core clock of DDRCTL is allowed to be gated<br>when APB slave select of DDRCTL is asserted.<br>1'b1: Axi0 clock and core clock of DDRCTL would not be gated<br>when APB slave select of DDRCTL is asserted.                                                |
| 2          | RW          | 0x0                | grf_con_ddrctl_axi1_cg_en<br>1'b0: Do not gate axi1 clock of DDRCTL<br>1'b1: Gate axi1 clock of DDRCTL unless<br>grf_con_ddrctl_apb_cg_en1==1'b1 and the APB slave select of<br>DDRCTL is asserted.                                                                                                          |
| 1          | RW          | 0x0                | grf_con_ddrctl_axi0_cg_en<br>1'b0: Do not gate axi0 clock of DDRCTL<br>1'b1: Gate axi0 clock of DDRCTL unless<br>grf_con_ddrctl_apb_cg_en0==1'b1 and the APB slave select of<br>DDRCTL is asserted.                                                                                                          |
| 0          | RW          | 0x0                | grf_con_upctl2_scramble_gate_dis<br>Scramble clock gating disable<br>1'b0: The clock of scramble is gating controlled scramble_bypass<br>1'b1: The clock of scramble is always enable                                                                                                                        |

### **GRF SOC CON17**

Address: Operational Base(0xFF288000) + 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:14      | RW          | 0x0                | grf_con_arautopre<br>Connected to the DDRCTL's input signal 'arautopre'. The<br>'arautopre' is AXI auto-precharge signal for read command.                  |
| 13:12      | RW          | 0x0                | grf_con_awpoison<br>Connected to the DDRCTL's input signal 'awpoison'. The<br>'awpoison' is an off-band signal to indicate an invalid write<br>transaction. |
| 11:10      | RW          | 0x0                | grf_con_awurgent<br>Connected to the DDRCTL's input AXI write urgent signal<br>'awurgent'.                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:8        | RW          | 0x0                | grf_con_arpoison<br>Connected to the DDRCTL's input signal 'arpoison'. The 'arpoison' is a sideband signal to indicate an invalid read transaction. |
| 7:6        | RW          | 0x0                | grf_con_arurgent<br>Connected to the DDRCTL's input AXI read urgent signal 'arurgent'.                                                              |
| 5:4        | RW          | 0x0                | grf_con_pa_wmask<br>Connected to the DDRCTL's input write port mask signal 'pa_wmask'.                                                              |
| 3:0        | RW          | 0x0                | grf_con_pa_rmask<br>Connected to DDRCTL's input read port mask signal 'pa_rmask'.                                                                   |

**GRF SOC CON18**

Address: Operational Base(0xFF288000) + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<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:10      | RW          | 0x00               | grf_con_ddrc_press_queue_wait_limit<br>The press queue wait limit time of DDRCTL's urgent control module.                                                                                                                                                                                   |
| 9:8        | RW          | 0x0                | grf_con_ddrc_press_policy<br>The press policy of DDRCTL's urgent control module.                                                                                                                                                                                                            |
| 7:6        | RW          | 0x0                | grf_con_ddrc_press_rdwr_order<br>Read/write order enable of DDRCTL's urgent control module. Each bit is corresponding to DDRCTL's AXI port 0~1 respectively. For example, press_rdwr_order[0] is used to control AXI port 0, press_rdwr_order[1] is used to control AXI port 1 and so on.   |
| 5:4        | RW          | 0x0                | grf_con_ddrc_press_cg_en<br>Clock gate enable of DDRCTL's urgent control module. Each bit is corresponding to DDRCTL's AXI port 0~1 respectively.<br>1'b0: Disable<br>1'b1: Enable<br>If the DDRCTL's urgent control module is not used, please set press_cg_en[1:0] to 2'h3 to save power. |
| 3:2        | RW          | 0x0                | grf_con_ddrc_press_en<br>Press enable, bit0 for port0 and bit1 for port1                                                                                                                                                                                                                    |
| 1:0        | RW          | 0x0                | grf_con_awautopre<br>Connected to the DDRCTL's input signal 'awautopre'. The 'awautopre' is AXI auto-precharge signal for write command.                                                                                                                                                    |

**GRF SOC CON19**

Address: Operational Base(0xFF288000) + 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:14      | RO          | 0x0                | reserved                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:12      | RW          | 0x0                | grf_con_ddrc_awqos_urgent_en<br>Enable the urgent mechanism of DDRCTL's AXI write port 0~1 according to the Aw-QoS. Each bit is corresponding to DDRCTL's AXI write port 0~1 respectively. For example, awqos_urgent_en[0] is used to enable AXI write port 0, awqos_urgent_en[1] is used to enable AXI write port 1 and so on.<br>1'b0: Disable<br>1'b1: Enable |
| 11:10      | RW          | 0x0                | grf_con_ddrc_arqos_urgent_en<br>Enable the urgent mechanism of DDRCTL's AXI read port 0~1 according to the Ar-QoS. Each bit is corresponding to DDRCTL's AXI read port 0~1 respectively. For example, arqos_urgent_en[0] is used to enable AXI read port 0, arqos_urgent_en[1] is used to enable AXI read port 1 and so on.<br>1'b0: Disable<br>1'b1: Enable     |
| 9          | RW          | 0x0                | grf_con_csysreq_axi_ddrlpc<br>1'b0: The hardware low power request signal of AXI block, is not related to DDR_LPC low power module.<br>1'b1: The hardware low power request signal of AXI block, can be generated by DDR_LPC low power module.                                                                                                                   |
| 8          | RW          | 0x0                | grf_con_csysreq_axi_pmu<br>1'b0: The hardware low power request signal of AXI block, is not related to PMU.<br>1'b1: The hardware low power request signal of AXI block, can be generated by PMU.                                                                                                                                                                |
| 7          | RW          | 0x0                | grf_con_csysreq_ddrc_ddrlpc<br>1'b0: The hardware low power request signal of DDRCTL, is not related to DDR_LPC low power module.<br>1'b1: The hardware low power request signal of DDRCTL, can be generated by DDR_LPC low power module.                                                                                                                        |
| 6          | RW          | 0x0                | grf_con_csysreq_ddrc_pmu<br>1'b0: The hardware low power request signal of DDRCTL, is not related to PMU.<br>1'b1: The hardware low power request signal of DDRCTL, can be generated by PMU.                                                                                                                                                                     |
| 5          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                         |
| 4          | RW          | 0x0                | grf_con_dfi_init_complete<br>When grf_con_dfi_init_complete_sel==1'b1, this signal is selected as DDRCTL's input signal, dfi_init_complete.                                                                                                                                                                                                                      |
| 3          | RW          | 0x0                | grf_con_dfi_init_complete_sel<br>1'b0: DDRCTL's input signal, dfi_init_complete, is generated by DDR PHY.<br>1'b1: DDRCTL's input signal, dfi_init_complete, is connected from grf_con_dfi_init_complete.                                                                                                                                                        |
| 2          | RW          | 0x0                | grf_con_dfi_init_start<br>When grf_con_dfi_init_start_sel==1'b1, this signal is selected as DDRPHY's input signal, dfi_init_start.                                                                                                                                                                                                                               |
| 1          | RW          | 0x0                | grf_con_dfi_init_start_sel<br>1'b0: DDRPHY's input signal, dfi_init_start, is generated by DDR_LPC low power module, dfi_ctl module or DDRCTL.<br>1'b1: DDRPHY's input signal, dfi_init_start, is connected from grf_con_dfi_init_start.                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | grf_con_upctl_slverr_enable<br>1'b0: Disable DDRCTL APB slave error respond.<br>1'b1: Enable DDRCTL APB slave error respond. |

### **GRF SOC CON20**

Address: Operational Base(0xFF288000) + 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          | 0x00               | grf_con_press_aw_th<br>Write QoS threshold.                                                                                        |
| 7:0        | RW          | 0x00               | grf_con_press_ar_th<br>Read QoS threshold.                                                                                         |

### **GRF SOC CON21**

Address: Operational Base(0xFF288000) + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 11:0       | RW          | 0x021              | mem_cfg_uhdspra<br>Single port memory timing adjustment setting for debug purpose.<br>[1:0]: RTSEL for Standard voltage threshold and all column mux option<br>[3:2]: WTSEL for Standard voltage threshold and all column mux option<br>[5:4]: RTSEL for high voltage threshold and column mux option equal to 1,2<br>[7:6]: WTSEL for high voltage threshold and column mux option equal to 1,2<br>[9:8]: RTSEL for high voltage threshold and column mux option equal to 4<br>[11:10]: WTSEL for high voltage threshold and column mux option equal to 4 |

### **GRF SOC CON22**

Address: Operational Base(0xFF288000) + 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:6       | RO          | 0x000              | reserved                                                                                                                           |
| 5:0        | RW          | 0x00               | mem_cfg_uhddpra<br>Dual port memory timing adjustment setting for debug purpose.<br>[1:0]: RTSEL<br>[3:2]: WTSEL<br>[5:4]: PTSEL   |

### **GRF SOC CON23**

Address: Operational Base(0xFF288000) + offset (0x005C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                          |
| 11:0       | RW          | 0x155              | mem_cfg_rom<br>ROM memory timing adjustment setting for debug purpose.<br>[1:0]: PTSEL_M<br>[3:2]: RTSEL_M<br>[5:4]: TRB_M<br>[7:6]: PTSEL_F<br>[9:8]: RTSEL_F<br>[11:10]: TRBT_F |

**GRF SOC CON24**

Address: Operational Base(0xFF288000) + 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          | 0x1                | usbotg0_utmi_bvalid<br>Software configuration for usbotg_utmi_bvalid.                                                                                              |
| 14         | RW          | 0x0                | usbotg0_utmi_bvalid_sel<br>usbotg_utmi_bvalid selection.<br>1'b0: usbotg_utmi_bvalid comes from USB PHY<br>1'b1: usbotg_utmi_bvalid comes from usbotg0_utmi_bvalid |
| 13:12      | RO          | 0x0                | reserved                                                                                                                                                           |
| 11         | RW          | 0x1                | usbotg0_utmi_idpullup<br>usbotg_utmi_idpullup configuration.                                                                                                       |
| 10         | RW          | 0x1                | usbotg0_utmi_iddig<br>Software configuration for usbotg_utmi_iddig.                                                                                                |
| 9          | RW          | 0x0                | usbotg0_utmi_iddig_sel<br>usbotg_utmi_iddig selection.<br>1'b0: usbotg_utmi_iddig comes from USB PHY<br>1'b1: usbotg_utmi_iddig comes from usbotg0_utmi_iddig      |
| 8          | RW          | 0x0                | usbotg0_utmi_dmpulldown<br>Software configuration for usbotg_utmi_dmpulldown when usbphy_sw_en is high.                                                            |
| 7          | RW          | 0x0                | usbotg0_utmi_dppulldown<br>Software configuration for usbotg_utmi_dppulldown when usbphy_sw_en is high.                                                            |
| 6          | RW          | 0x1                | usbotg0_utmi_termselect<br>Software configuration for usbotg_utmi_termselect when usbphy_sw_en is high.                                                            |
| 5:4        | RW          | 0x1                | usbotg0_utmi_xcvrselect<br>Software configuration for usbotg_utmi_xcvrselect when usbphy_sw_en is high.                                                            |
| 3:2        | RW          | 0x0                | usbotg0_utmi_opmode<br>Software configuration for usbotg_utmi_opmode when usbphy_sw_en is high.                                                                    |
| 1          | RW          | 0x1                | usbotg0_utmi_suspend_n<br>Software configuration for usbotg_utmi_suspend_n when usbphy_sw_en is high.                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | usb0_sw_en<br>USB OTG0 software configuration enable.<br>1'b0: Disable<br>1'b1: Enable |

**GRF SOC CON25**

Address: Operational Base(0xFF288000) + 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:10      | RO          | 0x00               | reserved                                                                                                                                                   |
| 9          | RW          | 0x0                | usb0_utmi_fs_se0<br>Serial mode communication SE0 data                                                                                                     |
| 8          | RW          | 0x0                | usb0_utmi_fs_data<br>Serial mode communication data                                                                                                        |
| 7          | RW          | 0x1                | usb0_utmi_fs_oe<br>Serial mode communication output enable                                                                                                 |
| 6          | RW          | 0x0                | usb0_utmi_fs_xver_own<br>Serial mode communication enable                                                                                                  |
| 5:4        | RO          | 0x0                | reserved                                                                                                                                                   |
| 3          | RW          | 0x0                | usb0_utmi_valid<br>Software configuration for usbhost_utmi_valid.                                                                                          |
| 2          | RW          | 0x0                | usb0_utmi_valid_sel<br>usb0_utmi_valid selection.<br>1'b0: usb0_utmi_valid comes from USBPHY<br>1'b1: usb0_utmi_valid comes from usb0_utmi_valid           |
| 1          | RW          | 0x0                | usb0_utmi_sessend<br>Software configuration for usbhost_utmi_sessend.                                                                                      |
| 0          | RW          | 0x0                | usb0_utmi_sessend_sel<br>usb0_utmi_sessend selection.<br>1'b0: usb0_utmi_sessend comes from USBPHY<br>1'b1: usb0_utmi_sessend comes from usb0_utmi_sessend |

**GRF SOC CON26**

Address: Operational Base(0xFF288000) + offset (0x0068)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 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                | usb0_utmi_dischrgvbus<br>usb0_utmi_dischrgvbus configuration.                                                                                               |
| 7          | RW          | 0x0                | usb0_utmi_chrgvbus<br>usb0_utmi_chrgvbus configuration.                                                                                                     |
| 6          | RO          | 0x0                | reserved                                                                                                                                                    |
| 5          | RW          | 0x0                | usb0_utmi_drvvbus<br>Software configuration for usb0_utmi_drvvbus.                                                                                          |
| 4          | RW          | 0x0                | usb0_utmi_drvvbus_sel<br>usb0_utmi_drvvbus selection.<br>1'b0: usb0_utmi_drvvbus comes from USB PHY<br>1'b1: usb0_utmi_drvvbus comes from usb0_utmi_drvvbus |
| 3:0        | RO          | 0x0                | reserved                                                                                                                                                    |

**GRF SOC CON27**

Address: Operational Base(0xFF288000) + 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:14      | RW          | 0x0                | usbphy_bc_weakpulldown_tune<br>Software configuration for usbphy_bc_weakpulldown_tune.                                             |
| 13:12      | RW          | 0x0                | usbphy_bc_weakpullup_tune<br>Software configuration for usbphy_bc_weakpullup_tune.                                                 |
| 11         | RW          | 0x0                | usbphy_bc_weakpulldown_en<br>Software configuration for usbphy_bc_weakpulldown_en.                                                 |
| 10         | RW          | 0x0                | usbphy_bc_weakpullup_en<br>Software configuration for usbphy_bc_weakpullup_en.                                                     |
| 9          | RW          | 0x0                | usbphy_force_dcp_det<br>Software configuration for usbphy_force_dcp_det.                                                           |
| 8          | RW          | 0x0                | usbphy_force_cp_det<br>Software configuration for usbphy_force_cp_det.                                                             |
| 7          | RW          | 0x0                | usbphy_force_dp_attached<br>Software configuration for usbphy_force_dp_attached.                                                   |
| 6          | RW          | 0x0                | usbphy_charge_det_byp<br>Software configuration for usbphy_charge_det_byp.                                                         |
| 5          | RW          | 0x0                | usbphy_vdm_src_en<br>Software configuration for usbphy_vdm_src_en.                                                                 |
| 4          | RW          | 0x0                | usbphy_vdp_src_en<br>Software configuration for usbphy_vdp_src_en.                                                                 |
| 3          | RW          | 0x0                | usbphy_rdm_pdwn_en<br>Software configuration for usbphy_rdm_pdwn_en.                                                               |
| 2          | RW          | 0x0                | usbphy_idp_src_en<br>Software configuration for usbphy_idp_src_en.                                                                 |
| 1          | RW          | 0x0                | usbphy_idm_sink_en<br>Software configuration for usbphy_idm_sink_en.                                                               |
| 0          | RW          | 0x0                | usbphy_idp_sink_en<br>Software configuration for usbphy_idp_sink_en.                                                               |

**GRF SOC CON28**

Address: Operational Base(0xFF288000) + 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         | RW          | 0x1                | usbotg1_utmi_bvalid<br>Software configuration for usbotg1_utmi_bvalid.                                                                                      |
| 14         | RW          | 0x0                | usbotg1_utmi_bvalid_sel<br>usbotg1_utmi_bvalid selection.<br>1'b0: usbotg1_utmi_bvalid tie high<br>1'b1: usbotg1_utmi_bvalid comes from usbotg1_utmi_bvalid |
| 13:11      | RO          | 0x0                | reserved                                                                                                                                                    |
| 10         | RW          | 0x1                | usbotg1_utmi_iddig<br>Software configuration for usbotg1_utmi_iddig.                                                                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9          | RW          | 0x0                | usbotg1_utmi_iddig_sel<br>usbhost_utmi_iddig selection.<br>1'b0: usbhost_utmi_iddig comes from USB PHY<br>1'b1: usbhost_utmi_iddig comes from usbotg1_utmi_iddig |
| 8          | RW          | 0x0                | usbotg1_utmi_dmpulldown<br>Software configuration for usbhost_utmi_dmpulldown when<br>usbhost_sw_en is high.                                                     |
| 7          | RW          | 0x0                | usbotg1_utmi_dppulldown<br>Software configuration for usbhost_utmi_dppulldown when<br>usbhost_sw_en is high.                                                     |
| 6          | RW          | 0x1                | usbotg1_utmi_termselect<br>Software configuration for usbhost_utmi_termselect when<br>usbhost_sw_en is high.                                                     |
| 5:4        | RW          | 0x1                | usbotg1_utmi_xcvrselect<br>Software configuration for usbhost_utmi_xcvrselect when<br>usbhost_sw_en is high.                                                     |
| 3:2        | RW          | 0x0                | usbotg1_utmi_opmode<br>Software configuration for usbhost_utmi_opmode when<br>usbhost_sw_en is high.                                                             |
| 1          | RW          | 0x1                | usbotg1_utmi_suspend_n<br>Software configuration for usbhost_utmi_suspend_n when<br>usbhost_sw_en is high.                                                       |
| 0          | RW          | 0x0                | usbotg1_sw_en<br>USB OTG1 software configuration enable.<br>1'b0: Disable<br>1'b1: Enable                                                                        |

**GRF SOC CON29**

Address: Operational Base(0xFF288000) + 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               |
| 15:10      | RO          | 0x00               | reserved                                                                                                                                         |
| 9          | RW          | 0x0                | usbotg1_utmi_fs_se0<br>Serial mode communication SE0 data                                                                                        |
| 8          | RW          | 0x0                | usbotg1_utmi_fs_data<br>Serial mode communication data                                                                                           |
| 7          | RW          | 0x1                | usbotg1_utmi_fs_oe<br>Serial mode communication output enable                                                                                    |
| 6          | RW          | 0x0                | usbotg1_utmi_fs_xver_own<br>Serial mode communication enable                                                                                     |
| 5:4        | RO          | 0x0                | reserved                                                                                                                                         |
| 3          | RW          | 0x0                | usbotg1_utmi_valid<br>Software configuration for usbhost_utmi_valid when<br>usbhost_sw_en is high.                                               |
| 2          | RW          | 0x0                | usbotg1_utmi_valid_sel<br>usbhost_utmi_valid selection.<br>1'b0: usbotg1_utmi_valid tie high<br>1'b1: usbotg1_utmi_valid comes from SOC_CON29[3] |
| 1          | RW          | 0x0                | usbotg1_utmi_sessend<br>Software configuration for usbhost_utmi_sessend.                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | usbotg1_utmi_sessend_sel<br>usbhost_utmi_sessend selection.<br>1'b0: usbotg_utmi_sessend tie low<br>1'b1: usbotg_utmi_sessend comes from usbotg1_utmi_sessend |

**GRF SOC CON30**

Address: Operational Base(0xFF288000) + 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         | RW          | 0x0                | grf_dsmc_req0_dmac_sel<br>1'b0: DMAC0 channel 2<br>1'b1: DMAC0 channel 8                                                           |
| 14         | RW          | 0x0                | grf_dsmc_req1_dmac_sel<br>1'b0: DMAC0 channel 3<br>1'b1: DMAC0 channel 10                                                          |
| 13:12      | RW          | 0x0                | grf_can1_rx_dmac_sel<br>2'b00: DMAC0 channel 1<br>2'b01: DMAC1 channel 11<br>2'b10: DMAC0 channel 5<br>2'b11: Reserved             |
| 11:10      | RW          | 0x0                | grf_can0_rx_dmac_sel<br>2'b00: DMAC0 channel 0<br>2'b01: DMAC1 channel 10<br>2'b10: DMAC0 channel 4<br>2'b11: Reserved             |
| 9:0        | RO          | 0x000              | reserved                                                                                                                           |

**GRF SOC CON31**

Address: Operational Base(0xFF288000) + offset (0x007C)

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

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:10 | RW   | 0x00        | <p>grf_gpio234_filter_sel1<br/>         GPIO select to go through second filter logic<br/>         6'h00: GPIO2A0<br/>         6'h01: GPIO2A1<br/>         6'h02: GPIO2A2<br/>         6'h03: GPIO2A3<br/>         6'h04: GPIO2A4<br/>         6'h05: GPIO2A5<br/>         6'h06: GPIO2B0<br/>         6'h07: GPIO2B1<br/>         6'h08: GPIO2B2<br/>         6'h09: GPIO2B3<br/>         6'h0a: GPIO2B4<br/>         6'h0b: GPIO2B5<br/>         6'h0c: GPIO2B6<br/>         6'h0d: GPIO2B7<br/>         6'h0d: GPIO2C0<br/>         6'h0f: GPIO3A0<br/>         6'h10: GPIO3A1<br/>         6'h11: GPIO3A2<br/>         6'h12: GPIO3A3<br/>         6'h13: GPIO3A4<br/>         6'h14: GPIO3A5<br/>         6'h15: GPIO3A6<br/>         6'h16: GPIO3A7<br/>         6'h17: GPIO3B0<br/>         6'h18: GPIO3B1<br/>         6'h19: GPIO3B2<br/>         6'h1a: GPIO3B3<br/>         6'h1b: GPIO3B4<br/>         6'h1c: GPIO3B5<br/>         6'h1d: GPIO3B6<br/>         6'h1e: GPIO4B0<br/>         6'h1f: GPIO4B1<br/>         6'h20: GPIO4B2<br/>         6'h21: GPIO4B3</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:4        | RW          | 0x00               | grf_gpio234_filter_sel0<br>GPIO select to go through first filter logic<br>6'h00: GPIO2A0<br>6'h01: GPIO2A1<br>6'h02: GPIO2A2<br>6'h03: GPIO2A3<br>6'h04: GPIO2A4<br>6'h05: GPIO2A5<br>6'h06: GPIO2B0<br>6'h07: GPIO2B1<br>6'h08: GPIO2B2<br>6'h09: GPIO2B3<br>6'h0a: GPIO2B4<br>6'h0b: GPIO2B5<br>6'h0c: GPIO2B6<br>6'h0d: GPIO2B7<br>6'h0d: GPIO2C0<br>6'h0f: GPIO3A0<br>6'h10: GPIO3A1<br>6'h11: GPIO3A2<br>6'h12: GPIO3A3<br>6'h13: GPIO3A4<br>6'h14: GPIO3A5<br>6'h15: GPIO3A6<br>6'h16: GPIO3A7<br>6'h17: GPIO3B0<br>6'h18: GPIO3B1<br>6'h19: GPIO3B2<br>6'h1a: GPIO3B3<br>6'h1b: GPIO3B4<br>6'h1c: GPIO3B5<br>6'h1d: GPIO3B6<br>6'h1e: GPIO4B0<br>6'h1f: GPIO4B1<br>6'h20: GPIO4B2<br>6'h21: GPIO4B3 |
| 3:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 1:0        | RW          | 0x0                | grf_gpio234_filter_en<br>There are two filter circuits for GPIO2, GPIO3 and GPIO4, each bit controls the enable of one filter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

**GRF SOC CON32**

Address: Operational Base(0xFF288000) + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                                                                                  |
| 19:0       | RW          | 0x00000            | grf_gpio234_filter_count0<br>Filter counter for first filter logic. When this value is n, it will filter pulse which width is n+1 oscillator clock cycle. |

**GRF SOC CON33**

Address: Operational Base(0xFF288000) + offset (0x0084)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                                                                                   |
| 19:0       | RW          | 0x00000            | grf_gpio234_filter_count1<br>Filter counter for second filter logic. When this value is n, it will filter pulse which width is n+1 oscillator clock cycle. |

**GRF SOC CON35**

Address: Operational Base(0xFF288000) + offset (0x008C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<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          | 0x0000             | reserved                                                                                                                                                                                                |
| 9:7        | RW          | 0x0                | grf_pwm1_uart_rx_mux_sel<br>PWM1 biphasic counter UART RX mux selection<br>3'h0: UART0_RX<br>3'h1: UART1_RX<br>3'h2: UART2_RX<br>3'h3: UART3_RX<br>3'h4: UART4_RX<br>3'h5: UART5_RX<br>Others: Reserved |
| 6          | RW          | 0x0                | grf_pwm1_phase_a6_sel<br>PWM1 biphasic counter phase a6 select.<br>1'b0: From RMIO PWM1_CH6<br>1'b1: From UART RX MUX                                                                                   |
| 5          | RW          | 0x0                | grf_pwm1_phase_a5_sel<br>PWM1 biphasic counter phase a5 select.<br>1'b0: From RMIO PWM1_BIP_CNTR_A5<br>1'b1: From UART5_RX                                                                              |
| 4          | RW          | 0x0                | grf_pwm1_phase_a4_sel<br>PWM1 biphasic counter phase a4 select.<br>1'b0: From RMIO PWM1_BIP_CNTR_A4<br>1'b1: From UART4_RX                                                                              |
| 3          | RW          | 0x0                | grf_pwm1_phase_a3_sel<br>PWM1 biphasic counter phase a3 select.<br>1'b0: From RMIO PWM1_BIP_CNTR_A3<br>1'b1: From UART3_RX                                                                              |
| 2          | RW          | 0x0                | grf_pwm1_phase_a2_sel<br>PWM1 biphasic counter phase a2 select.<br>1'b0: From RMIO PWM1_BIP_CNTR_A2<br>1'b1: From UART2_RX                                                                              |
| 1          | RW          | 0x0                | grf_pwm1_phase_a1_sel<br>PWM1 biphasic counter phase a1 select.<br>1'b0: From RMIO PWM1_BIP_CNTR_A1<br>1'b1: From UART1_RX                                                                              |
| 0          | RW          | 0x0                | grf_pwm1_phase_a0_sel<br>PWM1 biphasic counter phase a0 select.<br>1'b0: From RMIO PWM1_BIP_CNTR_A0<br>1'b1: From UART0_RX                                                                              |

**GRF SOC CON36**

Address: Operational Base(0xFF288000) + offset (0x0090)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 31:26      | RO          | 0x00               | reserved                                         |
| 25:0       | RW          | 0x00000000         | grf_con_m0_stalib<br>MCU system time calibration |

**GRF SOC CON37**

Address: Operational Base(0xFF288000) + offset (0x0094)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                               |
| 15         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                         |
| 14:7       | RW          | 0x00               | grf_con_mcu_irqlatency<br>IRQLATENCY specifies the minimum number of cycles between an interrupt that becomes pended in the NVIC, and the vector fetch for that interrupt being issued on the AHB-Lite interface.                                                                                                |
| 6          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                         |
| 5          | RW          | 0x0                | grf_con_mcu_wicenreq<br>Active HIGH request for deep sleep to be WIC-based deep sleep.                                                                                                                                                                                                                           |
| 4          | RW          | 0x1                | grf_con_mcu_sleepholdreqn<br>Request to extend the processor sleeping state regardless of wake-up events. If the processor acknowledges this request driving grf_mcu_sleepholdackn low, this guarantees the processor remains idle even on receipt of a wake-up event.                                           |
| 3          | RW          | 0x0                | grf_con_mcu_rxev<br>A HIGH level on this input causes the architecture defined Event Register to be set in the Cortex-M0 processor. This causes a WFE instruction to complete. It also awakens the processor if it is sleeping as the result of encountering a WFE instruction when the Event Register is clear. |
| 2          | RW          | 0x0                | grf_con_mcu_nmi<br>Non-maskable interrupt.<br>1'b1: Assert<br>1'b0: De-assert                                                                                                                                                                                                                                    |
| 1          | RW          | 0x0                | grf_con_mcu_edbgrp<br>External debug restart request.<br>1'b1: Assert<br>1'b0: De-assert                                                                                                                                                                                                                         |
| 0          | RW          | 0x0                | grf_con_mcu_dbgrestart<br>External debug restart request.<br>1'b1: Assert<br>1'b0: De-assert                                                                                                                                                                                                                     |

### **GRF SOC CON38**

Address: Operational Base(0xFF288000) + offset (0x0098)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<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:8       | RW          | 0x00               | dmac0_intr_mask1<br>DMAC0 interrupt mask 1, each bit for one interrupt.<br>1'b0: Not masked<br>1'b1: Masked                        |
| 7:6        | RO          | 0x0                | reserved                                                                                                                           |
| 5:0        | RW          | 0x00               | dmac0_intr_mask0<br>DMAC0 interrupt mask 0, each bit for one interrupt.<br>1'b0: Not masked<br>1'b1: Masked                        |

### **GRF SOC CON39**

### RK3506 TRM (Part 1)

Address: Operational Base(0xFF288000) + offset (0x009C)

| Bit   | Attr | Reset Value | Description                                                                                                                        |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8  | RW   | 0x00        | dmac1_intr_mask0<br>DMAC1 interrupt mask 0, each bit for one interrupt.<br>1'b0: Not masked<br>1'b1: Masked                        |
| 7:6   | RO   | 0x0         | reserved                                                                                                                           |
| 5:0   | RW   | 0x00        | dmac0_intr_mask2<br>DMAC0 interrupt mask 2, each bit for one interrupt.<br>1'b0: Not masked<br>1'b1: Masked                        |

### GRF SOC CON40

Address: Operational Base(0xFF288000) + offset (0x00A0)

| Bit   | Attr | Reset Value | Description                                                                                                                        |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8  | RW   | 0x00        | dmac1_intr_mask2<br>DMAC1 interrupt mask 2, each bit for one interrupt.<br>1'b0: Not masked<br>1'b1: Masked                        |
| 7:0   | RW   | 0x00        | dmac1_intr_mask1<br>DMAC1 interrupt mask 1, each bit for one interrupt.<br>1'b0: Not masked<br>1'b1: Masked                        |

### GRF SOC CON41

Address: Operational Base(0xFF288000) + offset (0x00A4)

| Bit   | Attr | Reset Value | Description                                                                                                                        |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:11 | RO   | 0x00        | reserved                                                                                                                           |
| 10    | RW   | 0x0         | grf_sai1_tx_dmac_sel<br>1'b0: DMAC1 channel 3<br>1'b1: DMAC0 channel 11                                                            |
| 9     | RW   | 0x0         | grf_sai1_rx_dmac_sel<br>1'b0: DMAC1 channel 2<br>1'b1: DMAC0 channel 10                                                            |
| 8     | RW   | 0x0         | grf_sai0_tx_dmac_sel<br>1'b0: DMAC1 channel 1<br>1'b1: DMAC0 channel 9                                                             |
| 7     | RW   | 0x0         | grf_sai0_rx_dmac_sel<br>1'b0: DMAC1 channel 0<br>1'b1: DMAC0 channel 8                                                             |
| 6     | RW   | 0x0         | grf_spdifrx_dmac_sel<br>1'b0: DMAC1 channel 11<br>1'b1: DMAC0 channel 7                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------|
| 5          | RW          | 0x0                | grf_spdiftx_dmac_sel<br>1'b0: DMAC1 channel 10<br>1'b1: DMAC0 channel 6  |
| 4          | RW          | 0x0                | grf_pdm_rx_dmac_sel<br>1'b0: DMAC1 channel 9<br>1'b1: DMAC0 channel 5    |
| 3          | RW          | 0x0                | grf_asrc1_tx_dmac_sel<br>1'b0: DMAC1 channel 19<br>1'b1: DMAC0 channel 3 |
| 2          | RW          | 0x0                | grf_asrc1_rx_dmac_sel<br>1'b0: DMAC1 channel 18<br>1'b1: DMAC0 channel 2 |
| 1          | RW          | 0x0                | grf_asrc0_tx_dmac_sel<br>1'b0: DMAC1 channel 17<br>1'b1: DMAC0 channel 1 |
| 0          | RW          | 0x0                | grf_asrc0_rx_dmac_sel<br>1'b0: DMAC1 channel 16<br>1'b1: DMAC0 channel 0 |

**GRF SOC CON42**

Address: Operational Base(0xFF288000) + offset (0x00A8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:14      | RW          | 0x0                | dmac0_ch7_sel<br>2'b00: SPDIFRX<br>2'b01: UART1 RX<br>Others: Reserved                                                             |
| 13:12      | RW          | 0x0                | dmac0_ch6_sel<br>2'b00: SPdifTX<br>2'b01: UART1 TX<br>Others: Reserved                                                             |
| 11:10      | RW          | 0x0                | dmac0_ch5_sel<br>2'b00: CAN1 RX<br>2'b01: UART0 RX<br>2'b10: PDM RX<br>2'b11: Reserved                                             |
| 9:8        | RW          | 0x0                | dmac0_ch4_sel<br>2'b00: CAN0 RX<br>2'b01: UART0 TX<br>Others: Reserved                                                             |
| 7:6        | RW          | 0x0                | dmac0_ch3_sel<br>2'b00: DSMC request 1<br>2'b01: SPI1 RX<br>2'b10: ASRC1 TX<br>2'b11: Reserved                                     |
| 5:4        | RW          | 0x0                | dmac0_ch2_sel<br>2'b00: DSMC request 0<br>2'b01: SPI1 TX<br>2'b10: ASRC1 RX<br>2'b11: Reserved                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------|
| 3:2        | RW          | 0x0                | dmac0_ch1_sel<br>2'b00: CAN1 RX<br>2'b01: SPI0 RX<br>2'b10: ASRC0 TX<br>2'b11: Reserved |
| 1:0        | RW          | 0x0                | dmac0_ch0_sel<br>2'b00: CAN0 RX<br>2'b01: SPI0 TX<br>2'b10: ASRC0 RX<br>2'b11: Reserved |

**GRF SOC CON43**

Address: Operational Base(0xFF288000) + offset (0x00AC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 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                | dmac1_ch11_sel<br>2'b00: CAN1 RX<br>2'b01: SPDIFRX<br>Others: Reserved                                                             |
| 9:8        | RW          | 0x0                | dmac1_ch10_sel<br>2'b00: CAN0 RX<br>2'b01: SPDIFTX<br>Others: Reserved                                                             |
| 7:6        | RW          | 0x0                | dmac0_ch11_sel<br>2'b00: SAI1 TX<br>2'b01: UART3 RX<br>Others: Reserved                                                            |
| 5:4        | RW          | 0x0                | dmac0_ch10_sel<br>2'b00: DSMC REQ1<br>2'b01: UART3 TX<br>2'b10: SAI1 RX<br>2'b11: Reserved                                         |
| 3:2        | RW          | 0x0                | dmac0_ch9_sel<br>2'b00: SAI0 TX<br>2'b01: UART2 RX<br>Others: Reserved                                                             |
| 1:0        | RW          | 0x0                | dmac0_ch8_sel<br>2'b00: DSMC REQ0<br>2'b01: UART2 TX<br>2'b10: SAI0 RX<br>2'b11: Reserved                                          |

**GRF SOC STATUS0**

Address: Operational Base(0xFF288000) + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                                |
| 28         | RW          | 0x0                | vccio4_supply_voltage<br>1'b0: Less than 2.02V<br>1'b1: More than 2.19V |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------|
| 27         | RW          | 0x0                | vccio3_supply_voltage<br>1'b0: Less than 2.02V<br>1'b1: More than 2.19V                           |
| 26         | RW          | 0x0                | vccio2_supply_voltage<br>1'b0: Less than 2.02V<br>1'b1: More than 2.19V                           |
| 25         | RW          | 0x0                | vccio1_supply_voltage<br>1'b0: Less than 2.02V<br>1'b1: More than 2.19V                           |
| 24         | RW          | 0x0                | crypto_idle<br>1'b0: CRYPTO not idle<br>1'b1: CRYPTO idle                                         |
| 23         | RW          | 0x0                | timer1_ch5_en_status<br>TIMER1 channel 5 active status.<br>1'b0: Inactive<br>1'b1: Active         |
| 22         | RW          | 0x0                | timer1_ch4_en_status<br>TIMER1 channel 4 active status.<br>1'b0: Inactive<br>1'b1: Active         |
| 21         | RW          | 0x0                | timer1_ch3_en_status<br>TIMER1 channel 3 active status.<br>1'b0: Inactive<br>1'b1: Active         |
| 20         | RW          | 0x0                | timer1_ch2_en_status<br>TIMER1 channel 2 active status.<br>1'b0: Inactive<br>1'b1: Active         |
| 19         | RO          | 0x0                | timer1_ch1_en_status<br>TIMER1 channel 1 active status.<br>1'b0: Inactive<br>1'b1: Active         |
| 18         | RO          | 0x0                | timer1_ch0_en_status<br>TIMER1 channel 0 active status.<br>1'b0: Inactive<br>1'b1: Active         |
| 17         | RW          | 0x0                | dfi_init_complete<br>DFI initial complete.                                                        |
| 16:15      | RO          | 0x0                | reserved                                                                                          |
| 14:13      | RW          | 0x0                | grf_st_mac1_speed<br>MAC Speed indication.<br>2'b10: 10Mbps<br>2'b11: 100Mbps<br>Others: Reserved |
| 12:11      | RW          | 0x0                | grf_st_mac0_speed<br>MAC Speed indication.<br>2'b10: 10Mbps<br>2'b11: 100Mbps<br>Others: Reserved |
| 10         | RO          | 0x0                | timer0_ch5_en_status<br>TIMER0 channel 5 active status.<br>1'b0: Inactive<br>1'b1: Active         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------|
| 9          | RO          | 0x0                | timer0_ch4_en_status<br>TIMER0 channel 4 active status.<br>1'b0: Inactive<br>1'b1: Active |
| 8          | RO          | 0x0                | timer0_ch3_en_status<br>TIMER0 channel 3 active status.<br>1'b0: Inactive<br>1'b1: Active |
| 7          | RO          | 0x0                | timer0_ch2_en_status<br>TIMER0 channel 2 active status.<br>1'b0: Inactive<br>1'b1: Active |
| 6          | RO          | 0x0                | timer0_ch1_en_status<br>TIMER0 channel 1 active status.<br>1'b0: Inactive<br>1'b1: Active |
| 5          | RO          | 0x0                | timer0_ch0_en_status<br>TIMER0 channel 0 active status.<br>1'b0: Inactive<br>1'b1: Active |
| 4          | RW          | 0x0                | vop_dsp_hold<br>VOP DSP hold                                                              |
| 3          | RW          | 0x0                | vop_dma_finish<br>VOP DMA finish                                                          |
| 2          | RW          | 0x0                | gpll_lock<br>GPLL lock status                                                             |
| 1          | RW          | 0x0                | v1pll_lock<br>V1PLL lock status                                                           |
| 0          | RW          | 0x0                | v0pll_lock<br>V0PLL lock status                                                           |

### **GRF SOC STATUS1**

Address: Operational Base(0xFF288000) + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x000000           | reserved                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 9:0        | RO          | 0x000              | biu_active_status<br>BIU access active status, high active.<br>[ 0 ]: mcu_to_core active<br>[ 1 ]: bus_to_ddr active<br>[ 2 ]: bus_to_hsperi active<br>[ 3 ]: bus_to_lsperi active<br>[ 4 ]: bus_to_vio active<br>[ 5 ]: reserved<br>[ 6 ]: vio_to_ddr active<br>[ 7 ]: hsperi_to_bus active<br>[ 8 ]: core_to_bus active<br>[ 9 ]: core_to_ddr active<br>[ 10 ]: core_to_coredp active<br>[ 11 ]: coredp_to_core active |

### **GRF SOC STATUS2**

Address: Operational Base(0xFF288000) + offset (0x0108)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9          | RW          | 0x0                | grf_mcu_wicenack<br>Active high acknowledge signal for grf_con_mcu_wicenreq.                                                                                                                                                      |
| 8          | RW          | 0x0                | grf_mcu_sleepholdackn<br>Response to grf_con_mcu_sleepholdreqn. If this signal is low, irrespective of the grf_mcu_sleeping signal value, the processor does not advance in execution and does not perform any memory operations. |
| 7          | RW          | 0x0                | grf_mcu_sleepdeep<br>Active only when MCU sleeping is high. Indicates that the sleepdeep bit in the NVIC is set to high and MCU is in deep sleep mode.                                                                            |
| 6          | RW          | 0x0                | grf_mcu_sleeping<br>Indicates that MCU is in sleep mode.<br>1'b1: MCU is idle, waiting for an interrupt<br>1'b0: MCU isn't idle                                                                                                   |
| 5          | RW          | 0x0                | grf_mcu_wakeup<br>Indicates MCU wakeup.                                                                                                                                                                                           |
| 4          | RW          | 0x0                | grf_mcu_hclk_gate<br>Indicates that HCLK can be gated because MCU is asleep without the debugger being active.<br>1'b1: MCU HCLK can be safely gated<br>1'b0: MCU HCLK can't be safely gated                                      |
| 3          | RW          | 0x0                | grf_mcu_lockup<br>Indicates that MCU is locked up.<br>1'b1: MCU is locked up<br>1'b0: MCU isn't locked up                                                                                                                         |
| 2          | RW          | 0x0                | grf_mcu_txev<br>MCU TXEV                                                                                                                                                                                                          |
| 1          | RW          | 0x0                | grf_mcu_halt<br>MCU halt                                                                                                                                                                                                          |
| 0          | RO          | 0x0                | grf_mcu_dbgrestared<br>Handshake of grf_con_mcu_dbgrestart.                                                                                                                                                                       |

### **GRF DDR STATUS0**

Address: Operational Base(0xFF288000) + offset (0x0110)

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

### **GRF DDR STATUS1**

Address: Operational Base(0xFF288000) + offset (0x0114)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------|
| 9          | RW          | 0x0                | grf_st_stat_ddrc_reg_selfref_type<br>Current self-refresh status and type. Equivalent to STAT.selfref_type register. |
| 8          | RW          | 0x0                | cactive_axi1<br>State of AXI low-power clock active, cactive_axi                                                     |
| 7          | RW          | 0x0                | csysack_axi1<br>State of AXI low-power request acknowledge, csysack_axi                                              |
| 6          | RW          | 0x0                | csysreq_axi1<br>State of AXI low-power request, csysreq_axi                                                          |
| 5          | RO          | 0x0                | cactive_axi0<br>State of AXI low-power clock active, cactive_axi                                                     |
| 4          | RO          | 0x0                | csysack_axi0<br>State of AXI low-power request acknowledge, csysack_axi                                              |
| 3          | RO          | 0x0                | csysreq_axi0<br>State of AXI low-power request, csysreq_axi                                                          |
| 2          | RO          | 0x0                | cactive_ddrc<br>State of DDRC hardware low-power clock active, cactive_ddrc                                          |
| 1          | RO          | 0x0                | csysack_ddrc<br>State of DDRC hardware low-power request acknowledge, cactive_ddrc                                   |
| 0          | RO          | 0x0                | csysreq_ddrc<br>State of DDRC hardware low-power request, csysreq_ddrc                                               |

**GRF USBPHY STATUS**

Address: Operational Base(0xFF288000) + offset (0x0118)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------|
| 31:27      | RO          | 0x00               | reserved                                                                                |
| 26         | RO          | 0x0                | usbotg1_phy_utmi_vpi<br>USBPHY Single ended data received on USB2_OTG_DP in serial mode |
| 25         | RO          | 0x0                | usbotg1_utmi_vmi<br>USBPHY Single ended data received on USB2_OTG_DM in serial mode     |
| 24         | RO          | 0x0                | usbotg1_phy_ls_fs_rcv<br>USBPHY receiver differential output in serial mode             |
| 23         | RO          | 0x0                | usbotg0_phy_utmi_vpi<br>USBPHY Single ended data received on USB2_OTG_DP in serial mode |
| 22         | RO          | 0x0                | usbotg0_utmi_vmi<br>USBPHY Single ended data received on USB2_OTG_DM in serial mode     |
| 21         | RO          | 0x0                | usbotg0_phy_ls_fs_rcv<br>USBPHY receiver differential output in serial mode             |
| 20         | RO          | 0x0                | usbphy_dp_attached<br>usbphy_dp_attached status, high active.                           |
| 19         | RO          | 0x0                | usbphy_cp_detected<br>usbphy_cp_detected status, high active.                           |
| 18         | RO          | 0x0                | usbphy_dcp_detected<br>usbphy_dcp_detected status, high active.                         |
| 17         | RO          | 0x0                | usbphy_dp_floatdet<br>usbphy_dp_floatdet status, high active.                           |
| 16         | RO          | 0x0                | usbphy_dm_floatdet<br>usbphy_dm_floatdet status, high active.                           |
| 15         | RW          | 0x0                | usbotg1_utmi_hostdisconnect<br>usbhost_utmi_hostdisconnect status, high active.         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------|
| 14         | RW          | 0x0                | usb0tg1_utmi_iddig<br>usbhost_utmi_iddig status, high active.                  |
| 13:12      | RO          | 0x0                | usb0tg1_utmi_linestate<br>usb0tg_utmi_linestate status, high active.           |
| 11         | RW          | 0x0                | usb0tg1_utmi_sessend<br>usbhost_utmi_sessend status, high active.              |
| 10         | RW          | 0x1                | usb0tg1_utmi_vbusvalid<br>usbhost_utmi_vbusvalid status, high active.          |
| 9          | RW          | 0x1                | usb0tg1_utmi_valid<br>usbhost_utmi_valid status, high active.                  |
| 8          | RW          | 0x1                | usb0tg1_utmi_bvalid<br>usbhost_utmi_bvalid status, high active.                |
| 7          | RO          | 0x0                | usb0tg0_utmi_hostdisconnect<br>usb0tg_utmi_hostdisconnect status, high active. |
| 6          | RO          | 0x0                | usb0tg0_utmi_iddig<br>usb0tg_utmi_iddig status, high active.                   |
| 5:4        | RO          | 0x0                | usb0tg0_utmi_linestate<br>usb0tg_utmi_linestate status, high active.           |
| 3          | RO          | 0x1                | usb0tg0_utmi_sessend<br>usb0tg_utmi_sessend status, high active.               |
| 2          | RO          | 0x0                | usb0tg0_utmi_vbusvalid<br>usb0tg_utmi_vbusvalid status, high active.           |
| 1          | RO          | 0x0                | usb0tg0_utmi_valid<br>usb0tg_utmi_valid status, high active.                   |
| 0          | RO          | 0x0                | usb0tg0_utmi_bvalid<br>usb0tg_utmi_bvalid status, high active.                 |

**GRF USBOTG0 SIG DETECT CON**

Address: Operational Base(0xFF288000) + 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:10      | RO          | 0x00               | reserved                                                                                                                           |
| 9          | RW          | 0x0                | otg0_vbusvalid_fall_irq_en<br>otg_vbusvalid falling edge IRQ enable.<br>1'b0: Disable<br>1'b1: Enable                              |
| 8          | RW          | 0x0                | otg0_vbusvalid_rise_irq_en<br>otg_vbusvalid rising edge IRQ enable.<br>1'b0: Disable<br>1'b1: Enable                               |
| 7          | RW          | 0x0                | otg0_disconnect_fall_irq_en<br>otg_disconnect falling edge IRQ enable.<br>1'b0: Disable<br>1'b1: Enable                            |
| 6          | RW          | 0x0                | otg0_disconnect_rise_irq_en<br>otg_disconnect rising edge IRQ enable.<br>1'b0: Disable<br>1'b1: Enable                             |
| 5          | RW          | 0x0                | otg0_id_fall_irq_en<br>otg_id falling edge IRQ enable.<br>1'b0: Disable<br>1'b1: Enable                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------|
| 4          | RW          | 0x0                | otg0_id_rise_irq_en<br>otg_id rising edge IRQ enable.<br>1'b0: Disable<br>1'b1: Enable          |
| 3          | RW          | 0x0                | otg0_bvalid_fall_irq_en<br>otg_bvalid falling edge IRQ enable.<br>1'b0: Disable<br>1'b1: Enable |
| 2          | RW          | 0x0                | otg0_bvalid_rise_irq_en<br>otg_bvalid rising edge IRQ enable.<br>1'b0: Disable<br>1'b1: Enable  |
| 1          | RO          | 0x0                | reserved                                                                                        |
| 0          | RW          | 0x0                | otg0_linestate_irq_en<br>otg_linestate change IRQ enable.<br>1'b0: Disable<br>1'b1: Enable      |

**GRF USBOTGO SIG DETECT STATUS**

Address: Operational Base(0xFF288000) + offset (0x0154)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x000000           | reserved                                                                                              |
| 9          | RO          | 0x0                | otg0_vbusvalid_fall_irq<br>otg_vbusvalid falling edge IRQ status.<br>1'b0: Inactive<br>1'b1: Active   |
| 8          | RO          | 0x0                | otg0_vbusvalid_rise_irq<br>otg_vbusvalid rising edge IRQ status.<br>1'b0: Inactive<br>1'b1: Active    |
| 7          | RO          | 0x0                | otg0_disconnect_fall_irq<br>otg_disconnect falling edge IRQ status.<br>1'b0: Inactive<br>1'b1: Active |
| 6          | RO          | 0x0                | otg0_disconnect_rise_irq<br>otg_disconnect rising edge IRQ status.<br>1'b0: Inactive<br>1'b1: Active  |
| 5          | RO          | 0x0                | otg0_id_fall_irq<br>otg_id falling edge IRQ status.<br>1'b0: Inactive<br>1'b1: Active                 |
| 4          | RO          | 0x0                | otg0_id_rise_irq<br>otg_id rising edge IRQ status.<br>1'b0: Inactive<br>1'b1: Active                  |
| 3          | RO          | 0x0                | otg0_bvalid_fall_irq<br>otg_bvalid falling edge IRQ status.<br>1'b0: Inactive<br>1'b1: Active         |
| 2          | RO          | 0x0                | otg0_bvalid_rise_irq<br>otg_bvalid rising edge IRQ status.<br>1'b0: Inactive<br>1'b1: Active          |
| 1          | RO          | 0x0                | reserved                                                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------|
| 0          | RO          | 0x0                | otg0_linestate_irq<br>otg_linestate change IRQ status.<br>1'b0: Inactive<br>1'b1: Active |

#### **GRF USBOTG0 SIG DETECT CLR**

Address: Operational Base(0xFF288000) + 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:8       | RO          | 0x00               | reserved                                                                                                                           |
| 7          | RW          | 0x0                | otg0_disconnect_fall_irq_clr<br>otg_disconnect falling edge IRQ clear. Write 1 to clear IRQ status.                                |
| 6          | RW          | 0x0                | otg0_disconnect_rise_irq_clr<br>otg_disconnect rising edge IRQ clear. Write 1 to clear IRQ status.                                 |
| 5          | RW          | 0x0                | otg0_id_fall_irq_clr<br>otg_id falling edge IRQ clear. Write 1 to clear IRQ status.                                                |
| 4          | RW          | 0x0                | otg0_id_rise_irq_clr<br>otg_id rising edge IRQ clear. Write 1 to clear IRQ status.                                                 |
| 3          | RW          | 0x0                | otg0_bvalid_fall_irq_clr<br>otg_bvalid falling edge IRQ clear. Write 1 to clear IRQ status.                                        |
| 2          | RW          | 0x0                | otg0_bvalid_rise_irq_clr<br>otg_bvalid rising edge IRQ clear. Write 1 to clear IRQ status.                                         |
| 1          | RO          | 0x0                | reserved                                                                                                                           |
| 0          | WO          | 0x0                | otg0_linestate_irq_clr<br>otg_linestate change IRQ clear. Write 1 to clear IRQ status.                                             |

#### **GRF USBOTG0 VBUSVALID DETECT CON**

Address: Operational Base(0xFF288000) + offset (0x015C)

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

#### **GRF USBOTG0 LINESTATE DETECT CON**

Address: Operational Base(0xFF288000) + offset (0x0160)

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

#### **GRF USBOTG0 DISCONNECT DETECT CON**

Address: Operational Base(0xFF288000) + offset (0x0164)

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

#### **GRF USBOTG0 BVALID DETECT CON**

Address: Operational Base(0xFF288000) + offset (0x0168)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------|
| 19:0       | RW          | 0x30100            | otg0_bvalid_detect_con<br>OTG bvalid filter time control register |

**GRF USBOTG0 ID DETECT CON**

Address: Operational Base(0xFF288000) + offset (0x016C)

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

**GRF USBOTG1 SIG DETECT CON**

Address: Operational Base(0xFF288000) + offset (0x0170)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<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                | otg1_vbusvalid_fall_irq_en<br>otg_vbusvalid falling edge IRQ enable.<br>1'b0: Disable<br>1'b1: Enable                              |
| 8          | RW          | 0x0                | otg1_vbusvalid_rise_irq_en<br>otg_vbusvalid rising edge IRQ enable.<br>1'b0: Disable<br>1'b1: Enable                               |
| 7          | RW          | 0x0                | otg1_disconnect_fall_irq_en<br>otg_disconnect falling edge IRQ enable.<br>1'b0: Disable<br>1'b1: Enable                            |
| 6          | RW          | 0x0                | otg1_disconnect_rise_irq_en<br>otg_disconnect rising edge IRQ enable.<br>1'b0: Disable<br>1'b1: Enable                             |
| 5          | RW          | 0x0                | otg1_id_fall_irq_en<br>otg_id falling edge IRQ enable.<br>1'b0: Disable<br>1'b1: Enable                                            |
| 4          | RW          | 0x0                | otg1_id_rise_irq_en<br>otg_id rising edge IRQ enable.<br>1'b0: Disable<br>1'b1: Enable                                             |
| 3          | RW          | 0x0                | otg1_bvalid_fall_irq_en<br>otg_bvalid falling edge IRQ enable.<br>1'b0: Disable<br>1'b1: Enable                                    |
| 2          | RW          | 0x0                | otg1_bvalid_rise_irq_en<br>otg_bvalid rising edge IRQ enable.<br>1'b0: Disable<br>1'b1: Enable                                     |
| 1          | RO          | 0x0                | reserved                                                                                                                           |
| 0          | RW          | 0x0                | otg1_linestate_irq_en<br>otg_linestate change IRQ enable.<br>1'b0: Disable<br>1'b1: Enable                                         |

**GRF USBOTG1 SIG DETECT STATUS**

Address: Operational Base(0xFF288000) + offset (0x0174)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x000000           | reserved                                                                                              |
| 9          | RO          | 0x0                | otg1_vbusvalid_fall_irq<br>otg_vbusvalid falling edge IRQ status.<br>1'b0: Inactive<br>1'b1: Active   |
| 8          | RO          | 0x0                | otg1_vbusvalid_rise_irq<br>otg_vbusvalid rising edge IRQ status.<br>1'b0: Inactive<br>1'b1: Active    |
| 7          | RO          | 0x0                | otg1_disconnect_fall_irq<br>otg_disconnect falling edge IRQ status.<br>1'b0: Inactive<br>1'b1: Active |
| 6          | RO          | 0x0                | otg1_disconnect_rise_irq<br>otg_disconnect rising edge IRQ status.<br>1'b0: Inactive<br>1'b1: Active  |
| 5          | RO          | 0x0                | otg1_id_fall_irq<br>otg_id falling edge IRQ status.<br>1'b0: Inactive<br>1'b1: Active                 |
| 4          | RO          | 0x0                | otg1_id_rise_irq<br>otg_id rising edge IRQ status.<br>1'b0: Inactive<br>1'b1: Active                  |
| 3          | RO          | 0x0                | otg1_bvalid_fall_irq<br>otg_bvalid falling edge IRQ status.<br>1'b0: Inactive<br>1'b1: Active         |
| 2          | RO          | 0x0                | otg1_bvalid_rise_irq<br>otg_bvalid rising edge IRQ status.<br>1'b0: Inactive<br>1'b1: Active          |
| 1          | RO          | 0x0                | reserved                                                                                              |
| 0          | RO          | 0x0                | otg1_linestate_irq<br>otg_linestate change IRQ status.<br>1'b0: Inactive<br>1'b1: Active              |

**GRF USBOTG1 SIG DETECT CLR**

Address: Operational Base(0xFF288000) + 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:8       | RO          | 0x00               | reserved                                                                                                                           |
| 7          | RW          | 0x0                | otg1_disconnect_fall_irq_clr<br>otg_disconnect falling edge IRQ clear. Write 1 to clear IRQ status.                                |
| 6          | RW          | 0x0                | otg1_disconnect_rise_irq_clr<br>otg_disconnect rising edge IRQ clear. Write 1 to clear IRQ status.                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------|
| 5          | RW          | 0x0                | otg1_id_fall_irq_clr<br>otg_id falling edge IRQ clear. Write 1 to clear IRQ status.         |
| 4          | RW          | 0x0                | otg1_id_rise_irq_clr<br>otg_id rising edge IRQ clear. Write 1 to clear IRQ status.          |
| 3          | RW          | 0x0                | otg1_bvalid_fall_irq_clr<br>otg_bvalid falling edge IRQ clear. Write 1 to clear IRQ status. |
| 2          | RW          | 0x0                | otg1_bvalid_rise_irq_clr<br>otg_bvalid rising edge IRQ clear. Write 1 to clear IRQ status.  |
| 1          | RO          | 0x0                | reserved                                                                                    |
| 0          | WO          | 0x0                | otg1_linestate_irq_clr<br>otg_linestate change IRQ clear. Write 1 to clear IRQ status.      |

#### **GRF USBOTG1\_VBUSVALID\_DETECT\_CON**

Address: Operational Base(0xFF288000) + offset (0x017C)

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

#### **GRF USBOTG1\_LINESTATE\_DETECT\_CON**

Address: Operational Base(0xFF288000) + offset (0x0180)

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

#### **GRF USBOTG1\_DISCONNECT\_DETECT\_CON**

Address: Operational Base(0xFF288000) + offset (0x0184)

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

#### **GRF USBOTG1\_BVALID\_DETECT\_CON**

Address: Operational Base(0xFF288000) + offset (0x0188)

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

#### **GRF USBOTG1\_ID\_DETECT\_CON**

Address: Operational Base(0xFF288000) + offset (0x018C)

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

#### **GRF MAC0\_MCGR\_ACK**

Address: Operational Base(0xFF288000) + offset (0x01A0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                  |
| 0          | W1T         | 0x0                | mac0_mcgr_ack<br>MAC0 media clock generation recovery ACK |

#### **GRF MAC1\_MCGR\_ACK**

## **RK3506 TRM (Part 1)**

Address: Operational Base(0xFF288000) + offset (0x01A4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                  |
| 0          | W1T         | 0x0                | mac1_mcgr_ack<br>MAC1 media clock generation recovery ACK |

### **GRF OS REG0**

Address: Operational Base(0xFF288000) + offset (0x0200)

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

### **GRF OS REG1**

Address: Operational Base(0xFF288000) + offset (0x0204)

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

### **GRF OS REG2**

Address: Operational Base(0xFF288000) + offset (0x0208)

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

### **GRF OS REG3**

Address: Operational Base(0xFF288000) + offset (0x020C)

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

### **GRF OS REG4**

Address: Operational Base(0xFF288000) + offset (0x0210)

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

### **GRF OS REG5**

Address: Operational Base(0xFF288000) + offset (0x0214)

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

### **GRF OS REG6**

Address: Operational Base(0xFF288000) + offset (0x0218)

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

### **GRF OS REG7**

Address: Operational Base(0xFF288000) + offset (0x021C)

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

### **GRF OS REG8**

Address: Operational Base(0xFF288000) + offset (0x0220)

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

**GRF OS REG9**

Address: Operational Base(0xFF288000) + offset (0x0224)

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

**GRF OS REG10**

Address: Operational Base(0xFF288000) + offset (0x0228)

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

**GRF OS REG11**

Address: Operational Base(0xFF288000) + offset (0x022C)

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

**GRF SOC VERSION**

Address: Operational Base(0xFF288000) + offset (0x0300)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:0       | RW          | 0x00003506         | soc_version        |

## 5.4 GRF\_CORE Register Description

### 5.4.1 Registers Summary

| <b>Name</b>                 | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                  |
|-----------------------------|---------------|-------------|--------------------|-------------------------------------|
| GRF CORE PVTPLL CON0_L      | 0x0000        | W           | 0x00000000         | PVTPLL control register 0 low part  |
| GRF CORE PVTPLL CON0_H      | 0x0004        | W           | 0x00000000         | PVTPLL control register 0 high part |
| GRF CORE PVTPLL CON1        | 0x0008        | W           | 0x00000018         | PVTPLL control register 1           |
| GRF CORE PVTPLL CON2        | 0x000C        | W           | 0x00040000         | PVTPLL control register 2           |
| GRF CORE PVTPLL CON3        | 0x0010        | W           | 0x00000000         | PVTPLL control register 3           |
| GRF CORE PVTPLL OSC_CNT     | 0x0014        | W           | 0x00000000         | PVTPLL OSC counter register         |
| GRF CORE PVTPLL OSC_CNT_AVG | 0x0018        | W           | 0x00000000         | PVTPLL OSC counter average register |
| GRF CORE CPU STATUS         | 0x0060        | W           | 0x00000000         | CPU status register                 |
| GRF CORE CPU CON0           | 0x0064        | W           | 0x0000000F         | CPU control register 0              |
| GRF CORE CPU CON1           | 0x0068        | W           | 0x00000060         | CPU control register 1              |
| GRF CORE CPU MEM CON0       | 0x006C        | W           | 0x00000001         | CPU memory control register 0       |
| GRF CORE SOC CON0           | 0x0084        | W           | 0x00000000         | System control register 0           |
| GRF CORE SOC CON1           | 0x0088        | W           | 0x00000000         | System control register 1           |
| GRF CORE SOC CON2           | 0x008C        | W           | 0x00000000         | System control register 2           |
| GRF CORE SOC CON3           | 0x0090        | W           | 0x00000000         | System control register 3           |
| GRF CORE SOC CON4           | 0x0094        | W           | 0x00000000         | System control register 4           |

| Name              | Offset | Size | Reset Value | Description               |
|-------------------|--------|------|-------------|---------------------------|
| GRF CORE SOC CONS | 0x0098 | W    | 0x00000000  | System control register 5 |

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

### 5.4.2 Detail Registers Description

#### GRF CORE PVTPLL CON0\_L

Address: Operational Base(0xFF840000) + offset (0x0000)

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

#### GRF CORE PVTPLL CON0\_H

Address: Operational Base(0xFF840000) + offset (0x0004)

| Bit   | Attr | Reset Value | Description                                                                                                                            |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable      |
| 15:11 | RW   | 0x00        | clk_div_out_logic<br>Frequency division factor for output clock for system logic.                                                      |
| 10    | RW   | 0x0         | clk_out_sel<br>Clock output selection<br>1'b0: OSC ring clock without frequency divider<br>1'b1: OSC ring clock with frequency divider |
| 9:7   | RW   | 0x0         | clk_div_out<br>Frequency division factor for output clock.                                                                             |
| 6:0   | RW   | 0x00        | ring_length_sel<br>Osc ring inverter length select                                                                                     |

#### GRF CORE PVTPLL CON1

Address: Operational Base(0xFF840000) + offset (0x0008)

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

**GRF CORE PVTPLL CON2**

Address: Operational Base(0xFF840000) + offset (0x000C)

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

**GRF CORE PVTPLL CON3**

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

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

**GRF CORE PVTPLL OSC CNT**

Address: Operational Base(0xFF840000) + offset (0x0014)

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

**GRF CORE PVTPLL OSC CNT AVG**

Address: Operational Base(0xFF840000) + offset (0x0018)

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

**GRF CORE CPU STATUS**

Address: Operational Base(0xFF840000) + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                 |
| 15         | RW          | 0x0                | jtagnsw<br>High if JTAG selected, low if SWD selected SWJ-DP             |
| 14         | RW          | 0x0                | jtagtop<br>Indicates TAP in TLR, RTI, Sel-DR or Sel-IR states for SWJ-DP |
| 13         | RW          | 0x0                | evento_rising_edge<br>Indicates an event output                          |
| 12         | RW          | 0x0                | standbywfi2<br>L2 memory system is in wfi state.                         |
| 11         | RO          | 0x0                | reserved                                                                 |
| 10:8       | RW          | 0x0                | smpnamp<br>It signals SMP mode or AMP mode for core.                     |
| 7          | RO          | 0x0                | reserved                                                                 |
| 6:4        | RW          | 0x0                | standbywfi<br>Core is in WFI state.                                      |
| 3          | RO          | 0x0                | reserved                                                                 |
| 2:0        | RW          | 0x0                | standbywfe<br>Core is in WFE state.                                      |

**GRF CORE CPU CON0**

Address: Operational Base(0xFF840000) + offset (0x0064)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16         | RW          | 0x0                | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                      |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                               |
| 13         | RW          | 0x0                | evento_clr<br>Clear the event output status to 1'b0                                                                                                                                    |
| 12         | RW          | 0x0                | eventi<br>Event input for processor wake-up from WFE state.                                                                                                                            |
| 11:8       | RW          | 0x0                | cfgte<br>Controls process state for exception handling (TE bit) at reset<br>1'b1: Thumb instruction set for exception handling<br>1'b0: ARM instruction set for exception handling     |
| 7:4        | RW          | 0x0                | cfgend<br>Controls endianness during dta exception handling (EE-bit) at reset<br>1'b1: Big-endian data during exception handling<br>1'b0: Little-endian data during exception handling |
| 3:0        | RW          | 0xf                | viniti<br>Sets the base address of the vector table<br>1'b1: A vector table base address of 0xFFFF0000<br>1'b0: A vector table base address of 0x00000000                              |

**GRF CORE CPU CON1**

Address: Operational Base(0xFF840000) + offset (0x0068)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:17      | RO          | 0x0000             | reserved                                                                                                                          |
| 16         | RW          | 0x0                | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:14      | RO          | 0x0                | reserved                                                                                                                          |
| 13         | RW          | 0x0                | pvtpll_oen_to_io_sel<br>PVTPLL enable to IO selection<br>1'b0: Control by PVTPLL<br>1'b1: Always enable                           |
| 12         | RW          | 0x0                | cpu_ema_detect_en<br>1'b0: ema detect disable<br>1'b1: ema detect enable                                                          |
| 11:7       | RO          | 0x00               | reserved                                                                                                                          |
| 6          | RW          | 0x1                | dbgselfaddrv<br>Debug self-address offset valid                                                                                   |
| 5          | RW          | 0x1                | dbgromaddrv<br>Debug ROM physical address valid                                                                                   |
| 4          | RW          | 0x0                | I2rstdisable<br>Disable automatic L2 cache invalidate at reset                                                                    |
| 3:0        | RW          | 0x0                | I1rstdisable<br>Disable automatic data cache, instruction cache and TLB invalidate at reset                                       |

**GRF CORE CPU MEM CON0**

Address: Operational Base(0xFF840000) + 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 16bits, 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                | wtsel_hvt_mux4<br>Timing adjustment setting for debug purpose                                                                     |
| 9:8        | RW          | 0x0                | rtsel_hvt_mux4<br>Timing adjustment setting for debug purpose                                                                     |
| 7:4        | RO          | 0x0                | reserved                                                                                                                          |
| 3:2        | RW          | 0x0                | wtsel<br>Timing adjustment setting for debug purpose                                                                              |
| 1:0        | RW          | 0x1                | rtsel<br>Timing adjustment setting for debug purpose                                                                              |

**GRF CORE SOC CON0**

Address: Operational Base(0xFF840000) + offset (0x0084)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 15         | RW          | 0x0                | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 14:10      | RW          | 0x00               | grf_gpio1_filter_sel1<br>GPIO select to go through second filter logic<br>5'h00: GPIO1A0<br>5'h01: GPIO1A1<br>5'h02: GPIO1A2<br>5'h03: GPIO1A3<br>5'h04: GPIO1A4<br>5'h05: GPIO1A5<br>5'h06: GPIO1A6<br>5'h07: GPIO1A7<br>5'h08: GPIO1B0<br>5'h09: GPIO1B1<br>5'h0a: GPIO1B2<br>5'h0b: GPIO1B3<br>5'h0c: GPIO1B4<br>5'h0d: GPIO1B5<br>5'h0e: GPIO1B6<br>5'h0f: GPIO1B7<br>5'h10: GPIO1C0<br>5'h11: GPIO1C1<br>5'h12: GPIO1C2<br>5'h13: GPIO1C3<br>5'h14: GPIO1C4<br>5'h15: GPIO1C5<br>5'h16: GPIO1C6<br>5'h17: GPIO1C7<br>5'h18: GPIO1D0<br>5'h19: GPIO1D1<br>5'h1a: GPIO1D2<br>5'h1b: GPIO1D3 |
| 9          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:4 | RW   | 0x00        | grf_gpio1_filter_sel0<br>GPIO select to go through first filter logic<br>5'h00: GPIO1A0<br>5'h01: GPIO1A1<br>5'h02: GPIO1A2<br>5'h03: GPIO1A3<br>5'h04: GPIO1A4<br>5'h05: GPIO1A5<br>5'h06: GPIO1A6<br>5'h07: GPIO1A7<br>5'h08: GPIO1B0<br>5'h09: GPIO1B1<br>5'h0a: GPIO1B2<br>5'h0b: GPIO1B3<br>5'h0c: GPIO1B4<br>5'h0d: GPIO1B5<br>5'h0e: GPIO1B6<br>5'h0f: GPIO1B7<br>5'h10: GPIO1C0<br>5'h11: GPIO1C1<br>5'h12: GPIO1C2<br>5'h13: GPIO1C3<br>5'h14: GPIO1C4<br>5'h15: GPIO1C5<br>5'h16: GPIO1C6<br>5'h17: GPIO1C7<br>5'h18: GPIO1D0<br>5'h19: GPIO1D1<br>5'h1a: GPIO1D2<br>5'h1b: GPIO1D3 |
| 3:0 | RW   | 0x0         | grf_gpio1_filter_en<br>There are four filter circuits for pad in GPIO1, each bit controls the enable of one filter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

**GRF CORE SOC CON1**

Address: Operational Base(0xFF840000) + offset (0x0088)

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

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14:10 | RW   | 0x00        | grf_gpio1_filter_sel3<br>GPIO select to go through fouth filter logic<br>5'h00: GPIO1A0<br>5'h01: GPIO1A1<br>5'h02: GPIO1A2<br>5'h03: GPIO1A3<br>5'h04: GPIO1A4<br>5'h05: GPIO1A5<br>5'h06: GPIO1A6<br>5'h07: GPIO1A7<br>5'h08: GPIO1B0<br>5'h09: GPIO1B1<br>5'h0a: GPIO1B2<br>5'h0b: GPIO1B3<br>5'h0c: GPIO1B4<br>5'h0d: GPIO1B5<br>5'h0e: GPIO1B6<br>5'h0f: GPIO1B7<br>5'h10: GPIO1C0<br>5'h11: GPIO1C1<br>5'h12: GPIO1C2<br>5'h13: GPIO1C3<br>5'h14: GPIO1C4<br>5'h15: GPIO1C5<br>5'h16: GPIO1C6<br>5'h17: GPIO1C7<br>5'h18: GPIO1D0<br>5'h19: GPIO1D1<br>5'h1a: GPIO1D2<br>5'h1b: GPIO1D3 |
| 9     | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:4 | RW   | 0x00        | grf_gpio1_filter_sel2<br>GPIO select to go through third filter logic<br>5'h00: GPIO1A0<br>5'h01: GPIO1A1<br>5'h02: GPIO1A2<br>5'h03: GPIO1A3<br>5'h04: GPIO1A4<br>5'h05: GPIO1A5<br>5'h06: GPIO1A6<br>5'h07: GPIO1A7<br>5'h08: GPIO1B0<br>5'h09: GPIO1B1<br>5'h0a: GPIO1B2<br>5'h0b: GPIO1B3<br>5'h0c: GPIO1B4<br>5'h0d: GPIO1B5<br>5'h0e: GPIO1B6<br>5'h0f: GPIO1B7<br>5'h10: GPIO1C0<br>5'h11: GPIO1C1<br>5'h12: GPIO1C2<br>5'h13: GPIO1C3<br>5'h14: GPIO1C4<br>5'h15: GPIO1C5<br>5'h16: GPIO1C6<br>5'h17: GPIO1C7<br>5'h18: GPIO1D0<br>5'h19: GPIO1D1<br>5'h1a: GPIO1D2<br>5'h1b: GPIO1D3 |
| 3:0 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

**GRF CORE SOC CON2**

Address: Operational Base(0xFF840000) + offset (0x008C)

| Bit   | Attr | Reset Value | Description                                                                                                                                             |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | RO   | 0x000       | reserved                                                                                                                                                |
| 19:0  | RW   | 0x00000     | grf_gpio1_filter_count0<br>Filter counter for first filter logic. When this value is n, it will filter pulse which width is n+1 oscillator clock cycle. |

**GRF CORE SOC CON3**

Address: Operational Base(0xFF840000) + offset (0x0090)

| Bit   | Attr | Reset Value | Description                                                                                                                                              |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | RO   | 0x000       | reserved                                                                                                                                                 |
| 19:0  | RW   | 0x00000     | grf_gpio1_filter_count1<br>Filter counter for second filter logic. When this value is n, it will filter pulse which width is n+1 oscillator clock cycle. |

**GRF CORE SOC CON4**

Address: Operational Base(0xFF840000) + offset (0x0094)

| Bit   | Attr | Reset Value | Description                                                                                                                                             |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | RO   | 0x000       | reserved                                                                                                                                                |
| 19:0  | RW   | 0x00000     | grf_gpio1_filter_count2<br>Filter counter for third filter logic. When this value is n, it will filter pulse which width is n+1 oscillator clock cycle. |

**GRF CORE SOC CONS**

Address: Operational Base(0xFF840000) + offset (0x0098)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                                                                                 |
| 19:0       | RW          | 0x00000            | grf_gpio1_filter_count3<br>Filter counter for fourth filter logic. When this value is n, it will filter pulse which width is n+1 oscillator clock cycle. |

**5.5 GRF\_PMU Register Description****5.5.1 Registers Summary**

| <b>Name</b>            | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------------------|---------------|-------------|--------------------|------------------------------------|
| GRF_PMU_SOC_CON0       | 0x0000        | W           | 0x00000001         | PMU System control register 0      |
| GRF_PMU_SOC_CON1       | 0x0004        | W           | 0x00000000         | PMU System control register 1      |
| GRF_PMU_SOC_CON2       | 0x0008        | W           | 0x000007EF         | PMU System control register 2      |
| GRF_PMU_SOC_CON3       | 0x000C        | W           | 0x00000000         | PMU System control register 3      |
| GRF_PMU_SOC_CON4       | 0x0010        | W           | 0x00000000         | PMU System control register 4      |
| GRF_PMU_SOC_CON5       | 0x0014        | W           | 0x00000000         | PMU System control register 5      |
| GRF_PMU_SOC_CON6       | 0x0018        | W           | 0x00000000         | PMU System control register 6      |
| GRF_PMU_SOC_CON7       | 0x001C        | W           | 0x00000000         | PMU System control register 7      |
| GRF_PMU_SOC_CON8       | 0x0020        | W           | 0x00000000         | PMU System control register 8      |
| GRF_PMU_SOC_CON9       | 0x0024        | W           | 0x00000000         | PMU System control register 9      |
| GRF_PMU_SOC_CON10      | 0x0028        | W           | 0x00000000         | PMU System control register 10     |
| GRF_PMU_SOC_CON11      | 0x002C        | W           | 0x00000000         | PMU System control register 11     |
| GRF_PMU_SOC_CON12      | 0x0030        | W           | 0x00000000         | PMU System control register 12     |
| GRF_PMU_SOC_CON13      | 0x0034        | W           | 0x00000000         | PMU System control register 13     |
| GRF_PMU_SOC_CON14      | 0x0038        | W           | 0x00000000         | PMU System control register 14     |
| GRF_PMU_SOC_CON15      | 0x003C        | W           | 0x00000000         | PMU System control register 15     |
| GRF_PMU_SOC_CON16      | 0x0040        | W           | 0x00000000         | PMU System control register 16     |
| GRF_PMU_SOC_CON17      | 0x0044        | W           | 0x00000000         | PMU System control register 17     |
| GRF_PMU_SOC_CON18      | 0x0048        | W           | 0x00000000         | PMU System control register 18     |
| GRF_PMU_SOC_STATUS     | 0x0100        | W           | 0x00000001         | PMU System status register         |
| GRF_PMU_OS_REG0        | 0x0200        | W           | 0x00000000         | OS register 0                      |
| GRF_PMU_OS_REG1        | 0x0204        | W           | 0x00000000         | OS register 1                      |
| GRF_PMU_OS_REG2        | 0x0208        | W           | 0x00000000         | OS register 2                      |
| GRF_PMU_OS_REG3        | 0x020C        | W           | 0x00000000         | OS register 3                      |
| GRF_PMU_OS_REG4        | 0x0210        | W           | 0x00000000         | OS register 4                      |
| GRF_PMU_OS_REG5        | 0x0214        | W           | 0x00000000         | OS register 5                      |
| GRF_PMU_OS_REG6        | 0x0218        | W           | 0x00000000         | OS register 6                      |
| GRF_PMU_OS_REG7        | 0x021C        | W           | 0x00000000         | OS register 7                      |
| GRF_PMU_OS_REG8        | 0x0220        | W           | 0x00000000         | OS register 9                      |
| GRF_PMU_OS_REG9        | 0x0224        | W           | 0x00000000         | OS register 9                      |
| GRF_PMU_OS_REG10       | 0x0228        | W           | 0x00000000         | OS register 10                     |
| GRF_PMU_OS_REG11       | 0x022C        | W           | 0x00000000         | OS register 11                     |
| GRF_PMU_RSTFUNC_STATUS | 0x0230        | W           | 0x00000000         | System reset status register       |
| GRF_PMU_RSTFUNC_CLR    | 0x0234        | W           | 0x00000000         | System reset status clear register |
| GRF_PMU_MCU_ISO_CON0   | 0x1000        | W           | 0x00000000         | MCU isolation control register 0   |
| GRF_PMU_MCU_ISO_CON1   | 0x1004        | W           | 0x00000000         | MCU isolation control register 1   |

| Name                     | Offset | Size | Reset Value | Description                          |
|--------------------------|--------|------|-------------|--------------------------------------|
| GRF PMU MCU ISO CON_2    | 0x1008 | W    | 0x00000000  | MCU isolation control register 2     |
| GRF PMU MCU ISO CON_3    | 0x100C | W    | 0x00000000  | MCU isolation control register 3     |
| GRF PMU MCU ISO CON_4    | 0x1010 | W    | 0x00000000  | MCU isolation control register 4     |
| GRF PMU MCU ISO CON_5    | 0x1014 | W    | 0x00000000  | MCU isolation control register 5     |
| GRF PMU MCU ISO CON_6    | 0x1018 | W    | 0x00000000  | MCU isolation control register 6     |
| GRF PMU MCU ISO CON_7    | 0x101C | W    | 0x00000000  | MCU isolation control register 7     |
| GRF PMU MCU ISO CON_8    | 0x1020 | W    | 0x00000100  | MCU isolation control register 8     |
| GRF PMU MCU ISO CON_9    | 0x1024 | W    | 0x00000000  | MCU isolation control register 9     |
| GRF PMU MCU ISO CON_10   | 0x1028 | W    | 0x00000000  | MCU isolation control register 10    |
| GRF PMU MCU ISO CON_11   | 0x102C | W    | 0x00000000  | MCU isolation control register 11    |
| GRF PMU MCU ISO DDR CON0 | 0x1400 | W    | 0x00000000  | MCU isolation DDR control register 0 |
| GRF PMU MCU ISO DDR CON1 | 0x1404 | W    | 0x00000000  | MCU isolation DDR control register 1 |
| GRF PMU MCU ISO LOC_K    | 0x1500 | W    | 0x00000000  | Secure system control register 0     |
| GRF PMU CPU ISO CON_0    | 0x2000 | W    | 0x00000000  | CPU isolation control register 0     |
| GRF PMU CPU ISO CON_1    | 0x2004 | W    | 0x00000000  | CPU isolation control register 1     |
| GRF PMU CPU ISO CON_2    | 0x2008 | W    | 0x00000000  | CPU isolation control register 2     |
| GRF PMU CPU ISO CON_3    | 0x200C | W    | 0x00000000  | CPU isolation control register 3     |
| GRF PMU CPU ISO CON_4    | 0x2010 | W    | 0x00000000  | CPU isolation control register 4     |
| GRF PMU CPU ISO CON_5    | 0x2014 | W    | 0x00000000  | CPU isolation control register 5     |
| GRF PMU CPU ISO CON_6    | 0x2018 | W    | 0x00000000  | CPU isolation control register 6     |
| GRF PMU CPU ISO CON_7    | 0x201C | W    | 0x00000000  | CPU isolation control register 7     |
| GRF PMU CPU ISO CON_8    | 0x2020 | W    | 0x00000200  | CPU isolation control register 8     |
| GRF PMU CPU ISO CON_9    | 0x2024 | W    | 0x00000000  | CPU isolation control register 9     |
| GRF PMU CPU ISO CON_10   | 0x2028 | W    | 0x00000000  | CPU isolation control register 10    |
| GRF PMU CPU ISO CON_11   | 0x202C | W    | 0x00000000  | CPU isolation control register 11    |
| GRF PMU CPU ISO DDR CON0 | 0x2400 | W    | 0x00000000  | CPU isolation DDR control register 0 |
| GRF PMU CPU ISO DDR CON1 | 0x2404 | W    | 0x00000000  | CPU isolation DDR control register 1 |

| Name                  | Offset | Size | Reset Value | Description                      |
|-----------------------|--------|------|-------------|----------------------------------|
| GRF PMU CPU ISO LOC_K | 0x2500 | W    | 0x00000000  | Secure system control register 0 |

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

### 5.5.2 Detail Registers Description

#### GRF PMU SOC CON0

Address: Operational Base(0xFF910000) + 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:13 | RO   | 0x0         | reserved                                                                                                                                      |
| 12    | RW   | 0x0         | ddrphy_addrctrl_hz<br>1'b0: Disable DDRPHY io high-z<br>1'b1: Enable DDRPHY io high-z                                                         |
| 11    | RW   | 0x0         | ddrphy_addrctrl_hz_sel<br>DDRPHY IO state selection.<br>1'b0: addrcmd_hz comes from PMU<br>1'b1: addrcmd_hz comes from ddrphy_addrctrl_hz     |
| 10    | RO   | 0x0         | reserved                                                                                                                                      |
| 9     | RW   | 0x0         | ddrphy_io_ret<br>1'b0: Disable DDRPHY IO retention<br>1'b1: Enable DDRPHY IO retention                                                        |
| 8     | RW   | 0x0         | ddrphy_io_ret_sel<br>DDRPHY IO retention control selection.<br>1'b0: Retention control from PMU<br>1'b1: Retention control from ddrphy_io_ret |
| 7:2   | RO   | 0x00        | reserved                                                                                                                                      |
| 1     | RW   | 0x0         | force_jtag_uart0_rxm0<br>force JTAG select enable when UART0 select and RX keep low a few times<br>1'b0: Disable<br>1'b1: Enable              |
| 0     | RW   | 0x1         | mem_auto_gating_en<br>Enable memory auto gating<br>1'b0: Disable<br>1'b1: Enable                                                              |

#### GRF PMU SOC CON1

Address: Operational Base(0xFF910000) + offset (0x0004)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:12 | RO   | 0x0         | reserved                                                                                                                          |
| 11    | RW   | 0x0         | rmio_test_mode<br>RMIO test mode enable                                                                                           |
| 10    | RW   | 0x0         | clk_32k_oen<br>clk_32k output enable<br>1'b0: Disable<br>1'b1: Enable                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9          | RW          | 0x0                | sai1_mclk_oen<br>sai1_mclk output enable<br>1'b0: Disable<br>1'b1: Enable                                                                                                               |
| 8          | RW          | 0x0                | sai0_mclk_oen<br>sai0_mclk output enable<br>1'b0: Disable<br>1'b1: Enable                                                                                                               |
| 7:4        | RO          | 0x0                | reserved                                                                                                                                                                                |
| 3          | RW          | 0x0                | pmic_core_sleep_pol<br>pmic_core_sleep polarity. This bit can only reset by nPOR.<br>1'b0: not invert pmic_core_sleep<br>1'b1: invert pmic_core_sleep                                   |
| 2          | RW          | 0x0                | pmic_core_sleep_sel<br>pmic_core_sleep polarity. This bit can only reset by nPOR.<br>1'b0: nPOR_out2chip_rst, from reset pulse generator.<br>1'b1: pmu_sleep, from PMU block.           |
| 1          | RW          | 0x0                | pmic_logic_sleep_pol<br>pmic_logic_sleep polarity. This bit can only reset by nPOR.<br>1'b0: not invert pmic_logic_sleep<br>1'b1: invert pmic_logic_sleep                               |
| 0          | RW          | 0x0                | pmic_logic_sleep_sel<br>PMIC_LOGIC_SLEEP source selection. This bit can only reset by nPOR.<br>1'b0: nPOR_out2chip_rst, from reset pulse generator.<br>1'b1: pmu_sleep, from PMU block. |

### **GRF PMU SOC CON2**

Address: Operational Base(0xFF910000) + offset (0x0008)

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

### **GRF PMU SOC CON3**

Address: Operational Base(0xFF910000) + 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:10      | RO          | 0x00               | reserved                                                                                                                                        |
| 9          | RW          | 0x0                | resetn_pmu_touch_key_hold_ena<br>Hold resetn_touch_key. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable      |
| 8          | RW          | 0x0                | resetn_pmu_gpio1_shadow_hold_ena<br>Hold dbresetn_pmu_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>                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | RW          | 0x0                | presetn_pmu_pwm0_hold_ena<br>Hold presetn_pmu_pwm0. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable       |
| 6          | RO          | 0x0                | reserved                                                                                                                                     |
| 5          | RW          | 0x0                | presetn_pmu_sgrf_hold_ena<br>Hold presetn_pmu_sgrf. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable       |
| 4          | RW          | 0x0                | presetn_gpio0_ioc_hold_ena<br>Hold presetn_gpio0_ioc. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable     |
| 3          | RW          | 0x0                | presetn_pmu_grf_hold_ena<br>Hold presetn_pmu_grf. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable         |
| 2          | RW          | 0x0                | resetn_pmu_gpio0_hold_ena<br>Hold dbresetn_pmu_gpio0. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable     |
| 1          | RW          | 0x0                | presetn_pmu_cru_hold_ena<br>Hold presetn_pmu_cru. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable         |
| 0          | RW          | 0x0                | presetn_pmu_hptimer_hold_ena<br>Hold presetn_pmu_hptimer. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable |

#### **GRF PMU SOC CON4**

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | uart_jtag_dly_cnt<br>force jtag uart keep low counter |

#### **GRF PMU SOC CONS**

Address: Operational Base(0xFF910000) + offset (0x0014)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14:10      | RW          | 0x00               | <p>grf_gpio0_filter_sel1<br/>         GPIO select to go through second filter logic<br/>         5'h00: GPIO0A0<br/>         5'h01: GPIO0A1<br/>         5'h02: GPIO0A2<br/>         5'h03: GPIO0A3<br/>         5'h04: GPIO0A4<br/>         5'h05: GPIO0A5<br/>         5'h06: GPIO0A6<br/>         5'h07: GPIO0A7<br/>         5'h08: GPIO0B0<br/>         5'h09: GPIO0B1<br/>         5'h0a: GPIO0B2<br/>         5'h0b: GPIO0B3<br/>         5'h0c: GPIO0B4<br/>         5'h0d: GPIO0B5<br/>         5'h0e: GPIO0B6<br/>         5'h0f: GPIO0B7<br/>         5'h10: GPIO0C0<br/>         5'h11: GPIO0C1<br/>         5'h12: GPIO0C2<br/>         5'h13: GPIO0C3<br/>         5'h14: GPIO0C4<br/>         5'h15: GPIO0C5<br/>         5'h16: GPIO0C6<br/>         5'h17: GPIO0C7<br/>         5'h18: GPIO0D0</p> |
| 9          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 8:4        | RW          | 0x00               | <p>grf_gpio0_filter_sel0<br/>         GPIO select to go through first filter logic<br/>         5'h00: GPIO0A0<br/>         5'h01: GPIO0A1<br/>         5'h02: GPIO0A2<br/>         5'h03: GPIO0A3<br/>         5'h04: GPIO0A4<br/>         5'h05: GPIO0A5<br/>         5'h06: GPIO0A6<br/>         5'h07: GPIO0A7<br/>         5'h08: GPIO0B0<br/>         5'h09: GPIO0B1<br/>         5'h0a: GPIO0B2<br/>         5'h0b: GPIO0B3<br/>         5'h0c: GPIO0B4<br/>         5'h0d: GPIO0B5<br/>         5'h0e: GPIO0B6<br/>         5'h0f: GPIO0B7<br/>         5'h10: GPIO0C0<br/>         5'h11: GPIO0C1<br/>         5'h12: GPIO0C2<br/>         5'h13: GPIO0C3<br/>         5'h14: GPIO0C4<br/>         5'h15: GPIO0C5<br/>         5'h16: GPIO0C6<br/>         5'h17: GPIO0C7<br/>         5'h18: GPIO0D0</p>  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 3:0        | RW          | 0x0                | grf_gpio0_filter_en<br>There are four filter circuits for pad in GPIO0, each bit controls the enable of one filter. |

**GRF PMU SOC CON6**

Address: Operational Base(0xFF910000) + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 15         | RW          | 0x0                | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                                                                                                                                                                                                                                                               |
| 14:10      | RW          | 0x00               | grf_gpio0_filter_sel3<br>GPIO filter select to go through fourth filter logic<br>5'h00: GPIO0A0<br>5'h01: GPIO0A1<br>5'h02: GPIO0A2<br>5'h03: GPIO0A3<br>5'h04: GPIO0A4<br>5'h05: GPIO0A5<br>5'h06: GPIO0A6<br>5'h07: GPIO0A7<br>5'h08: GPIO0B0<br>5'h09: GPIO0B1<br>5'h0a: GPIO0B2<br>5'h0b: GPIO0B3<br>5'h0c: GPIO0B4<br>5'h0d: GPIO0B5<br>5'h0e: GPIO0B6<br>5'h0f: GPIO0B7<br>5'h10: GPIO0C0<br>5'h11: GPIO0C1<br>5'h12: GPIO0C2<br>5'h13: GPIO0C3<br>5'h14: GPIO0C4<br>5'h15: GPIO0C5<br>5'h16: GPIO0C6<br>5'h17: GPIO0C7<br>5'h18: GPIO0D0 |
| 9          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:4        | RW          | 0x00               | grf_gpio0_filter_sel2<br>GPIO filter select to go through third filter logic<br>5'h00: GPIO0A0<br>5'h01: GPIO0A1<br>5'h02: GPIO0A2<br>5'h03: GPIO0A3<br>5'h04: GPIO0A4<br>5'h05: GPIO0A5<br>5'h06: GPIO0A6<br>5'h07: GPIO0A7<br>5'h08: GPIO0B0<br>5'h09: GPIO0B1<br>5'h0a: GPIO0B2<br>5'h0b: GPIO0B3<br>5'h0c: GPIO0B4<br>5'h0d: GPIO0B5<br>5'h0e: GPIO0B6<br>5'h0f: GPIO0B7<br>5'h10: GPIO0C0<br>5'h11: GPIO0C1<br>5'h12: GPIO0C2<br>5'h13: GPIO0C3<br>5'h14: GPIO0C4<br>5'h15: GPIO0C5<br>5'h16: GPIO0C6<br>5'h17: GPIO0C7<br>5'h18: GPIO0D0 |
| 3:0        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

#### **GRF PMU SOC CON7**

Address: Operational Base(0xFF910000) + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                                                                                |
| 19:0       | RW          | 0x00000            | grf_gpio0_filter_count0<br>Filter counter for first filter logic. When this value is n, it will filter pulse which width is n+1 oscillator clock cycle. |

#### **GRF PMU SOC CON8**

Address: Operational Base(0xFF910000) + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                                                                                 |
| 19:0       | RW          | 0x00000            | grf_gpio0_filter_count1<br>Filter counter for second filter logic. When this value is n, it will filter pulse which width is n+1 oscillator clock cycle. |

#### **GRF PMU SOC CON9**

Address: Operational Base(0xFF910000) + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                                                                                |
| 19:0       | RW          | 0x00000            | grf_gpio0_filter_count2<br>Filter counter for third filter logic. When this value is n, it will filter pulse which width is n+1 oscillator clock cycle. |

#### **GRF PMU SOC CON10**

Address: Operational Base(0xFF910000) + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                                                                                 |
| 19:0       | RW          | 0x00000            | grf_gpio0_filter_count3<br>Filter counter for fourth filter logic. When this value is n, it will filter pulse which width is n+1 oscillator clock cycle. |

**GRF PMU SOC CON11**

Address: Operational Base(0xFF910000) + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 15         | RW          | 0x0                | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 14:10      | RW          | 0x00               | grf_gpio1_shadow_filter_sel1<br>GPIO select to go through second filter logic<br>5'h00: GPIO1A0<br>5'h01: GPIO1A1<br>5'h02: GPIO1A2<br>5'h03: GPIO1A3<br>5'h04: GPIO1A4<br>5'h05: GPIO1A5<br>5'h06: GPIO1A6<br>5'h07: GPIO1A7<br>5'h08: GPIO1B0<br>5'h09: GPIO1B1<br>5'h0a: GPIO1B2<br>5'h0b: GPIO1B3<br>5'h0c: GPIO1B4<br>5'h0d: GPIO1B5<br>5'h0e: GPIO1B6<br>5'h0f: GPIO1B7<br>5'h10: GPIO1C0<br>5'h11: GPIO1C1<br>5'h12: GPIO1C2<br>5'h13: GPIO1C3<br>5'h14: GPIO1C4<br>5'h15: GPIO1C5<br>5'h16: GPIO1C6<br>5'h17: GPIO1C7<br>5'h18: GPIO1D0<br>5'h19: GPIO1D1<br>5'h1a: GPIO1D2<br>5'h1b: GPIO1D3 |
| 9          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:4 | RW   | 0x00        | grf_gpio1_shadow_filter_sel0<br>GPIO select to go through first filter logic<br>5'h00: GPIO1A0<br>5'h01: GPIO1A1<br>5'h02: GPIO1A2<br>5'h03: GPIO1A3<br>5'h04: GPIO1A4<br>5'h05: GPIO1A5<br>5'h06: GPIO1A6<br>5'h07: GPIO1A7<br>5'h08: GPIO1B0<br>5'h09: GPIO1B1<br>5'h0a: GPIO1B2<br>5'h0b: GPIO1B3<br>5'h0c: GPIO1B4<br>5'h0d: GPIO1B5<br>5'h0e: GPIO1B6<br>5'h0f: GPIO1B7<br>5'h10: GPIO1C0<br>5'h11: GPIO1C1<br>5'h12: GPIO1C2<br>5'h13: GPIO1C3<br>5'h14: GPIO1C4<br>5'h15: GPIO1C5<br>5'h16: GPIO1C6<br>5'h17: GPIO1C7<br>5'h18: GPIO1D0<br>5'h19: GPIO1D1<br>5'h1a: GPIO1D2<br>5'h1b: GPIO1D3 |
| 3:0 | RW   | 0x0         | grf_gpio1_shadow_filter_en<br>There are four filter circuits for pad in GPIO1_SHADOW, each bit controls the enable of one filter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

**GRF PMU SOC CON12**

Address: Operational Base(0xFF910000) + offset (0x0030)

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

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14:10 | RW   | 0x00        | grf_gpio1_shadow_filter_sel3<br>GPIO select to go through fourth filter logic<br>5'h00: GPIO1A0<br>5'h01: GPIO1A1<br>5'h02: GPIO1A2<br>5'h03: GPIO1A3<br>5'h04: GPIO1A4<br>5'h05: GPIO1A5<br>5'h06: GPIO1A6<br>5'h07: GPIO1A7<br>5'h08: GPIO1B0<br>5'h09: GPIO1B1<br>5'h0a: GPIO1B2<br>5'h0b: GPIO1B3<br>5'h0c: GPIO1B4<br>5'h0d: GPIO1B5<br>5'h0e: GPIO1B6<br>5'h0f: GPIO1B7<br>5'h10: GPIO1C0<br>5'h11: GPIO1C1<br>5'h12: GPIO1C2<br>5'h13: GPIO1C3<br>5'h14: GPIO1C4<br>5'h15: GPIO1C5<br>5'h16: GPIO1C6<br>5'h17: GPIO1C7<br>5'h18: GPIO1D0<br>5'h19: GPIO1D1<br>5'h1a: GPIO1D2<br>5'h1b: GPIO1D3 |
| 9     | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:4 | RW   | 0x00        | grf_gpio1_shadow_filter_sel2<br>GPIO select to go through third filter logic<br>5'h00: GPIO1A0<br>5'h01: GPIO1A1<br>5'h02: GPIO1A2<br>5'h03: GPIO1A3<br>5'h04: GPIO1A4<br>5'h05: GPIO1A5<br>5'h06: GPIO1A6<br>5'h07: GPIO1A7<br>5'h08: GPIO1B0<br>5'h09: GPIO1B1<br>5'h0a: GPIO1B2<br>5'h0b: GPIO1B3<br>5'h0c: GPIO1B4<br>5'h0d: GPIO1B5<br>5'h0e: GPIO1B6<br>5'h0f: GPIO1B7<br>5'h10: GPIO1C0<br>5'h11: GPIO1C1<br>5'h12: GPIO1C2<br>5'h13: GPIO1C3<br>5'h14: GPIO1C4<br>5'h15: GPIO1C5<br>5'h16: GPIO1C6<br>5'h17: GPIO1C7<br>5'h18: GPIO1D0<br>5'h19: GPIO1D1<br>5'h1a: GPIO1D2<br>5'h1b: GPIO1D3 |
| 3:0 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

**GRF PMU SOC CON13**

Address: Operational Base(0xFF910000) + offset (0x0034)

| Bit   | Attr | Reset Value | Description                                                                                                                                                    |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | RO   | 0x000       | reserved                                                                                                                                                       |
| 19:0  | RW   | 0x00000     | grf_gpio1_shadow_filter_count0<br>Filter counter for first filter logic. When this value is n, it will filter pulse which width is n+1 oscillator clock cycle. |

**GRF PMU SOC CON14**

Address: Operational Base(0xFF910000) + offset (0x0038)

| Bit   | Attr | Reset Value | Description                                                                                                                                                     |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | RO   | 0x000       | reserved                                                                                                                                                        |
| 19:0  | RW   | 0x00000     | grf_gpio1_shadow_filter_count1<br>Filter counter for second filter logic. When this value is n, it will filter pulse which width is n+1 oscillator clock cycle. |

**GRF PMU SOC CON15**

Address: Operational Base(0xFF910000) + offset (0x003C)

| Bit   | Attr | Reset Value | Description                                                                                                                                                    |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | RO   | 0x000       | reserved                                                                                                                                                       |
| 19:0  | RW   | 0x00000     | grf_gpio1_shadow_filter_count2<br>Filter counter for third filter logic. When this value is n, it will filter pulse which width is n+1 oscillator clock cycle. |

**GRF PMU SOC CON16**

Address: Operational Base(0xFF910000) + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                                                                                        |
| 19:0       | RW          | 0x00000            | grf_gpio1_shadow_filter_count3<br>Filter counter for fourth filter logic. When this value is n, it will filter pulse which width is n+1 oscillator clock cycle. |

**GRF PMU SOC CON17**

Address: Operational Base(0xFF910000) + 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:0       | RW          | 0x0000             | gpio1_shadow_enable_low<br>GPIO1_SHADOW enable for GPIO1A0~APIO1B7, each bit for one GPIO.                                        |

**GRF PMU SOC CON18**

Address: Operational Base(0xFF910000) + 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:12      | RO          | 0x0                | reserved                                                                                                                          |
| 11:0       | RW          | 0x000              | gpio1_shadow_enable_high<br>GPIO1_SHADOW enable for GPIO1C0~APIO1D3, each bit for one GPIO.                                       |

**GRF PMU SOC STATUS**

Address: Operational Base(0xFF910000) + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                               |
| 0          | RO          | 0x1                | npor_powergood<br>NPOR power state.<br>1'b0: Power bad state<br>1'b1: Power good state |

**GRF PMU OS REG0**

Address: Operational Base(0xFF910000) + offset (0x0200)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | os_reg<br>OS register, with reset pin. it's bit0~31 can use to control the signal 0~31 of IO array when io_array_test_mode is asserted. |

**GRF PMU OS REG1**

Address: Operational Base(0xFF910000) + offset (0x0204)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | os_reg<br>OS register, with reset pin. it's bit0~31 can use to control the signal 32~65 of IO array when io_array_test_mode is asserted. |

**GRF PMU OS REG2**

Address: Operational Base(0xFF910000) + offset (0x0208)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | os_reg<br>OS register, with reset pin. it's bit0~31 can use to control the signal 64~95 of IO array when io_array_test_mode is asserted. |

**GRF PMU OS REG3**

Address: Operational Base(0xFF910000) + offset (0x020C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | os_reg<br>OS register, with reset pin. it's bit0~1 can use to control the signal 96~97 of IO array when io_array_test_mode is asserted. |

**GRF PMU OS REG4**

Address: Operational Base(0xFF910000) + offset (0x0210)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | os_reg<br>OS register, with reset pin. it's bit0~31 can use to control the signal output enable 0~31 of IO array when io_array_test_mode is asserted. |

**GRF PMU OS REG5**

Address: Operational Base(0xFF910000) + offset (0x0214)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | os_reg<br>OS register, with reset pin. it's bit0~31 can use to control the signal output enable 32~65 of IO array when io_array_test_mode is asserted. |

**GRF PMU OS REG6**

Address: Operational Base(0xFF910000) + offset (0x0218)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | os_reg<br>OS register, with reset pin. it's bit0~31 can use to control the signal output enable 64~95 of IO array when io_array_test_mode is asserted. |

**GRF PMU OS REG7**

Address: Operational Base(0xFF910000) + offset (0x021C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | os_reg<br>OS register, with reset pin. it's bit0~1 can use to control the signal output enable 96~97 of IO array when io_array_test_mode is asserted. |

**GRF PMU OS REG8**

Address: Operational Base(0xFF910000) + offset (0x0220)

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

**GRF PMU OS REG9**

Address: Operational Base(0xFF910000) + offset (0x0224)

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

**GRF PMU OS REG10**

Address: Operational Base(0xFF910000) + offset (0x0228)

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

**GRF PMU OS REG11**

Address: Operational Base(0xFF910000) + offset (0x022C)

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

**GRF PMU RSTFUNC STATUS**

Address: Operational Base(0xFF910000) + offset (0x0230)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                                                                                                                                          |
| 2          | RO          | 0x0                | tsadc_shut_reset_src_stat<br>Reset state.<br>When high, reset by TSADC shut trigger. After power on, user should clear the status once by write 1'b1 to tsadc_shut_reset_src_clr. |
| 1          | RO          | 0x0                | wdt_reset_src_stat<br>Reset state.<br>When high, reset by WDT trigger. After power on, user should clear the status once by write 1'b1 to wdt_reset_src_clr.                      |
| 0          | RO          | 0x0                | first_reset_src_stat<br>Reset state.<br>When high, reset by first reset trigger. After power on, user should clear the status once by write 1'b1 to first_reset_src_clr.          |

**GRF PMU RSTFUNC CLR**

Address: Operational Base(0xFF910000) + offset (0x0234)

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

**GRF PMU MCU ISO CON0**

Address: Operational Base(0xFF910000) + offset (0x1000)

| <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          | 0x0                | dsmc_mem_iso_ctrl<br>DSMC_MEM control bit. There are 1024MB address space for DSMC_MEM, it is separated into four 256MB space.<br>dsmc_mem_iso_ctrl[0], first 256MB<br>dsmc_mem_iso_ctrl[1], second 256MB<br>dsmc_mem_iso_ctrl[2], third 256MB<br>dsmc_mem_iso_ctrl[3], fourth 256MB<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU     |
| 11         | RW          | 0x0                | dsmc_iso_ctrl<br>DSMC isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                                              |
| 10         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                 |
| 9          | RW          | 0x0                | flexbus_iso_ctrl<br>FLEXBUS isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                                        |
| 8:5        | RW          | 0x0                | gpio1_iso_ctrl<br>GPIO1 isolation control bit. There are 16KB address space for GPIO1, it is separated into four 4KB space.<br>gpio1_iso_ctrl[0], first 4KB<br>gpio1_iso_ctrl[1], second 4KB<br>gpio1_iso_ctrl[2], third 4KB<br>gpio1_iso_ctrl[3], fourth 4KB<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                            |
| 4:1        | RW          | 0x0                | grf_core_iso_ctrl<br>GRF_CORE slave isolation control bit. There are 16KB address space for GRF_CORE, it is separated into four 4KB space.<br>grf_core_iso_ctrl[0], first 4KB<br>grf_core_iso_ctrl[1], second 4KB<br>grf_core_iso_ctrl[2], third 4KB<br>grf_core_iso_ctrl[3], fourth 4KB<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU |
| 0          | RW          | 0x0                | a7dbg_iso_ctrl<br>A7 debug isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                                         |

**GRF PMU MCU ISO CON1**

Address: Operational Base(0xFF910000) + offset (0x1004)

| <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          | 0x0                | mailbox_iso_ctrl<br>MAILBOX slave isolation control bit, There are 16KB address space for MAILBOX, it is separated into four 4KB space.<br>mailbox_iso_ctrl[0], first 4KB<br>mailbox_iso_ctrl[1], second 4KB<br>mailbox_iso_ctrl[2], third 4KB<br>mailbox_iso_ctrl[3], fourth 4KB<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU |
| 11:8       | RW          | 0x0                | grf_bus_iso_ctrl<br>GRF_BUS slave isolation control bit. There are 16KB address space for GRF_BUS, it is separated into four 4KB space.<br>grf_bus_iso_ctrl[0], first 4KB<br>grf_bus_iso_ctrl[1], second 4KB<br>grf_bus_iso_ctrl[2], third 4KB<br>grf_bus_iso_ctrl[3], fourth 4KB<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU |
| 7          | RW          | 0x0                | ddr_lpc_iso_ctrl<br>DDR LPC slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                           |
| 6          | RW          | 0x0                | ddr_monitor_iso_ctrl<br>DDR monitor slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                   |
| 5          | RW          | 0x0                | ddrc_iso_ctrl<br>DDR controller slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                       |
| 4          | RW          | 0x0                | dmac1_iso_ctrl<br>DMAC1 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                               |
| 3          | RW          | 0x0                | dmac0_iso_ctrl<br>DMAC0 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                               |
| 2          | RW          | 0x0                | sgrf_bus_iso_ctrl<br>SGRF_BUS isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                               |
| 1          | RW          | 0x0                | secure_dmac1_iso_ctrl<br>DMAC1 secure only slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                            |
| 0          | RW          | 0x0                | secure_dmac0_iso_ctrl<br>DMAC0 secure only slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                            |

**GRF PMU MCU ISO CON2**

Address: Operational Base(0xFF910000) + offset (0x1008)

| <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       | RW          | 0x00               | timer1_iso_ctrl<br>TIMER1 slave isolation control bit. There are 32KB address space for TIMER1, it is separated into eight 4KB space.<br>timer1_iso_ctrl[0], first 4KB<br>timer1_iso_ctrl[1], second 4KB<br>timer1_iso_ctrl[2], third 4KB<br>timer1_iso_ctrl[3], fourth 4KB<br>timer1_iso_ctrl[4], fifth 4KB<br>timer1_iso_ctrl[5], sixth 4KB<br>timer1_iso_ctrl[6], seventh 4KB<br>timer1_iso_ctrl[7], eighth 4KB<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU |
| 7:0        | RW          | 0x00               | timer0_iso_ctrl<br>TIMER0 slave isolation control bit. There are 32KB address space for TIMER0, it is separated into eight 4KB space.<br>timer0_iso_ctrl[0], first 4KB<br>timer0_iso_ctrl[1], second 4KB<br>timer0_iso_ctrl[2], third 4KB<br>timer0_iso_ctrl[3], fourth 4KB<br>timer0_iso_ctrl[4], fifth 4KB<br>timer0_iso_ctrl[5], sixth 4KB<br>timer0_iso_ctrl[6], seventh 4KB<br>timer0_iso_ctrl[7], eighth 4KB<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU |

**GRF PMU MCU ISO CON3**

Address: Operational Base(0xFF910000) + offset (0x100C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable         |
| 15         | RO          | 0x0                | reserved                                                                                                                                  |
| 14         | RW          | 0x0                | dma2ddr_iso_ctrl<br>DMA2DDR slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                   |
| 13         | RW          | 0x0                | secure_trng_iso_ctrl<br>Secure RNG slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU            |
| 12         | RW          | 0x0                | secure_keyladder_iso_ctrl<br>Secure keyladder slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU |
| 11         | RW          | 0x0                | secure_crypto_iso_ctrl<br>Secure CRYPTO slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU       |

| Bit | Attr | Reset Value | Description                                                                                                                         |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 10  | RW   | 0x0         | bootrom_iso_ctrl<br>BOOTROM slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU             |
| 9   | RW   | 0x0         | ddrphy_iso_ctrl<br>DDRPHY slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU               |
| 8   | RW   | 0x0         | usb2otg1_iso_ctrl<br>USB2.0_OTG1 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU        |
| 7   | RW   | 0x0         | usb2otg0_iso_ctrl<br>USB2.0_OTG0 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU        |
| 6   | RW   | 0x0         | ns_trng_iso_ctrl<br>RNG non-secure slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU      |
| 5   | RW   | 0x0         | ns_crypto_iso_ctrl<br>Crypto non-secure slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU |
| 4   | RW   | 0x0         | usbphy_iso_ctrl<br>USBPHY slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU               |
| 3   | RW   | 0x0         | intmux_iso_ctrl<br>INTMUX slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU               |
| 2   | RO   | 0x0         | reserved                                                                                                                            |
| 1   | RW   | 0x0         | wdt1_iso_ctrl<br>WDT1 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                   |
| 0   | RW   | 0x0         | wdt0_iso_ctrl<br>WDT0 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                   |

**GRF PMU MCU ISO CON4**

Address: Operational Base(0xFF910000) + offset (0x1010)

| 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         | uart4_iso_ctrl<br>UART4 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU               |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14  | RW   | 0x0         | uart3_iso_ctrl<br>UART3 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                                      |
| 13  | RW   | 0x0         | uart2_iso_ctrl<br>UART2 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                                      |
| 12  | RW   | 0x0         | uart1_iso_ctrl<br>UART1 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                                      |
| 11  | RW   | 0x0         | uart0_iso_ctrl<br>UART0 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                                      |
| 10  | RW   | 0x0         | spi1_iso_ctrl<br>SPI1 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                                        |
| 9   | RW   | 0x0         | spi0_iso_ctrl<br>SPI0 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                                        |
| 8   | RW   | 0x0         | i2c2_iso_ctrl<br>I2C2 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                                        |
| 7   | RW   | 0x0         | i2c1_iso_ctrl<br>I2C1 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                                        |
| 6   | RW   | 0x0         | i2c0_iso_ctrl<br>I2C0 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                                        |
| 5:4 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                 |
| 3:0 | RW   | 0x0         | spinlock_iso_ctrl<br>SPINLOCK slave isolation control bit, There are 16KB address space for SPINLOCK, it is separated into four 4KB space.<br>spinlock_iso_ctrl[0], first 4KB<br>spinlock_iso_ctrl[1], second 4KB<br>spinlock_iso_ctrl[2], third 4KB<br>spinlock_iso_ctrl[3], fourth 4KB<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU |

**GRF PMU MCU ISO CONS**

Address: Operational Base(0xFF910000) + offset (0x1014)

| 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:12      | RW          | 0x0                | <p>gpio3_iso_ctrl<br/>GPIO3 slave isolation control bit. There are 16KB address space for GPIO3, it is separated into four 4KB space.</p> <p>gpio3_iso_ctrl[0], first 4KB<br/>gpio3_iso_ctrl[1], second 4KB<br/>gpio3_iso_ctrl[2], third 4KB<br/>gpio3_iso_ctrl[3], fourth 4KB</p> <p>1'b0: Can be access by MCU<br/>1'b1: Can not be access by MCU</p>                                                                                                                              |
| 11:8       | RW          | 0x0                | <p>gpio2_iso_ctrl<br/>GPIO2 slave isolation control bit. There are 16KB address space for GPIO2, it is separated into four 4KB space.</p> <p>gpio2_iso_ctrl[0], first 4KB<br/>gpio2_iso_ctrl[1], second 4KB<br/>gpio2_iso_ctrl[2], third 4KB<br/>gpio2_iso_ctrl[3], fourth 4KB</p> <p>1'b0: Can be access by MCU<br/>1'b1: Can not be access by MCU</p>                                                                                                                              |
| 7:0        | RW          | 0x00               | <p>pwm1_iso_ctrl<br/>PWM1 slave isolation control bit. There are 32KB address space for PWM1, it is separated into eight 4KB space.</p> <p>pwm1_iso_ctrl[0], first 4KB<br/>pwm1_iso_ctrl[1], second 4KB<br/>pwm1_iso_ctrl[2], third 4KB<br/>pwm1_iso_ctrl[3], fourth 4KB<br/>pwm1_iso_ctrl[4], fifth 4KB<br/>pwm1_iso_ctrl[5], sixth 4KB<br/>pwm1_iso_ctrl[6], seventh 4KB<br/>pwm1_iso_ctrl[7], eighth 4KB</p> <p>1'b0: Can be access by MCU<br/>1'b1: Can not be access by MCU</p> |

**GRF PMU MCU ISO CON6**

Address: Operational Base(0xFF910000) + offset (0x1018)

| <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.</p> <p>1'b0: Write access disable<br/>1'b1: Write access enable</p> |
| 15         | RW          | 0x0                | <p>gpio1_ioc_iso_ctrl<br/>GPIO1_IOC slave isolation control bit</p> <p>1'b0: Can be access by MCU<br/>1'b1: Can not be access by MCU</p>       |
| 14         | RW          | 0x0                | <p>dphy_iso_ctrl<br/>DPHY slave isolation control bit</p> <p>1'b0: Can be access by MCU<br/>1'b1: Can not be access by MCU</p>                 |
| 13         | RW          | 0x0                | <p>dsi_iso_ctrl<br/>DSI slave isolation control bit</p> <p>1'b0: Can be access by MCU<br/>1'b1: Can not be access by MCU</p>                   |
| 12         | RW          | 0x0                | <p>spdif_rx_iso_ctrl<br/>SPDIF_RX slave isolation control bit</p> <p>1'b0: Can be access by MCU<br/>1'b1: Can not be access by MCU</p>         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11         | RW          | 0x0                | spdif_tx_iso_ctrl<br>SPDIF_TX slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                           |
| 10         | RW          | 0x0                | pdm_iso_ctrl<br>PDM slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                     |
| 9          | RW          | 0x0                | can1_iso_ctrl<br>CAN1 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                   |
| 8          | RW          | 0x0                | can0_iso_ctrl<br>CAN0 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                   |
| 7          | RW          | 0x0                | sai1_iso_ctrl<br>SAI1 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                   |
| 6          | RW          | 0x0                | sai0_iso_ctrl<br>SAI0 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                   |
| 5          | RW          | 0x0                | asrc1_iso_ctrl<br>ASRC1 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                 |
| 4          | RW          | 0x0                | asrc0_iso_ctrl<br>ASRC0 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                 |
| 3:0        | RW          | 0x0                | gpio4_iso_ctrl<br>GPIO4 slave isolation control bit. There are 16KB address space for GPIO4, it is separated into four 4KB space.<br>gpio4_iso_ctrl[0], first 4KB<br>gpio4_iso_ctrl[1], second 4KB<br>gpio4_iso_ctrl[2], third 4KB<br>gpio4_iso_ctrl[3], fourth 4KB<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU |

### **GRF PMU MCU ISO CON7**

Address: Operational Base(0xFF910000) + offset (0x101C)

| <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                | fspi_iso_ctrl<br>FSPI slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 14         | RW          | 0x0                | sdmmc_iso_ctrl<br>SDMMC slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                               |
| 13         | RW          | 0x0                | audio_adc_iso_ctrl<br>Audio ADC slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                       |
| 12         | RW          | 0x0                | gpio234_ioc_iso_ctrl<br>GPIO2_IOC/GPIO3_IOC/GPIO4_IOC slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU |
| 11         | RW          | 0x0                | saradc_iso_ctrl<br>SARADC slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                             |
| 10         | RW          | 0x0                | otpc_ns_iso_ctrl<br>Non-secure OTPC slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                   |
| 9          | RW          | 0x0                | uart5_iso_ctrl<br>UART5 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                               |
| 8          | RW          | 0x0                | spi2_iso_ctrl<br>SPI2 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                 |
| 7          | RW          | 0x0                | mac1_iso_ctrl<br>MAC1 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                 |
| 6          | RW          | 0x0                | mac0_iso_ctrl<br>MAC0 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                 |
| 5          | RW          | 0x0                | secure_keyreader_iso_ctrl<br>Secure KEYREADER slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU         |
| 4          | RW          | 0x0                | secure_otpc_mask_iso_ctrl<br>Secure OTPC mask slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU         |
| 3          | RW          | 0x0                | secure_otpc_iso_ctrl<br>Secure OTPC slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                   |
| 2          | RW          | 0x0                | vop_iso_ctrl<br>VOP slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                   |
| 1          | RW          | 0x0                | rga_iso_ctrl<br>RGA slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | tsadc_iso_ctrl<br>TSADC controller slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU |

**GRF PMU MCU ISO CON8**

Address: Operational Base(0xFF910000) + offset (0x1020)

| <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          | 0x0                | gpio0_iso_ctrl<br>GPIO0 slave isolation control bit. There are 16KB address space for GPIO0, it is separated into four 4KB space.<br>gpio0_iso_ctrl[0], first 4KB<br>gpio0_iso_ctrl[1], second 4KB<br>gpio0_iso_ctrl[2], third 4KB<br>gpio0_iso_ctrl[3], fourth 4KB<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU               |
| 11         | RW          | 0x0                | sgrf_pmu_iso_ctrl<br>sgrf_pmu slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                         |
| 10:7       | RW          | 0x2                | grf_pmu_iso_ctrl<br>GRF_PMU slave isolation control bit. There are 16KB address space for GRF_PMU, it is separated into four 4KB space.<br>grf_pmu_iso_ctrl[0], first 4KB<br>grf_pmu_iso_ctrl[1], second 4KB<br>grf_pmu_iso_ctrl[2], third 4KB<br>grf_pmu_iso_ctrl[3], fourth 4KB<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU |
| 6          | RW          | 0x0                | secure_cru_pmu_iso_ctrl<br>Secure CRU_PMU slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                             |
| 5          | RW          | 0x0                | cru_pmu_iso_ctrl<br>CRU_PMU slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                           |
| 4          | RW          | 0x0                | pmu_iso_ctrl<br>PMU slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                                   |
| 3          | RW          | 0x0                | audio_dsm_iso_ctrl<br>Audio DSM slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                       |
| 2          | RW          | 0x0                | sai4_iso_ctrl<br>SAI4 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | sai3_iso_ctrl<br>SAI3 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU |
| 0          | RW          | 0x0                | sai2_iso_ctrl<br>SAI2 slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU |

**GRF PMU MCU ISO CON9**

Address: Operational Base(0xFF910000) + offset (0x1024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                                                                                                    |
| 15:13      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                             |
| 12         | RW          | 0x0                | secure_cru_iso_ctrl<br>Secure CRU slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                                                        |
| 11         | RW          | 0x0                | cru_iso_ctrl<br>CRU slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                                                                      |
| 10         | RW          | 0x0                | gpio0_ioc_iso_ctrl<br>GPIO0_IOC slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                                                          |
| 9          | RW          | 0x0                | touchkey_iso_ctrl<br>Touch key slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                                                           |
| 8:5        | RW          | 0x0                | pwm0_iso_ctrl<br>PWM0 slave isolation control bit. There are 16KB address space for PWM0, it is separated into four 4KB space.<br>pwm0_iso_ctrl[0], first 4KB<br>pwm0_iso_ctrl[1], second 4KB<br>pwm0_iso_ctrl[2], third 4KB<br>pwm0_iso_ctrl[3], fourth 4KB<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                         |
| 4          | RW          | 0x0                | hptimer_iso_ctrl<br>HPTIMER slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU                                                                                                                                                                                                                                                              |
| 3:0        | RW          | 0x0                | gpio1_shadow_iso_ctrl<br>GPIO1_SHADOW slave isolation control bit. There are 16KB address space for GPIO1_SHADOW, it is separated into four 4KB space.<br>gpio1_shadow_iso_ctrl[0], first 4KB<br>gpio1_shadow_iso_ctrl[1], second 4KB<br>gpio1_shadow_iso_ctrl[2], third 4KB<br>gpio1_shadow_iso_ctrl[3], fourth 4KB<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU |

**GRF PMU MCU ISO CON10**

Address: Operational Base(0xFF910000) + offset (0x1028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable        |
| 15:7       | RO          | 0x000              | reserved                                                                                                                                 |
| 6          | RW          | 0x0                | nocsrv_firewall_iso_ctrl<br>firewall slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU         |
| 5          | RW          | 0x0                | nocsrv_ddr_iso_ctrl<br>noc service ddr slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU       |
| 4          | RW          | 0x0                | nocsrv_vio_iso_ctrl<br>noc service vio slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU       |
| 3          | RW          | 0x0                | nocsrv_hsperi_iso_ctrl<br>noc service hsperi slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU |
| 2          | RW          | 0x0                | nocsrv_bus_iso_ctrl<br>noc service bus slave isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU       |
| 1          | RW          | 0x0                | nocsrv_cpup_iso_ctrl<br>noc service cpu peripheral isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU |
| 0          | RW          | 0x0                | nocsrv_cpu_iso_ctrl<br>noc service cpu isolation control bit<br>1'b0: Can be access by MCU<br>1'b1: Can not be access by MCU             |

**GRF PMU MCU ISO CON11**

Address: Operational Base(0xFF910000) + offset (0x102C)

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

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:0 | RW   | 0x000       | <p>sysram_iso_ctrl<br/>           System sram isolation control bit, There are 48KB address space for System sram, it is separated into eight 4KB space.</p> <ul style="list-style-type: none"> <li>sysram_iso_ctrl[0], first 4KB</li> <li>sysram_iso_ctrl[1], second 4KB</li> <li>sysram_iso_ctrl[2], third 4KB</li> <li>sysram_iso_ctrl[3], fourth 4KB</li> <li>sysram_iso_ctrl[4], fifth 4KB</li> <li>sysram_iso_ctrl[5], sixth 4KB</li> <li>sysram_iso_ctrl[6], seventh 4KB</li> <li>sysram_iso_ctrl[7], eighth 4KB</li> <li>sysram_iso_ctrl[8], ninth 4KB</li> <li>sysram_iso_ctrl[9], tenth 4KB</li> <li>sysram_iso_ctrl[10], eleventh 4KB</li> <li>sysram_iso_ctrl[11], twelfth 4KB</li> </ul> <p>1'b0: Can be access by MCU<br/>           1'b1: Can not be access by MCU</p> |

**GRF PMU MCU ISO DDR CON0**

Address: Operational Base(0xFF910000) + offset (0x1400)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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>usb2otg1_ddr_iso_ctrl<br/>           USB2.0_OTG1 access DDR isolation control bit<br/>           1'b0: Can be access<br/>           1'b1: Can not be access<br/>           Notes: The access is controlled by MCU_ISO_DDR_CON0[15] and CPU_ISO_DDR_CON0[15]. It can not be access when any bit is asserted.</p> |
| 14    | RW   | 0x0         | <p>usb2otg0_ddr_iso_ctrl<br/>           USB2.0_OTG0 access DDR isolation control bit<br/>           1'b0: Can be access<br/>           1'b1: Can not be access<br/>           Notes: The access is controlled by MCU_ISO_DDR_CON0[14] and CPU_ISO_DDR_CON0[14]. It can not be access when any bit is asserted.</p> |
| 13    | RW   | 0x0         | <p>spi2_ddr_iso_ctrl<br/>           SPI2 access DDR isolation control bit<br/>           1'b0: Can be access<br/>           1'b1: Can not be access<br/>           Notes: The access is controlled by MCU_ISO_DDR_CON0[13] and CPU_ISO_DDR_CON0[13]. It can not be access when any bit is asserted.</p>            |
| 12    | RW   | 0x0         | <p>rga_wr_ddr_iso_ctrl<br/>           RGA write access DDR isolation control bit<br/>           1'b0: Can be access<br/>           1'b1: Can not be access<br/>           Notes: The access is controlled by MCU_ISO_DDR_CON0[12] and CPU_ISO_DDR_CON0[12]. It can not be access when any bit is asserted.</p>     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11         | RW          | 0x0                | <p>rga_rd_ddr_iso_ctrl<br/>RGA read access DDR isolation control bit<br/>1'b0: Can be access<br/>1'b1: Can not be access<br/>Notes: The access is controlled by MCU_ISO_DDR_CON0[11] and CPU_ISO_DDR_CON0[11]. It can not be access when any bit is asserted.</p> |
| 10         | RW          | 0x0                | <p>dma2ddr_ddr_iso_ctrl<br/>DMA2DDR access DDR isolation control bit<br/>1'b0: Can be access<br/>1'b1: Can not be access<br/>Notes: The access is controlled by MCU_ISO_DDR_CON0[10] and CPU_ISO_DDR_CON0[10]. It can not be access when any bit is asserted.</p> |
| 9          | RW          | 0x0                | <p>mcu_ddr_iso_ctrl<br/>MCU access DDR isolation control bit<br/>1'b0: Can be access<br/>1'b1: Can not be access<br/>Notes: The access is controlled by MCU_ISO_DDR_CON0[9] and CPU_ISO_DDR_CON0[9]. It can not be access when any bit is asserted.</p>           |
| 8          | RW          | 0x0                | <p>mac1_ddr_iso_ctrl<br/>MAC1 access DDR isolation control bit<br/>1'b0: Can be access<br/>1'b1: Can not be access<br/>Notes: The access is controlled by MCU_ISO_DDR_CON0[8] and CPU_ISO_DDR_CON0[8]. It can not be access when any bit is asserted.</p>         |
| 7          | RW          | 0x0                | <p>mac0_ddr_iso_ctrl<br/>MAC0 access DDR isolation control bit<br/>1'b0: Can be access<br/>1'b1: Can not be access<br/>Notes: The access is controlled by MCU_ISO_DDR_CON0[7] and CPU_ISO_DDR_CON0[7]. It can not be access when any bit is asserted.</p>         |
| 6          | RW          | 0x0                | <p>fpsi_ddr_iso_ctrl<br/>FSPI access DDR isolation control bit<br/>1'b0: Can be access<br/>1'b1: Can not be access<br/>Notes: The access is controlled by MCU_ISO_DDR_CON0[6] and CPU_ISO_DDR_CON0[6]. It can not be access when any bit is asserted.</p>         |
| 5          | RW          | 0x0                | <p>sdmmc_ddr_iso_ctrl<br/>SDMMC access DDR isolation control bit<br/>1'b0: Can be access<br/>1'b1: Can not be access<br/>Notes: The access is controlled by MCU_ISO_DDR_CON0[5] and CPU_ISO_DDR_CON0[5]. It can not be access when any bit is asserted.</p>       |
| 4          | RW          | 0x0                | <p>dmac1_ddr_iso_ctrl<br/>DMAC1 access DDR isolation control bit<br/>1'b0: Can be access<br/>1'b1: Can not be access<br/>Notes: The access is controlled by MCU_ISO_DDR_CON0[4] and CPU_ISO_DDR_CON0[4]. It can not be access when any bit is asserted.</p>       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | dmac0_ddr_iso_ctrl<br>DMAC0 access DDR isolation control bit<br>1'b0: Can be access<br>1'b1: Can not be access<br>Notes: The access is controlled by MCU_ISO_DDR_CON0[3] and CPU_ISO_DDR_CON0[3]. It can not be access when any bit is asserted.     |
| 2          | RW          | 0x0                | crypto_ddr_iso_ctrl<br>CRYPTO access DDR isolation control bit<br>1'b0: Can be access<br>1'b1: Can not be access<br>Notes: The access is controlled by MCU_ISO_DDR_CON0[2] and CPU_ISO_DDR_CON0[2]. It can not be access when any bit is asserted.   |
| 1          | RW          | 0x0                | flexbus_ddr_iso_ctrl<br>FLEXBUS access DDR isolation control bit<br>1'b0: Can be access<br>1'b1: Can not be access<br>Notes: The access is controlled by MCU_ISO_DDR_CON0[1] and CPU_ISO_DDR_CON0[1]. It can not be access when any bit is asserted. |
| 0          | RW          | 0x0                | cpu_ddr_iso_ctrl<br>CPU access DDR isolation control bit<br>1'b0: Can be access<br>1'b1: Can not be access<br>Notes: The access is controlled by MCU_ISO_DDR_CON0[0] and CPU_ISO_DDR_CON0[0]. It can not be access when any bit is asserted.         |

### **GRF PMU MCU ISO DDR CON1**

Address: Operational Base(0xFF910000) + offset (0x1404)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                            |
| 15:1       | RO          | 0x0000             | reserved                                                                                                                                                                                                                                     |
| 0          | RW          | 0x0                | vop_ddr_iso_ctrl<br>VOP access DDR isolation control bit<br>1'b0: Can be access<br>1'b1: Can not be access<br>Notes: The access is controlled by MCU_ISO_DDR_CON1[0] and CPU_ISO_DDR_CON1[0]. It can not be access when any bit is asserted. |

### **GRF PMU MCU ISO LOCK**

Address: Operational Base(0xFF910000) + offset (0x1500)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                      |
| 0          | RW          | 0x0                | mcu_iso_lock<br>Lock for MCU isolation register program.<br>If it is programmed to 1, MCU isolation register locked and cannot be programmed. |

### **GRF PMU CPU ISO CON0**

Address: Operational Base(0xFF910000) + offset (0x2000)

| <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          | 0x0                | dsmc_mem_iso_ctrl<br>DSMC_MEM control bit. There are 1024MB address space for DSMC_MEM, it is separated into four 256MB space.<br>dsmc_mem_iso_ctrl[0], first 256MB<br>dsmc_mem_iso_ctrl[1], second 256MB<br>dsmc_mem_iso_ctrl[2], third 256MB<br>dsmc_mem_iso_ctrl[3], fourth 256MB<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU     |
| 11         | RW          | 0x0                | dsmc_iso_ctrl<br>DSMC isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                                              |
| 10         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                 |
| 9          | RW          | 0x0                | flexbus_iso_ctrl<br>FLEXBUS isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                                        |
| 8:5        | RW          | 0x0                | gpio1_iso_ctrl<br>GPIO1 isolation control bit. There are 16KB address space for GPIO1, it is separated into four 4KB space.<br>gpio1_iso_ctrl[0], first 4KB<br>gpio1_iso_ctrl[1], second 4KB<br>gpio1_iso_ctrl[2], third 4KB<br>gpio1_iso_ctrl[3], fourth 4KB<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                            |
| 4:1        | RW          | 0x0                | grf_core_iso_ctrl<br>GRF_CORE slave isolation control bit. There are 16KB address space for GRF_CORE, it is separated into four 4KB space.<br>grf_core_iso_ctrl[0], first 4KB<br>grf_core_iso_ctrl[1], second 4KB<br>grf_core_iso_ctrl[2], third 4KB<br>grf_core_iso_ctrl[3], fourth 4KB<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU |
| 0          | RW          | 0x0                | a7dbg_iso_ctrl<br>A7 debug isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                                         |

**GRF PMU CPU ISO CON1**

Address: Operational Base(0xFF910000) + offset (0x2004)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12         | RW          | 0x0                | mailbox_iso_ctrl<br>MAILBOX slave isolation control bit, There are 16KB address space for MAILBOX, it is separated into four 4KB space.<br>mailbox_iso_ctrl[0], first 4KB<br>mailbox_iso_ctrl[1], second 4KB<br>mailbox_iso_ctrl[2], third 4KB<br>mailbox_iso_ctrl[3], fourth 4KB<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU |
| 11:8       | RW          | 0x0                | grf_bus_iso_ctrl<br>GRF_BUS slave isolation control bit. There are 16KB address space for GRF_BUS, it is separated into four 4KB space.<br>grf_bus_iso_ctrl[0], first 4KB<br>grf_bus_iso_ctrl[1], second 4KB<br>grf_bus_iso_ctrl[2], third 4KB<br>grf_bus_iso_ctrl[3], fourth 4KB<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU |
| 7          | RW          | 0x0                | ddr_lpc_iso_ctrl<br>DDR LPC slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                           |
| 6          | RW          | 0x0                | ddr_monitor_iso_ctrl<br>DDR monitor slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                   |
| 5          | RW          | 0x0                | ddrc_iso_ctrl<br>DDR controller slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                       |
| 4          | RW          | 0x0                | dmac1_iso_ctrl<br>DMAC1 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                               |
| 3          | RW          | 0x0                | dmac0_iso_ctrl<br>DMAC0 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                               |
| 2          | RW          | 0x0                | sgrf_bus_iso_ctrl<br>SGRF_BUS isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                               |
| 1          | RW          | 0x0                | secure_dmac1_iso_ctrl<br>DMAC1 secure only slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                            |
| 0          | RW          | 0x0                | secure_dmac0_iso_ctrl<br>DMAC0 secure only slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                            |

**GRF PMU CPU ISO CON2**

Address: Operational Base(0xFF910000) + offset (0x2008)

| <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       | RW          | 0x00               | timer1_iso_ctrl<br>TIMER1 slave isolation control bit. There are 32KB address space for TIMER1, it is separated into eight 4KB space.<br>timer1_iso_ctrl[0], first 4KB<br>timer1_iso_ctrl[1], second 4KB<br>timer1_iso_ctrl[2], third 4KB<br>timer1_iso_ctrl[3], fourth 4KB<br>timer1_iso_ctrl[4], fifth 4KB<br>timer1_iso_ctrl[5], sixth 4KB<br>timer1_iso_ctrl[6], seventh 4KB<br>timer1_iso_ctrl[7], eighth 4KB<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU |
| 7:0        | RW          | 0x00               | timer0_iso_ctrl<br>TIMER0 slave isolation control bit. There are 32KB address space for TIMER0, it is separated into eight 4KB space.<br>timer0_iso_ctrl[0], first 4KB<br>timer0_iso_ctrl[1], second 4KB<br>timer0_iso_ctrl[2], third 4KB<br>timer0_iso_ctrl[3], fourth 4KB<br>timer0_iso_ctrl[4], fifth 4KB<br>timer0_iso_ctrl[5], sixth 4KB<br>timer0_iso_ctrl[6], seventh 4KB<br>timer0_iso_ctrl[7], eighth 4KB<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU |

**GRF PMU CPU ISO CON3**

Address: Operational Base(0xFF910000) + offset (0x200C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable         |
| 15         | RO          | 0x0                | reserved                                                                                                                                  |
| 14         | RW          | 0x0                | dma2ddr_iso_ctrl<br>DMA2DDR slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                   |
| 13         | RW          | 0x0                | secure_trng_iso_ctrl<br>Secure RNG slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU            |
| 12         | RW          | 0x0                | secure_keyladder_iso_ctrl<br>Secure keyladder slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU |
| 11         | RW          | 0x0                | secure_crypto_iso_ctrl<br>Secure CRYPTO slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 10         | RW          | 0x0                | bootrom_iso_ctrl<br>BOOTROM slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU             |
| 9          | RW          | 0x0                | ddrphy_iso_ctrl<br>DDRPHY slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU               |
| 8          | RW          | 0x0                | usb2otg1_iso_ctrl<br>USB2.0_OTG1 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU        |
| 7          | RW          | 0x0                | usb2otg0_iso_ctrl<br>USB2.0_OTG0 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU        |
| 6          | RW          | 0x0                | ns_trng_iso_ctrl<br>RNG non-secure slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU      |
| 5          | RW          | 0x0                | ns_crypto_iso_ctrl<br>Crypto non-secure slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU |
| 4          | RW          | 0x0                | usbphy_iso_ctrl<br>USBPHY slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU               |
| 3          | RW          | 0x0                | intmux_iso_ctrl<br>INTMUX slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU               |
| 2          | RO          | 0x0                | reserved                                                                                                                            |
| 1          | RW          | 0x0                | wdt1_iso_ctrl<br>WDT1 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                   |
| 0          | RW          | 0x0                | wdt0_iso_ctrl<br>WDT0 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                   |

#### **GRF PMU CPU ISO CON4**

Address: Operational Base(0xFF910000) + offset (0x2010)

| <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                | uart4_iso_ctrl<br>UART4 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14         | RW          | 0x0                | uart3_iso_ctrl<br>UART3 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                                      |
| 13         | RW          | 0x0                | uart2_iso_ctrl<br>UART2 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                                      |
| 12         | RW          | 0x0                | uart1_iso_ctrl<br>UART1 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                                      |
| 11         | RW          | 0x0                | uart0_iso_ctrl<br>UART0 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                                      |
| 10         | RW          | 0x0                | spi1_iso_ctrl<br>SPI1 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                                        |
| 9          | RW          | 0x0                | spi0_iso_ctrl<br>SPI0 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                                        |
| 8          | RW          | 0x0                | i2c2_iso_ctrl<br>I2C2 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                                        |
| 7          | RW          | 0x0                | i2c1_iso_ctrl<br>I2C1 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                                        |
| 6          | RW          | 0x0                | i2c0_iso_ctrl<br>I2C0 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                                        |
| 5:4        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                 |
| 3:0        | RW          | 0x0                | spinlock_iso_ctrl<br>SPINLOCK slave isolation control bit, There are 16KB address space for SPINLOCK, it is separated into four 4KB space.<br>spinlock_iso_ctrl[0], first 4KB<br>spinlock_iso_ctrl[1], second 4KB<br>spinlock_iso_ctrl[2], third 4KB<br>spinlock_iso_ctrl[3], fourth 4KB<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU |

### **GRF PMU CPU ISO CONS**

Address: Operational Base(0xFF910000) + offset (0x2014)

| <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          | 0x0                | <p>gpio3_iso_ctrl<br/>GPIO3 slave isolation control bit. There are 16KB address space for GPIO3, it is separated into four 4KB space.</p> <p>gpio3_iso_ctrl[0], first 4KB<br/>gpio3_iso_ctrl[1], second 4KB<br/>gpio3_iso_ctrl[2], third 4KB<br/>gpio3_iso_ctrl[3], fourth 4KB</p> <p>1'b0: Can be access by CPU<br/>1'b1: Can not be access by CPU</p>                                                                                                                              |
| 11:8       | RW          | 0x0                | <p>gpio2_iso_ctrl<br/>GPIO2 slave isolation control bit. There are 16KB address space for GPIO2, it is separated into four 4KB space.</p> <p>gpio2_iso_ctrl[0], first 4KB<br/>gpio2_iso_ctrl[1], second 4KB<br/>gpio2_iso_ctrl[2], third 4KB<br/>gpio2_iso_ctrl[3], fourth 4KB</p> <p>1'b0: Can be access by CPU<br/>1'b1: Can not be access by CPU</p>                                                                                                                              |
| 7:0        | RW          | 0x00               | <p>pwm1_iso_ctrl<br/>PWM1 slave isolation control bit. There are 32KB address space for PWM1, it is separated into eight 4KB space.</p> <p>pwm1_iso_ctrl[0], first 4KB<br/>pwm1_iso_ctrl[1], second 4KB<br/>pwm1_iso_ctrl[2], third 4KB<br/>pwm1_iso_ctrl[3], fourth 4KB<br/>pwm1_iso_ctrl[4], fifth 4KB<br/>pwm1_iso_ctrl[5], sixth 4KB<br/>pwm1_iso_ctrl[6], seventh 4KB<br/>pwm1_iso_ctrl[7], eighth 4KB</p> <p>1'b0: Can be access by CPU<br/>1'b1: Can not be access by CPU</p> |

**GRF PMU CPU ISO CON6**

Address: Operational Base(0xFF910000) + offset (0x2018)

| <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.</p> <p>1'b0: Write access disable<br/>1'b1: Write access enable</p> |
| 15         | RW          | 0x0                | <p>gpio1_ioc_iso_ctrl<br/>GPIO1_IOC slave isolation control bit</p> <p>1'b0: Can be access by CPU<br/>1'b1: Can not be access by CPU</p>       |
| 14         | RW          | 0x0                | <p>dphy_iso_ctrl<br/>DPHY slave isolation control bit</p> <p>1'b0: Can be access by CPU<br/>1'b1: Can not be access by CPU</p>                 |
| 13         | RW          | 0x0                | <p>dsi_iso_ctrl<br/>DSI slave isolation control bit</p> <p>1'b0: Can be access by CPU<br/>1'b1: Can not be access by CPU</p>                   |
| 12         | RW          | 0x0                | <p>spdif_rx_iso_ctrl<br/>SPDIF_RX slave isolation control bit</p> <p>1'b0: Can be access by CPU<br/>1'b1: Can not be access by CPU</p>         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11         | RW          | 0x0                | spdif_tx_iso_ctrl<br>SPDIF_TX slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                           |
| 10         | RW          | 0x0                | pdm_iso_ctrl<br>PDM slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                     |
| 9          | RW          | 0x0                | can1_iso_ctrl<br>CAN1 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                   |
| 8          | RW          | 0x0                | can0_iso_ctrl<br>CAN0 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                   |
| 7          | RW          | 0x0                | sai1_iso_ctrl<br>SAI1 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                   |
| 6          | RW          | 0x0                | sai0_iso_ctrl<br>SAI0 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                   |
| 5          | RW          | 0x0                | asrc1_iso_ctrl<br>ASRC1 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                 |
| 4          | RW          | 0x0                | asrc0_iso_ctrl<br>ASRC0 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                 |
| 3:0        | RW          | 0x0                | gpio4_iso_ctrl<br>GPIO4 slave isolation control bit. There are 16KB address space for GPIO4, it is separated into four 4KB space.<br>gpio4_iso_ctrl[0], first 4KB<br>gpio4_iso_ctrl[1], second 4KB<br>gpio4_iso_ctrl[2], third 4KB<br>gpio4_iso_ctrl[3], fourth 4KB<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU |

### **GRF PMU CPU ISO CON7**

Address: Operational Base(0xFF910000) + offset (0x201C)

| <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                | fspi_iso_ctrl<br>FSPI slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 14         | RW          | 0x0                | sdmmc_iso_ctrl<br>SDMMC slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                               |
| 13         | RW          | 0x0                | audio_adc_iso_ctrl<br>Audio ADC slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                       |
| 12         | RW          | 0x0                | gpio234_ioc_iso_ctrl<br>GPIO2_IOC/GPIO3_IOC/GPIO4_IOC slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU |
| 11         | RW          | 0x0                | saradc_iso_ctrl<br>SARADC slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                             |
| 10         | RW          | 0x0                | otpc_ns_iso_ctrl<br>Non-secure OTPC slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                   |
| 9          | RW          | 0x0                | uart5_iso_ctrl<br>UART5 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                               |
| 8          | RW          | 0x0                | spi2_iso_ctrl<br>SPI2 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                 |
| 7          | RW          | 0x0                | mac1_iso_ctrl<br>MAC1 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                 |
| 6          | RW          | 0x0                | mac0_iso_ctrl<br>MAC0 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                 |
| 5          | RW          | 0x0                | secure_keyreader_iso_ctrl<br>Secure KEYREADER slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU         |
| 4          | RW          | 0x0                | secure_otpc_mask_iso_ctrl<br>Secure OTPC mask slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU         |
| 3          | RW          | 0x0                | secure_otpc_iso_ctrl<br>Secure OTPC slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                   |
| 2          | RW          | 0x0                | vop_iso_ctrl<br>VOP slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                   |
| 1          | RW          | 0x0                | rga_iso_ctrl<br>RGA slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | tsadc_iso_ctrl<br>TSADC controller slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU |

**GRF PMU CPU ISO CON8**

Address: Operational Base(0xFF910000) + offset (0x2020)

| <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          | 0x0                | gpio0_iso_ctrl<br>GPIO0 slave isolation control bit. There are 16KB address space for GPIO0, it is separated into four 4KB space.<br>gpio0_iso_ctrl[0], first 4KB<br>gpio0_iso_ctrl[1], second 4KB<br>gpio0_iso_ctrl[2], third 4KB<br>gpio0_iso_ctrl[3], fourth 4KB<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU               |
| 11         | RW          | 0x0                | sgrf_pmu_iso_ctrl<br>sgrf_pmu slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                         |
| 10:7       | RW          | 0x4                | grf_pmu_iso_ctrl<br>GRF_PMU slave isolation control bit. There are 16KB address space for GRF_PMU, it is separated into four 4KB space.<br>grf_pmu_iso_ctrl[0], first 4KB<br>grf_pmu_iso_ctrl[1], second 4KB<br>grf_pmu_iso_ctrl[2], third 4KB<br>grf_pmu_iso_ctrl[3], fourth 4KB<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU |
| 6          | RW          | 0x0                | secure_cru_pmu_iso_ctrl<br>Secure CRU_PMU slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                             |
| 5          | RW          | 0x0                | cru_pmu_iso_ctrl<br>CRU_PMU slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                           |
| 4          | RW          | 0x0                | pmu_iso_ctrl<br>PMU slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                                   |
| 3          | RW          | 0x0                | audio_dsm_iso_ctrl<br>Audio DSM slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                       |
| 2          | RW          | 0x0                | sai4_iso_ctrl<br>SAI4 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | sai3_iso_ctrl<br>SAI3 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU |
| 0          | RW          | 0x0                | sai2_iso_ctrl<br>SAI2 slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU |

**GRF PMU CPU ISO CON9**

Address: Operational Base(0xFF910000) + offset (0x2024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                                                                                                    |
| 15:13      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                             |
| 12         | RW          | 0x0                | secure_cru_iso_ctrl<br>Secure CRU slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                                                        |
| 11         | RW          | 0x0                | cru_iso_ctrl<br>CRU slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                                                                      |
| 10         | RW          | 0x0                | gpio0_ioc_iso_ctrl<br>GPIO0_IOC slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                                                          |
| 9          | RW          | 0x0                | touchkey_iso_ctrl<br>Touch key slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                                                           |
| 8:5        | RW          | 0x0                | pwm0_iso_ctrl<br>PWM0 slave isolation control bit. There are 16KB address space for PWM0, it is separated into four 4KB space.<br>pwm0_iso_ctrl[0], first 4KB<br>pwm0_iso_ctrl[1], second 4KB<br>pwm0_iso_ctrl[2], third 4KB<br>pwm0_iso_ctrl[3], fourth 4KB<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                         |
| 4          | RW          | 0x0                | hptimer_iso_ctrl<br>HPTIMER slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU                                                                                                                                                                                                                                                              |
| 3:0        | RW          | 0x0                | gpio1_shadow_iso_ctrl<br>GPIO1_SHADOW slave isolation control bit. There are 16KB address space for GPIO1_SHADOW, it is separated into four 4KB space.<br>gpio1_shadow_iso_ctrl[0], first 4KB<br>gpio1_shadow_iso_ctrl[1], second 4KB<br>gpio1_shadow_iso_ctrl[2], third 4KB<br>gpio1_shadow_iso_ctrl[3], fourth 4KB<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU |

**GRF PMU CPU ISO CON10**

Address: Operational Base(0xFF910000) + offset (0x2028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable        |
| 15:7       | RO          | 0x000              | reserved                                                                                                                                 |
| 6          | RW          | 0x0                | nocsrv_firewall_iso_ctrl<br>firewall slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU         |
| 5          | RW          | 0x0                | nocsrv_ddr_iso_ctrl<br>noc service ddr slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU       |
| 4          | RW          | 0x0                | nocsrv_vio_iso_ctrl<br>noc service vio slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU       |
| 3          | RW          | 0x0                | nocsrv_hsperi_iso_ctrl<br>noc service hsperi slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU |
| 2          | RW          | 0x0                | nocsrv_bus_iso_ctrl<br>noc service bus slave isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU       |
| 1          | RW          | 0x0                | nocsrv_cpup_iso_ctrl<br>noc service cpu peripheral isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU |
| 0          | RW          | 0x0                | nocsrv_cpu_iso_ctrl<br>noc service cpu isolation control bit<br>1'b0: Can be access by CPU<br>1'b1: Can not be access by CPU             |

**GRF PMU CPU ISO CON11**

Address: Operational Base(0xFF910000) + offset (0x202C)

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

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:0 | RW   | 0x000       | <p>sysram_iso_ctrl<br/>           System sram isolation control bit, There are 48KB address space for System sram, it is separated into eight 4KB space.</p> <ul style="list-style-type: none"> <li>sysram_iso_ctrl[0], first 4KB</li> <li>sysram_iso_ctrl[1], second 4KB</li> <li>sysram_iso_ctrl[2], third 4KB</li> <li>sysram_iso_ctrl[3], fourth 4KB</li> <li>sysram_iso_ctrl[4], fifth 4KB</li> <li>sysram_iso_ctrl[5], sixth 4KB</li> <li>sysram_iso_ctrl[6], seventh 4KB</li> <li>sysram_iso_ctrl[7], eighth 4KB</li> <li>sysram_iso_ctrl[8], ninth 4KB</li> <li>sysram_iso_ctrl[9], tenth 4KB</li> <li>sysram_iso_ctrl[10], eleventh 4KB</li> <li>sysram_iso_ctrl[11], twelfth 4KB</li> </ul> <p>1'b0: Can be access by CPU<br/>           1'b1: Can not be access by CPU</p> |

**GRF PMU CPU ISO DDR CON0**

Address: Operational Base(0xFF910000) + offset (0x2400)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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>usb2otg1_ddr_iso_ctrl<br/>           USB2.0_OTG1 access DDR isolation control bit<br/>           1'b0: Can be access<br/>           1'b1: Can not be access<br/>           Notes: The access is controlled by MCU_ISO_DDR_CON0[15] and CPU_ISO_DDR_CON0[15]. It can not be access when any bit is asserted.</p> |
| 14    | RW   | 0x0         | <p>usb2otg0_ddr_iso_ctrl<br/>           USB2.0_OTG0 access DDR isolation control bit<br/>           1'b0: Can be access<br/>           1'b1: Can not be access<br/>           Notes: The access is controlled by MCU_ISO_DDR_CON0[14] and CPU_ISO_DDR_CON0[14]. It can not be access when any bit is asserted.</p> |
| 13    | RW   | 0x0         | <p>spi2_ddr_iso_ctrl<br/>           SPI2 access DDR isolation control bit<br/>           1'b0: Can be access<br/>           1'b1: Can not be access<br/>           Notes: The access is controlled by MCU_ISO_DDR_CON0[13] and CPU_ISO_DDR_CON0[13]. It can not be access when any bit is asserted.</p>            |
| 12    | RW   | 0x0         | <p>rga_wr_ddr_iso_ctrl<br/>           RGA write access DDR isolation control bit<br/>           1'b0: Can be access<br/>           1'b1: Can not be access<br/>           Notes: The access is controlled by MCU_ISO_DDR_CON0[12] and CPU_ISO_DDR_CON0[12]. It can not be access when any bit is asserted.</p>     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11         | RW          | 0x0                | <p>rga_rd_ddr_iso_ctrl<br/>RGA read access DDR isolation control bit<br/>1'b0: Can be access<br/>1'b1: Can not be access<br/>Notes: The access is controlled by MCU_ISO_DDR_CON0[11] and CPU_ISO_DDR_CON0[11]. It can not be access when any bit is asserted.</p> |
| 10         | RW          | 0x0                | <p>dma2ddr_ddr_iso_ctrl<br/>DMA2DDR access DDR isolation control bit<br/>1'b0: Can be access<br/>1'b1: Can not be access<br/>Notes: The access is controlled by MCU_ISO_DDR_CON0[10] and CPU_ISO_DDR_CON0[10]. It can not be access when any bit is asserted.</p> |
| 9          | RW          | 0x0                | <p>mcu_ddr_iso_ctrl<br/>MCU access DDR isolation control bit<br/>1'b0: Can be access<br/>1'b1: Can not be access<br/>Notes: The access is controlled by MCU_ISO_DDR_CON0[9] and CPU_ISO_DDR_CON0[9]. It can not be access when any bit is asserted.</p>           |
| 8          | RW          | 0x0                | <p>mac1_ddr_iso_ctrl<br/>MAC1 access DDR isolation control bit<br/>1'b0: Can be access<br/>1'b1: Can not be access<br/>Notes: The access is controlled by MCU_ISO_DDR_CON0[8] and CPU_ISO_DDR_CON0[8]. It can not be access when any bit is asserted.</p>         |
| 7          | RW          | 0x0                | <p>mac0_ddr_iso_ctrl<br/>MAC0 access DDR isolation control bit<br/>1'b0: Can be access<br/>1'b1: Can not be access<br/>Notes: The access is controlled by MCU_ISO_DDR_CON0[7] and CPU_ISO_DDR_CON0[7]. It can not be access when any bit is asserted.</p>         |
| 6          | RW          | 0x0                | <p>fpsi_ddr_iso_ctrl<br/>FSPI access DDR isolation control bit<br/>1'b0: Can be access<br/>1'b1: Can not be access<br/>Notes: The access is controlled by MCU_ISO_DDR_CON0[6] and CPU_ISO_DDR_CON0[6]. It can not be access when any bit is asserted.</p>         |
| 5          | RW          | 0x0                | <p>sdmmc_ddr_iso_ctrl<br/>SDMMC access DDR isolation control bit<br/>1'b0: Can be access<br/>1'b1: Can not be access<br/>Notes: The access is controlled by MCU_ISO_DDR_CON0[5] and CPU_ISO_DDR_CON0[5]. It can not be access when any bit is asserted.</p>       |
| 4          | RW          | 0x0                | <p>dmac1_ddr_iso_ctrl<br/>DMAC1 access DDR isolation control bit<br/>1'b0: Can be access<br/>1'b1: Can not be access<br/>Notes: The access is controlled by MCU_ISO_DDR_CON0[4] and CPU_ISO_DDR_CON0[4]. It can not be access when any bit is asserted.</p>       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | dmac0_ddr_iso_ctrl<br>DMAC0 access DDR isolation control bit<br>1'b0: Can be access<br>1'b1: Can not be access<br>Notes: The access is controlled by MCU_ISO_DDR_CON0[3] and CPU_ISO_DDR_CON0[3]. It can not be access when any bit is asserted.     |
| 2          | RW          | 0x0                | crypto_ddr_iso_ctrl<br>CRYPTO access DDR isolation control bit<br>1'b0: Can be access<br>1'b1: Can not be access<br>Notes: The access is controlled by MCU_ISO_DDR_CON0[2] and CPU_ISO_DDR_CON0[2]. It can not be access when any bit is asserted.   |
| 1          | RW          | 0x0                | flexbus_ddr_iso_ctrl<br>FLEXBUS access DDR isolation control bit<br>1'b0: Can be access<br>1'b1: Can not be access<br>Notes: The access is controlled by MCU_ISO_DDR_CON0[1] and CPU_ISO_DDR_CON0[1]. It can not be access when any bit is asserted. |
| 0          | RW          | 0x0                | cpu_ddr_iso_ctrl<br>CPU access DDR isolation control bit<br>1'b0: Can be access<br>1'b1: Can not be access<br>Notes: The access is controlled by MCU_ISO_DDR_CON0[0] and CPU_ISO_DDR_CON0[0]. It can not be access when any bit is asserted.         |

#### **GRF PMU CPU ISO DDR CON1**

Address: Operational Base(0xFF910000) + offset (0x2404)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                            |
| 15:1       | RO          | 0x0000             | reserved                                                                                                                                                                                                                                     |
| 0          | RW          | 0x0                | vop_ddr_iso_ctrl<br>VOP access DDR isolation control bit<br>1'b0: Can be access<br>1'b1: Can not be access<br>Notes: The access is controlled by MCU_ISO_DDR_CON1[0] and CPU_ISO_DDR_CON1[0]. It can not be access when any bit is asserted. |

#### **GRF PMU CPU ISO LOCK**

Address: Operational Base(0xFF910000) + offset (0x2500)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                      |
| 0          | RW          | 0x0                | cpu_iso_lock<br>Lock for CPU isolation register program.<br>If it is programmed to 1, CPU isolation register locked and cannot be programmed. |

## Chapter 6 Power Management Unit (PMU)

### 6.1 Overview

In order to meet low power requirements, a power management unit (PMU) is designed for controlling power resources in SOC. RK3506 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, VD\_PLL
- Support multi virtual power domains in VD\_CORE: PD\_CPU0, PD\_CPU1, PD\_CPU2
- Support power down/up all power domains by software or hardware
- Support power down/up all voltage domains by software or hardware
- Support CPU auto power down with two mode
- Support to clamp all VD\_CORE output before power off VD\_CORE in low power mode
- Support VD\_CORE power down, send scu\_pwroff output to IO
- Support to clamp all VD\_PMU input before power off VD\_LOGIC in low power mode
- Support VD\_LOGIC power down, send pmu\_sleep output to IO
- Support PMU controlled by CPU or MCU for low power management
- Support respective global interrupt disable for CPU and MCU in low power mode
- Support BIU idle operations: BIU\_CPU, BIU\_CPU\_P, BIU\_BUS, BIU\_DDR, BIU\_VIO, BIU\_HSPERI, BIU\_LSPERI
- Support to send idle request to BIU for each bus domain by software or hardware
- Support clock gate mask for each bus domain by software or hardware
- Support DDR low power management
- Support PLLs power down/up by hardware in low power mode
- Support PMU clock switch to low frequency clock in low power mode
- Support OSC enable/disable request in low power mode
- Support PMU sleep hold with configurable counter
- Support PWM auto switch to GPIO during power mode
- Support wakeup reset control for full chip in power off mode
- Support PMU debug info output to IO with UART interface mode
- Support varies configurable wakeup source for low power mode
- Support combined interrupt output for alarm and second catch interrupt

### 6.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. 6-1 PMU Bock Diagram

### 6.3 Function Description

#### 6.3.1 Domain Partition



Fig. 6-2 RK3506 Voltage Domain and Power Domain Partition

The above diagram describes the power domain and voltage domain partition.

Table 6-1 RK3506 Voltage Domain and Power Domain Summary

| Voltage Domain | Power Domain    | Description                                                                                                                                                                                                                                                                |
|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VD_CORE        | PD_CPU0/1/2     | CPU0/1/2<br>L1 I/D Cache<br>L2 Cache<br>SCU<br>GIC400<br>CPU Debug<br>CPU_EMA_DETECT<br>PVTPLL_CORE<br>GRF_CORE<br>SGRF_CORE<br>GPIO1<br>Master DSMC<br>Slave DSMC<br>FLEXBUS                                                                                              |
| VD_LOGIC       | BUS_WRAPPER     | CRU<br>PAD_RING/PMUX<br>MCU<br>INTMUX<br>Mailbox<br>ROM<br>AXI/AHB Slave SRAM<br>GRF<br>SGRF<br>DMAC0/1<br>DMA2DDR<br>DDRPHY<br>DDRMON<br>DDR_LPC<br>DDRCTL<br>S/NS Crypto<br>S/NS RNG<br>S KEYLAD<br>SPINLOCK<br>USB2.0_OTG0/1<br>USBPHY<br>WDT0/1<br>TIMER0/1<br>BUS_IOC |
|                | HS_PERI_WRAPPER | SDMMC<br>FSPI<br>S/NS OTPC<br>OTP AP<br>OTP Mask<br>MAC0/1<br>UART5                                                                                                                                                                                                        |

| Voltage Domain | Power Domain            | Description                                                                                                                                                           |
|----------------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                |                         | SPI2<br>SAI2/3/4<br>Audio DSM<br>Audio ADC<br>SARADC<br>HSPERI_IOC                                                                                                    |
|                | LS_PERI_WRAPPER         | SAI0/1<br>PDM<br>SPDIF_TX<br>SPDIF_RX<br>ASRC0/1<br>CAN0/1<br>SPI0/1<br>GPIO2/3/4<br>Touch Key<br>I2C0/1/2<br>UART0/1/2/3/4<br>PWM1/2                                 |
|                | VIO_WRAPPER             | RGA<br>DSI Host<br>VOP<br>DPHY<br>TSADC                                                                                                                               |
| VD_PMU         |                         | system SRAM<br>CRU_PMU<br>GRF_PMU<br>SGRF_PMU<br>PMU<br>HPTIMER<br>PWM0<br>Touch Key<br>OSC<br>nPOR<br>GPIO0<br>GPIO1_SHADOW<br>PMU_IOC<br>RM_IO<br>PMU PAD RING/PMUX |
|                | CLK_WRAPPER<br>(VD_PLL) | OSC<br>WiFi REFCLK<br>GPLL<br>VPLL0/1                                                                                                                                 |

### 6.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 RK3506 chip.

## 6.4 Register Description

### 6.4.1 Registers Summary

| Name                   | Offset | Size | Reset Value | Description                                       |
|------------------------|--------|------|-------------|---------------------------------------------------|
| PMU_VERSION            | 0x0000 | W    | 0x01010002  | PMU version register                              |
| PMU_PWR_CON            | 0x0004 | W    | 0x00000000  | PMU power control register                        |
| PMU_GLB_POWER_STS      | 0x0008 | W    | 0x00000000  | PMU power status register                         |
| PMU_INT_MASK_CON       | 0x000C | W    | 0x00000000  | Interrupt mask control register                   |
| PMU_WAKEUP_INT_CON     | 0x0010 | W    | 0x00000000  | Wakeup interrupt control register                 |
| PMU_WAKEUP_INT_ST      | 0x0014 | W    | 0x00000000  | Wakeup interrupt status register                  |
| PMU_DDR_PWR_CON        | 0x0020 | W    | 0x00000000  | DDR power hardware control register               |
| PMU_DDR_PWR_SFTCON     | 0x0030 | W    | 0x00000000  | DDR power software control register               |
| PMU_DDR_POWER_STS      | 0x0040 | W    | 0x00000000  | DDR power state register                          |
| PMU_DDR_STS            | 0x0044 | W    | 0x00000000  | DDR status register                               |
| PMU_CRU_PWR_CON0       | 0x0050 | W    | 0x00000000  | Clock and reset hardware power control register 0 |
| PMU_CRU_PWR_CON1       | 0x0054 | W    | 0x00000000  | Clock and reset hardware power control register 1 |
| PMU_CRU_PWR_SFTCON0    | 0x0058 | W    | 0x00000000  | Clock and reset software power control register 0 |
| PMU_CRU_PWR_SFTCON1    | 0x005C | W    | 0x00000007  | Clock and reset software power control register 1 |
| PMU_CRU_POWER_STS      | 0x0060 | W    | 0x00000000  | Clock and reset power state register              |
| PMU_PLLPD_CON          | 0x0070 | W    | 0x00000000  | PLL power hardware control register               |
| PMU_PLLPD_SFTCON       | 0x0078 | W    | 0x00000000  | PLL power software control register               |
| PMU_INFO_TX_CON        | 0x0080 | W    | 0x00000000  | PMU information transmit control register         |
| PMU_PMIC_STABLE_CNT    | 0x0090 | W    | 0x000FFFFF  | PMIC stable counter register                      |
| PMU_OSC_STABLE_CNT     | 0x0094 | W    | 0x000FFFFF  | OSC stable counter register                       |
| PMU_WAKEUP_RSTCLR_CNT  | 0x0098 | W    | 0x000FFFFF  | Wakeup reset clear counter register               |
| PMU_PLL_LOCK_CNT       | 0x009C | W    | 0x000FFFFF  | PLL lock counter register                         |
| PMU_WAKEUP_TIMEOUT_CNT | 0x00A0 | W    | 0x00005DC0  | WAKEUP timeout counter register                   |
| PMU_PWM_SWITCH_CNT     | 0x00A4 | W    | 0x000FFFFF  | PWM switch stable counter register                |
| PMU_SLEEP_HOLD_CNT     | 0x00A8 | W    | 0x000FFFFF  | PMU sleep hold counter register                   |

| Name                     | Offset | Size | Reset Value | Description                                   |
|--------------------------|--------|------|-------------|-----------------------------------------------|
| PMU_MISC_CON             | 0x00B0 | W    | 0x00000000  | PMU miscellaneous control register            |
| PMU_MISC_INT_ST          | 0x00B4 | W    | 0x00000000  | PMU miscellaneous interrupt status register   |
| PMU_ALARM_CNT            | 0x00B8 | W    | 0x1FFFFFFF  | Alarm counter register                        |
| PMU_RTC_ST               | 0x00BC | W    | 0x00000000  | Real time clock status register               |
| PMU_CLKDIV_CON           | 0x00C0 | W    | 0x00007FFF  | Clock divider control register                |
| PMU_SCU_PWR_CON          | 0x1000 | W    | 0x00000000  | SCU power hardware control register           |
| PMU_SCU_PWR_SFTCON       | 0x1004 | W    | 0x00000000  | SCU power software control register           |
| PMU_SCU_AUTO_CON         | 0x1008 | W    | 0x00000000  | SCU power auto control register               |
| PMU_SCU_POWER_STS        | 0x100C | W    | 0x00000000  | SCU power state register                      |
| PMU_CLUSTER_PWR_ST       | 0x101C | W    | 0x00000000  | Cluster power state register                  |
| PMU_CLUSTER_IDLE_CON     | 0x1020 | W    | 0x00000000  | Cluster idle control register                 |
| PMU_CLUSTER_IDLE_SFT_CON | 0x1024 | W    | 0x00000000  | Cluster idle software control register        |
| PMU_CORE_PWRUP_CNT       | 0x1030 | W    | 0x00005DC0  | Core power up counter register                |
| PMU_CORE_PWRDN_CNT       | 0x1034 | W    | 0x00005DC0  | Core power down counter register              |
| PMU_CORE_STABLE_CNT      | 0x1038 | W    | 0x000FFFFF  | Core power stable counter register            |
| PMU_CPU0_AUTO_PWR_CON    | 0x1040 | W    | 0x00000000  | CPU0 power control register                   |
| PMU_CPU1_AUTO_PWR_CON    | 0x1044 | W    | 0x00000000  | CPU1 power control register                   |
| PMU_CPU2_AUTO_PWR_CON    | 0x1048 | W    | 0x00000000  | CPU2 power control register                   |
| PMU_CPU0_PWR_SFTCON      | 0x1050 | W    | 0x00000000  | CPU0 power software control register          |
| PMU_CPU1_PWR_SFTCON      | 0x1054 | W    | 0x00000000  | CPU1 power software control register          |
| PMU_CPU2_PWR_SFTCON      | 0x1058 | W    | 0x00000000  | CPU2 power software control register          |
| PMU_BIU_IDLE_CON         | 0x1100 | W    | 0x00000000  | BIU idle request hardware control register    |
| PMU_BIU_IDLE_SFTCON      | 0x1110 | W    | 0x00000000  | BIU idle request software control register    |
| PMU_BIU_IDLE_ACK         | 0x1120 | W    | 0x00000000  | BIU idle acknowledge status register          |
| PMU_BIU_IDLE_ST          | 0x1128 | W    | 0x00000000  | BIU idle status register                      |
| PMU_BIU_GATMASK_CON      | 0x1130 | W    | 0x00000000  | BIU clock gate mask hardware control register |
| PMU_BIU_GATMASK_SFTCON   | 0x1140 | W    | 0x00000000  | BIU clock gate mask software control register |

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

## 6.4.2 Detail Registers Description

### PMU VERSION

Address: Operational Base(0xFF900000) + offset (0x0000)

| Bit  | Attr | Reset Value | Description                    |
|------|------|-------------|--------------------------------|
| 31:0 | RO   | 0x01010002  | version<br>PMU version number. |

### PMU PWR CON

Address: Operational Base(0xFF900000) + offset (0x0004)

| Bit   | Attr   | Reset Value | Description                                                                                                                                                        |
|-------|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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    | R/W SC | 0x0         | sft_wakeup_en<br>Low power mode software wakeup enable. When controller enters low power flow, this bit is automatically cleared.<br>1'b0: Disable<br>1'b1: Enable |
| 14:8  | RO     | 0x00        | reserved                                                                                                                                                           |
| 7     | RW     | 0x0         | cru_bypass<br>Bypass clock and reset low power flow in low power procedure.<br>1'b0: Disable<br>1'b1: Enable                                                       |
| 6     | RW     | 0x0         | pwrctrl_bypass<br>Bypass power gate 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 BIU idle in low power procedure.<br>1'b0: Disable<br>1'b1: Enable                                                                             |
| 3     | RW     | 0x0         | mcu_bypass<br>Bypass MCU in low power procedure.<br>1'b0: Disable<br>1'b1: Enable                                                                                  |
| 2     | RW     | 0x0         | scu_act_bypass<br>Bypass SCU active in low power procedure.<br>1'b0: Disable<br>1'b1: Enable                                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 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 GLB POWER STS**

Address: Operational Base(0xFF900000) + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 3:0        | RO          | 0x0                | power_state<br>PMU global power state.<br>4'h0: Normal state<br>4'h2: SCU low power state<br>4'h3: MCU low power state<br>4'h4: BIU low power state<br>4'h5: DDR low power state<br>4'h6: Power gate low power state<br>4'h7: Clock and reset low power state<br>4'h8: Sleep state<br>4'h9: Clock and reset active state<br>4'ha: Power gate active state<br>4'hb: DDR active state<br>4'hc: BIU active state<br>4'hd: MCU active state<br>4'he: SCU active state<br>Others: Reserved |

**PMU INT MASK CON**

Address: Operational Base(0xFF900000) + 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:3       | RO          | 0x0000             | reserved                                                                                                                           |
| 2          | RW          | 0x0                | mcu_RST_DIS_CFG<br>MCU reset disable by software.<br>1'b0: Disable, MCU reset assert<br>1'b1: Enable, MCU reset release            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | glb_int_mask_mcu<br>MCU global interrupt mask during low power procedure.<br>1'b0: Disable<br>1'b1: Enable |
| 0          | RW          | 0x0                | glb_int_mask<br>Global interrupt mask during low power procedure.<br>1'b0: Disable<br>1'b1: Enable         |

**PMU WAKEUP INT CON**

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                           |
| 29         | RW          | 0x0                | wakeup_timeout_en<br>Enable PMU timeout interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable               |
| 28         | RW          | 0x0                | wakeup_second_catch_int_en<br>Enable PMU second catch interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable |
| 27         | RW          | 0x0                | wakeup_alarm_int_en<br>Enable PMU alarm interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable               |
| 26         | RW          | 0x0                | wakeup_saradc_int_en<br>Enable SARADC interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable                 |
| 25         | RW          | 0x0                | wakeup_touch_key_int_en<br>Enable Touch Key interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable           |
| 24         | RW          | 0x0                | wakeup_can1_int_en<br>Enable CAN1 interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable                     |
| 23         | RW          | 0x0                | wakeup_can0_int_en<br>Enable CAN0 interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable                     |
| 22         | RW          | 0x0                | wakeup_timer1_int_en<br>Enable TIMER1 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>                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------|
| 21         | RW          | 0x0                | wakeup_timer0_int_en<br>Enable TIMER0 interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable        |
| 20         | RW          | 0x0                | wakeup_mac1_int_en<br>Enable MAC1 interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable            |
| 19         | RW          | 0x0                | wakeup_mac0_int_en<br>Enable MAC0 interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable            |
| 18         | RW          | 0x0                | wakeup_usb1_det_int_en<br>Enable USB1 detect interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable |
| 17         | RW          | 0x0                | wakeup_usb0_det_int_en<br>Enable USB0 detect interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable |
| 16         | RW          | 0x0                | wakeup_uart5_int_en<br>Enable UART5 interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable          |
| 15         | RW          | 0x0                | wakeup_uart4_int_en<br>Enable UART4 interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable          |
| 14         | RW          | 0x0                | wakeup_uart3_int_en<br>Enable UART3 interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable          |
| 13         | RW          | 0x0                | wakeup_uart2_int_en<br>Enable UART2 interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable          |
| 12         | RW          | 0x0                | wakeup_uart1_int_en<br>Enable UART1 interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable          |
| 11         | RW          | 0x0                | wakeup_uart0_int_en<br>Enable UART0 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>                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------|
| 10         | RW          | 0x0                | wakeup_pwm2_int_en<br>Enable PWM2 interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable                 |
| 9          | RW          | 0x0                | wakeup_pwm1_int_en<br>Enable PWM1 interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable                 |
| 8          | RW          | 0x0                | wakeup_pwm0_int_en<br>Enable PWM0 interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable                 |
| 7          | RW          | 0x0                | wakeup_gpio4_int_en<br>Enable GPIO4 interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable               |
| 6          | RW          | 0x0                | wakeup_gpio3_int_en<br>Enable GPIO3 interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable               |
| 5          | RW          | 0x0                | wakeup_gpio2_int_en<br>Enable GPIO2 interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable               |
| 4          | RW          | 0x0                | wakeup_gpio1_shadow_int_en<br>Enable GPIO1 shadow interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable |
| 3          | RW          | 0x0                | wakeup_gpio0_int_en<br>Enable GPIO0 interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable               |
| 2          | RW          | 0x0                | wakeup_hptimer_int_en<br>Enable HPTIMER interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable           |
| 1          | RW          | 0x0                | wakeup_mcu_int_en<br>Enable MCU interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable                   |
| 0          | RW          | 0x0                | wakeup_cpu_int_en<br>Enable CPU interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable                   |

**PMU WAKEUP INT ST**

Address: Operational Base(0xFF900000) + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                                                                            |
| 30         | RO          | 0x0                | sft_wakeup_st<br>PMU software wakeup as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active                     |
| 29         | RO          | 0x0                | wakeup_timeout_st<br>PMU timeout interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active               |
| 28         | RO          | 0x0                | wakeup_second_catch_int_st<br>PMU second catch interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active |
| 27         | RO          | 0x0                | wakeup_alarm_int_st<br>PMU alarm interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active               |
| 26         | RO          | 0x0                | wakeup_saradc_int_st<br>SARADC interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active                 |
| 25         | RO          | 0x0                | wakeup_touch_key_int_st<br>Touch Key interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active           |
| 24         | RO          | 0x0                | wakeup_can1_int_st<br>CAN1 interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active                     |
| 23         | RO          | 0x0                | wakeup_can0_int_st<br>CAN0 interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active                     |
| 22         | RO          | 0x0                | wakeup_timer1_int_st<br>TIMER1 interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active                 |
| 21         | RO          | 0x0                | wakeup_timer0_int_st<br>TIMER0 interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------|
| 20         | RO          | 0x0                | wakeup_mac1_int_st<br>MAC1 interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active            |
| 19         | RO          | 0x0                | wakeup_mac0_int_st<br>MAC0 interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active            |
| 18         | RO          | 0x0                | wakeup_usb1_det_int_st<br>USB1 detect interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active |
| 17         | RO          | 0x0                | wakeup_usb0_det_int_st<br>USB0 detect interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active |
| 16         | RO          | 0x0                | wakeup_uart5_int_st<br>UART5 interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active          |
| 15         | RO          | 0x0                | wakeup_uart4_int_st<br>UART4 interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active          |
| 14         | RO          | 0x0                | wakeup_uart3_int_st<br>UART3 interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active          |
| 13         | RO          | 0x0                | wakeup_uart2_int_st<br>UART2 interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active          |
| 12         | RO          | 0x0                | wakeup_uart1_int_st<br>UART1 interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active          |
| 11         | RO          | 0x0                | wakeup_uart0_int_st<br>UART0 interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active          |
| 10         | RO          | 0x0                | wakeup_pwm2_int_st<br>PWM2 interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------|
| 9          | RO          | 0x0                | wakeup_pwm1_int_st<br>PWM1 interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active                 |
| 8          | RO          | 0x0                | wakeup_pwm0_int_st<br>PWM0 interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active                 |
| 7          | RO          | 0x0                | wakeup_gpio4_int_st<br>GPIO4 interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active               |
| 6          | RO          | 0x0                | wakeup_gpio3_int_st<br>GPIO3 interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active               |
| 5          | RO          | 0x0                | wakeup_gpio2_int_st<br>GPIO2 interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active               |
| 4          | RO          | 0x0                | wakeup_gpio1_shadow_int_st<br>GPIO1 shadow interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active |
| 3          | RO          | 0x0                | wakeup_gpio0_int_st<br>GPIO0 interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active               |
| 2          | RO          | 0x0                | wakeup_hptimer_int_st<br>HPTIMER interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active           |
| 1          | RO          | 0x0                | wakeup_mcu_int_st<br>MCU interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active                   |
| 0          | RO          | 0x0                | wakeup_cpu_int_st<br>CPU interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active                   |

**PMU DDR PWR CON**

Address: Operational Base(0xFF900000) + 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 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                | ddrio_hz_exit_ena<br>Enable DDR IO High-Z de-asserted performed by hardware.<br>1'b0: Disable<br>1'b1: Enable                                                 |
| 11         | RW          | 0x0                | ddrio_hz_ena<br>Enable DDR IO High-Z function performed by hardware.<br>1'b0: Disable<br>1'b1: Enable                                                         |
| 10         | RW          | 0x0                | ddrphy_auto_gating_ena<br>Enable DDRPHY auto clock gating function performed by PMU, when DDR enter self-refresh state.<br>1'b0: Disable<br>1'b1: Enable      |
| 9          | RW          | 0x0                | ddrctl_c_auto_gating_ena<br>Enable DDRCTL's core-clock auto clock gating. Core-clock can be gated when in self-refresh mode.<br>1'b0: Disable<br>1'b1: Enable |
| 8          | RW          | 0x0                | ddrctl_a_auto_gating_ena<br>Enable DDRCTL's AXI-clock auto clock gating. AXI-clock can be gated when in self-refresh mode.<br>1'b0: Disable<br>1'b1: Enable   |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                      |
| 5          | RW          | 0x0                | ddrio_ret_exit_ena<br>Enable DDR IO retention de-asserted performed by hardware.<br>1'b0: Disable<br>1'b1: Enable                                             |
| 4:3        | RO          | 0x0                | reserved                                                                                                                                                      |
| 2          | RW          | 0x0                | ddrio_ret_ena<br>Enable DDR IO retention function performed by hardware.<br>1'b0: Disable<br>1'b1: Enable                                                     |
| 1          | RW          | 0x0                | ddr_sref_a_ena<br>Enable DDR self-refresh mode for AXI-clock domain by hardware.<br>1'b0: Disable<br>1'b1: Enable                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | ddr_sref_c_ena<br>Enable DDR self-refresh mode for core-clock domain by hardware.<br>1'b0: Disable<br>1'b1: Enable |

**PMU DDR PWR SFTCON**

Address: Operational Base(0xFF900000) + 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 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                | ddrio_hz_exit_sftena<br>DDR IO High-Z exit request by software.<br>1'b0: Disable<br>1'b1: Enable                                                                                                   |
| 12         | RW          | 0x0                | ddrio_hz_enter_sftena<br>DDR IO High-Z enter request by software.<br>1'b0: Disable<br>1'b1: Enable                                                                                                 |
| 11         | RW          | 0x0                | ddrctl_c_active_wait_enter<br>1'b0: Not need to wait for ddrctl_c_active low before FSM enter self-refresh state<br>1'b1: Need to wait for ddrctl_c_active low before FSM enter self-refresh state |
| 10         | RW          | 0x0                | ddrctl_a_active_wait_exit<br>1'b0: Not need to wait for ddrctl_a_active high before FSM exit self-refresh state<br>1'b1: Need to wait for ddrctl_a_active high before FSM exit self-refresh state  |
| 9          | RW          | 0x0                | ddrctl_c_active_wait_exit<br>1'b0: Not need to wait for ddrctl_c_active high before FSM exit self-refresh state<br>1'b1: Need to wait for ddrctl_c_active high before FSM exit self-refresh state  |
| 8          | RW          | 0x0                | ddrctl_a_active_wait_enter<br>1'b0: Not need to wait for ddrctl_a_active low before FSM enter self-refresh state<br>1'b1: Need to wait for ddrctl_a_active low before FSM enter self-refresh state |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------|
| 5          | RW          | 0x0                | ddrio_ret_exit_sftena<br>DDR IO retention exit request by software.<br>1'b0: Disable<br>1'b1: Enable                  |
| 4:3        | RO          | 0x0                | reserved                                                                                                              |
| 2          | RW          | 0x0                | ddrio_ret_enter_sftena<br>DDR IO retention enter request by software.<br>1'b0: Disable<br>1'b1: Enable                |
| 1          | RW          | 0x0                | ddr_sref_a_sftena<br>Enable DDR self-refresh mode for AXI-clock domain by software.<br>1'b0: Disable<br>1'b1: Enable  |
| 0          | RW          | 0x0                | ddr_sref_c_sftena<br>Enable DDR self-refresh mode for core-clock domain by software.<br>1'b0: Disable<br>1'b1: Enable |

### **PMU DDR POWER STS**

Address: Operational Base(0xFF900000) + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2:0        | RO          | 0x0                | ddr_power_state<br>DDR power state.<br>4'h0: Normal state<br>4'h1: Enter self-refresh mode for AXI-clock state<br>4'h2: Enter self-refresh mode core-clock state<br>4'h3: Enter retention mode state<br>4'h5: Sleep state<br>4'h7: Exit retention mode<br>4'h8: Exit self-refresh mode for core-clock state<br>4'h9: Exit self-refresh mode for AXI-clock state<br>4'ha: Enter IO High-Z mode state<br>4'hb: Exit IO High-Z mode<br>Others: Reserved |

### **PMU DDR STS**

Address: Operational Base(0xFF900000) + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------|
| 31:7       | RO          | 0x00000000         | reserved                                                           |
| 6          | RO          | 0x0                | ddrio_hz<br>DDR IO High-Z state.<br>1'b0: Inactive<br>1'b1: Active |
| 5          | RO          | 0x0                | reserved                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------|
| 4          | RO          | 0x0                | ddrctl_a_active<br>DDRCTL AXI clock active.<br>1'b0: Inactive<br>1'b1: Active                           |
| 3          | RO          | 0x0                | ddrctl_a_sysack<br>DDRCTL AXI hardware low-power request acknowledge.<br>1'b0: Inactive<br>1'b1: Active |
| 2          | RO          | 0x0                | ddrio_ret<br>DDR IO retention state.<br>1'b0: Inactive<br>1'b1: Active                                  |
| 1          | RO          | 0x0                | ddrctl_c_active<br>DDRCTL hardware low-power clock active.<br>1'b0: Inactive<br>1'b1: Active            |
| 0          | RO          | 0x0                | ddrctl_c_sysack<br>DDRCTL hardware low-power request acknowledge.<br>1'b0: Inactive<br>1'b1: Active     |

**PMU CRU PWR CON0**

Address: Operational Base(0xFF900000) + 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 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                | alive_hptimer_ena<br>HPTIMER switch to 32KHz clock enable by hardware.<br>1'b0: Disable<br>1'b1: Enable                            |
| 13         | RW          | 0x0                | vdpll_output_clamp_ena<br>VD_PLL output clamp enable by hardware.<br>1'b0: Disable<br>1'b1: Enable                                 |
| 12         | RW          | 0x0                | pwm_clk_gate_osc_ena<br>PWM clock source OSC gating enable by hardware.<br>1'b0: Disable<br>1'b1: Enable                           |
| 11         | RW          | 0x0                | pwm_clk_gate_pll_ena<br>PWM clock source PLL gating enable by hardware.<br>1'b0: Disable<br>1'b1: Enable                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10         | RW          | 0x0                | sleep_hold_ena<br>PMU sleep hold enable by hardware.<br>1'b0: Disable<br>1'b1: Enable                                                                                      |
| 9          | RO          | 0x0                | reserved                                                                                                                                                                   |
| 8          | RW          | 0x0                | pwm_switch_iout<br>PWM switch output.                                                                                                                                      |
| 7          | RW          | 0x0                | pwm_gpio_ioe_ena<br>PWM output enable by hardware.<br>1'b0: Disable<br>1'b1: Enable                                                                                        |
| 6          | RW          | 0x0                | pwm_switch_ena<br>PWM switch enable by hardware.<br>1'b0: Disable<br>1'b1: Enable                                                                                          |
| 5          | RW          | 0x0                | power_off_ena<br>Chip power off enable by hardware.<br>1'b0: Disable<br>1'b1: Enable                                                                                       |
| 4          | RW          | 0x0                | alive_osc_ena<br>Clock of PMU wakeup source switch to oscillator enable by hardware. 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 by hardware. 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>Invalidate oscillator by hardware.<br>1'b0: Disable<br>1'b1: Enable                                                                                         |
| 0          | RW          | 0x0                | alive_32k_ena<br>Clock of PMU wakeup source and clk_pmu switch to 32KHz clock enable by hardware.<br>1'b0: Disable<br>1'b1: Enable                                         |

**PMU CRU PWR CON1**

Address: Operational Base(0xFF900000) + 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 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                | clk_src_gate_mode<br>Auto gate clock mode.<br>1'b0: Release when CRU_POWER_STS exit sleep state.<br>1'b1: Release when CRU_POWER_STS exit PLL power up state. |
| 1          | RW          | 0x0                | core_clk_src_gate_ena<br>Auto gate clock in VD_CORE when CRU_POWER_STS is in sleep state.<br>1'b0: Disable<br>1'b1: Enable                                    |
| 0          | RW          | 0x0                | logic_clk_src_gate_ena<br>Auto gate clock in VD_LOGIC when CRU_POWER_STS is in sleep state.<br>1'b0: Disable<br>1'b1: Enable                                  |

### **PMU CRU PWR SFTCON0**

Address: Operational Base(0xFF900000) + 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 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable     |
| 15         | RW          | 0x0                | alive_hptimer_sftena<br>Enable HPTIMER switch to 32KHz clock by software.<br>1'b0: Disable<br>1'b1: Enable                             |
| 14:10      | RO          | 0x00               | reserved                                                                                                                               |
| 9          | RW          | 0x0                | core_clk_src_gate_sftena<br>Gate clock in VD_CORE when CRU_POWER_STS is in sleep state by software.<br>1'b0: Disable<br>1'b1: Enable   |
| 8          | RW          | 0x0                | logic_clk_src_gate_sftena<br>Gate clock in VD_LOGIC when CRU_POWER_STS is in sleep state by software.<br>1'b0: Disable<br>1'b1: Enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | RW          | 0x0                | vdpll_clamp_sftena<br>VD_PLL output clamp enable by software.<br>1'b0: Disable<br>1'b1: Enable                                                                                   |
| 6          | RW          | 0x0                | power_off_pol<br>Power off polarity.<br>1'b0: High active<br>1'b1: Low active                                                                                                    |
| 5          | RW          | 0x0                | power_off_sftena<br>Power off chip by software.<br>1'b0: Disable<br>1'b1: Enable                                                                                                 |
| 4          | RW          | 0x0                | alive_osc_sftena<br>Clock of PMU wakeup source switch to oscillator enable by software. When alive_32k_sftena is asserted, this bit is ignored.<br>1'b0: Disable<br>1'b1: Enable |
| 3          | RW          | 0x0                | input_clamp_sftena<br>VD_PMU input clamp enable by software.<br>1'b0: Disable<br>1'b1: Enable                                                                                    |
| 2          | RW          | 0x0                | wakeup_RST_sftena<br>Wakeup reset enable by software. Reset the whole chip, except IPs supporting reset hold function.<br>1'b0: Disable<br>1'b1: Enable                          |
| 1          | RW          | 0x0                | osc_dis_sftena<br>Invalidate oscillator by software.<br>1'b0: Disable<br>1'b1: Enable                                                                                            |
| 0          | RW          | 0x0                | alive_32k_sftena<br>Clock of PMU wakeup source and clk_pmu switch to 32KHz clock enable by software.<br>1'b0: Disable<br>1'b1: Enable                                            |

**PMU\_CRU\_PWR\_SFTCON1**

Address: Operational Base(0xFF900000) + 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 16 bits, each bit is individual.<br>1'b0: Write access disable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>            |
|------------|-------------|--------------------|-------------------------------|
|            |             |                    | 1'b1: Write access enable     |
| 15:3       | RO          | 0x0000             | reserved                      |
| 2:0        | RW          | 0x7                | osc_ds<br>OSC drive strength. |

**PMU\_CRU\_POWER\_STS**

Address: Operational Base(0xFF900000) + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 3:0        | RO          | 0x0                | cru_power_state<br>Clock and reset power state.<br>4'h0: Normal state<br>4'h1: Clock low frequency state<br>4'h2: PLL power down state<br>4'h4: Input clamp state<br>4'h5: Oscillator disable state<br>4'h6: Sleep state<br>4'h7: Wake up state<br>4'h9: Oscillator enable state<br>4'ha: Input clamp release state<br>4'hb: Clock high frequency state<br>4'hc: Wake up reset clear state<br>4'hd: GPIO switch state<br>4'he: PLL power up state<br>4'hf: PWM switch state<br>Others: Reserved |

**PMU\_PLLPD\_CON**

Address: Operational Base(0xFF900000) + 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 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                | vpll1_pd_ena<br>VPLL1 power down by hardware.<br>1'b0: Disable<br>1'b1: Enable                                                     |
| 1          | RW          | 0x0                | vpll0_pd_ena<br>VPLL0 power down by hardware.<br>1'b0: Disable<br>1'b1: Enable                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | gpll_pd_ena<br>GPLL power down by hardware.<br>1'b0: Disable<br>1'b1: Enable |

**PMU PLLPD SFTCON**

Address: Operational Base(0xFF900000) + 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 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                | vpll1_pd_sftena<br>VPLL1 power down by software.<br>1'b0: Disable<br>1'b1: Enable                                                  |
| 1          | RW          | 0x0                | vpll0_pd_sftena<br>VPLL0 power down by software.<br>1'b0: Disable<br>1'b1: Enable                                                  |
| 0          | RW          | 0x0                | gpll_pd_sftena<br>GPLL power down by software.<br>1'b0: Disable<br>1'b1: Enable                                                    |

**PMU INFO TX CON**

Address: Operational Base(0xFF900000) + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable         |
| 15:9       | RO          | 0x00               | reserved                                                                                                                                   |
| 8          | RW          | 0x0                | info_tx_en<br>PMU debug information transmit enable.<br>1'b0: Disable<br>1'b1: Enable                                                      |
| 7:0        | 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. |

**PMU PMIC STABLE CNT**

Address: Operational Base(0xFF900000) + offset (0x0090)

| <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 wake up. |

**PMU OSC STABLE CNT**

Address: Operational Base(0xFF900000) + offset (0x0094)

| <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 disable to enable. |

**PMU WAKEUP\_RSTCLR\_CNT**

Address: Operational Base(0xFF900000) + offset (0x0098)

| <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(0xFF900000) + offset (0x009C)

| <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 power up to lock. |

**PMU WAKEUP TIMEOUT CNT**

Address: Operational Base(0xFF900000) + offset (0x00A0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                |
|------------|-------------|--------------------|---------------------------------------------------|
| 31:0       | RW          | 0x00005dc0         | wakeup_timeout_cnt<br>PMU wakeup timeout counter. |

**PMU PWM SWITCH CNT**

Address: Operational Base(0xFF900000) + offset (0x00A4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                       |
|------------|-------------|--------------------|------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                 |
| 19:0       | RW          | 0xfffff            | stable_cnt<br>PWM switch stable counter. |

**PMU SLEEP HOLD CNT**

Address: Operational Base(0xFF900000) + offset (0x00A8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                        |
|------------|-------------|--------------------|-------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                  |
| 19:0       | RW          | 0xfffff            | sleep_hold_cnt<br>PMU sleep hold counter. |

**PMU\_MISC\_CON**

Address: Operational Base(0xFF900000) + 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:7       | RO          | 0x000              | reserved                                                                                                                                                                  |
| 6          | R/W SC      | 0x0                | rtc_en<br>Real time clock enable.<br>1'b0: Disable<br>1'b1: Enable                                                                                                        |
| 5          | R/W SC      | 0x0                | timeout_mode<br>Timeout mode select.<br>1'b0: timeout counter start once wakeup_timeout_en<br>1'b1: timeout counter start only when wakeup_timeout_en and PMU enter sleep |
| 4          | RO          | 0x0                | reserved                                                                                                                                                                  |
| 3          | R/W SC      | 0x0                | second_catch_int_en<br>Second catch interrupt enable.<br>1'b0: Disable<br>1'b1: Enable                                                                                    |
| 2          | R/W SC      | 0x0                | second_catch_en<br>Second catch enable.<br>1'b0: Disable<br>1'b1: Enable                                                                                                  |
| 1          | R/W SC      | 0x0                | alarm_int_en<br>Alarm interrupt enable.<br>1'b0: Disable<br>1'b1: Enable                                                                                                  |
| 0          | R/W SC      | 0x0                | alarm_en<br>Alarm enable.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                |

**PMU\_MISC\_INT\_ST**

Address: Operational Base(0xFF900000) + offset (0x00B4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                              |
| 2          | RO          | 0x0                | pmu_int_st<br>PMU interrupt status.<br>1'b0: Inactive<br>1'b1: Active |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------|
| 1          | RO          | 0x0                | second_catch_int_st<br>Second catch interrupt status.<br>1'b0: Inactive<br>1'b1: Active |
| 0          | RO          | 0x0                | alarm_int_st<br>Alarm interrupt status.<br>1'b0: Inactive<br>1'b1: Active               |

**PMU ALARM CNT**

Address: Operational Base(0xFF900000) + offset (0x00B8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>          |
|------------|-------------|--------------------|-----------------------------|
| 31:29      | RO          | 0x0                | reserved                    |
| 28:0       | RW          | 0x1fffffff         | alarm_cnt<br>Alarm counter. |

**PMU RTC ST**

Address: Operational Base(0xFF900000) + offset (0x00BC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:29      | RO          | 0x0                | reserved                           |
| 28:0       | RO          | 0x00000000         | rtc_cnt<br>Real time clock status. |

**PMU CLKDIV CON**

Address: Operational Base(0xFF900000) + offset (0x00C0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 31:18      | RO          | 0x0000             | reserved                                                                                                            |
| 17:0       | RW          | 0x07fff            | clkdiv_con<br>PMU clock divider, which is used to get 1Hz clock from 32KHz source. Divide value equal clkdiv_con+1. |

**PMU SCU PWR CON**

Address: Operational Base(0xFF900000) + offset (0x1000)

| <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:10      | RO          | 0x00               | reserved                                                                                                                           |
| 9          | RW          | 0x0                | standbywfil2_bypass_ena<br>L2 STANDBYWFI bypass enable for SCU enter low power mode by hardware.<br>1'b0: Disable<br>1'b1: Enable  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 8          | RW          | 0x0                | standbywfi_bypass_ena<br>CPU STANDBYWFI bypass enable for SCU enter low power mode by hardware.<br>1'b0: Disable<br>1'b1: Enable |
| 7          | RW          | 0x0                | scu_vol_gate_ena<br>SCU voltage gate enable by hardware.<br>1'b0: Disable<br>1'b1: Enable                                        |
| 6          | RW          | 0x0                | cluster_clk_src_gate_ena<br>CPU clock source gating enable by hardware.<br>1'b0: Disable<br>1'b1: Enable                         |
| 5          | RW          | 0x0                | cluster_cpu_pwrdown_ena<br>CPU power down enable by hardware.<br>1'b0: Disable<br>1'b1: Enable                                   |
| 4          | RO          | 0x0                | reserved                                                                                                                         |
| 3          | RW          | 0x0                | scu_pwroff_ena<br>SCU power off enable by hardware.<br>1'b0: Disable<br>1'b1: Enable                                             |
| 2          | RW          | 0x0                | scu_pwrdown_ena<br>SCU power down enable by hardware.<br>1'b0: Disable<br>1'b1: Enable                                           |
| 1          | RW          | 0x0                | l2_idle_ena<br>L2 idle enable by hardware.<br>1'b0: Disable<br>1'b1: Enable                                                      |
| 0          | RW          | 0x0                | l2_flush_ena<br>L2 flush enable by hardware.<br>1'b0: Disable<br>1'b1: Enable                                                    |

### **PMU SCU PWR SFTCON**

Address: Operational Base(0xFF900000) + offset (0x1004)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------|
| 5          | RW          | 0x0                | scu_pwroff_pol<br>SCU power off polarity.<br>1'b0: High active.<br>1'b1: Low active.      |
| 4          | RO          | 0x0                | reserved                                                                                  |
| 3          | RW          | 0x0                | scu_pwroff_sftena<br>SCU power off enable by software.<br>1'b0: Disable<br>1'b1: Enable   |
| 2          | RW          | 0x0                | scu_pwrdown_sftena<br>SCU power down enable by software.<br>1'b0: Disable<br>1'b1: Enable |
| 1          | RO          | 0x0                | reserved                                                                                  |
| 0          | RW          | 0x0                | l2_flush_sftena<br>L2 flash enable by software.<br>1'b0: Disable<br>1'b1: Enable          |

### **PMU SCU AUTO CON**

Address: Operational Base(0xFF900000) + offset (0x1008)

| <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_sft_wakeup_cluster_ena<br>SCU software wakeup enable.<br>1'b0: Disable<br>1'b1: Enable                                         |
| 2          | RW          | 0x0                | scu_int_mask_ena<br>SCU interrupt mask enable.<br>1'b0: Disable<br>1'b1: Enable                                                    |
| 1          | RW          | 0x0                | scu_int_wakeup_cluster_ena<br>SCU interrupt wakeup enable.<br>1'b0: Disable<br>1'b1: Enable                                        |
| 0          | RW          | 0x0                | scu_lp_ena<br>SCU low power enable.<br>1'b0: Disable<br>1'b1: Enable                                                               |

### **PMU SCU POWER STS**

Address: Operational Base(0xFF900000) + offset (0x100C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                            |
| 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'h2: L2 flush state<br>4'h3: L2 idle 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 CLUSTER PWR ST**

Address: Operational Base(0xFF900000) + offset (0x101C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------|
| 31:13      | RO          | 0x00000            | reserved                                                                              |
| 12         | RO          | 0x0                | scu_dwn_state<br>SCU power down state.<br>1'b0: Inactive<br>1'b1: Active              |
| 11         | RO          | 0x0                | cpu2_dwn_state<br>CPU2 power down state.<br>1'b0: Inactive<br>1'b1: Active            |
| 10         | RO          | 0x0                | cpu1_dwn_state<br>CPU1 power down state.<br>1'b0: Inactive<br>1'b1: Active            |
| 9          | RO          | 0x0                | cpu0_dwn_state<br>CPU0 power down state.<br>1'b0: Inactive<br>1'b1: Active            |
| 8          | RO          | 0x0                | idle_ack_cpu_p<br>BIU_CPU_P idle acknowledge state.<br>1'b0: Inactive<br>1'b1: Active |
| 7          | RO          | 0x0                | idle_cpu_p<br>BIU_CPU_P idle state.<br>1'b0: Inactive<br>1'b1: Active                 |

| Bit | Attr | Reset Value | Description                                                                       |
|-----|------|-------------|-----------------------------------------------------------------------------------|
| 6   | RO   | 0x0         | idle_ack_cpu<br>BIU_CPU idle acknowledge state.<br>1'b0: Inactive<br>1'b1: Active |
| 5   | RO   | 0x0         | idle_cpu<br>BIU_CPU idle state.<br>1'b0: Inactive<br>1'b1: Active                 |
| 4   | RO   | 0x0         | l2flushdone<br>L2 flush done state.<br>1'b0: Inactive<br>1'b1: Active             |
| 3   | RO   | 0x0         | standbywfi2<br>L2 STANDBYWFI state.<br>1'b0: Inactive<br>1'b1: Active             |
| 2   | RO   | 0x0         | cpu2_standbywfi<br>CPU2 STANDBYWFI state.<br>1'b0: Inactive<br>1'b1: Active       |
| 1   | RO   | 0x0         | cpu1_standbywfi<br>CPU1 STANDBYWFI state.<br>1'b0: Inactive<br>1'b1: Active       |
| 0   | RO   | 0x0         | cpu0_standbywfi<br>CPU0 STANDBYWFI state.<br>1'b0: Inactive<br>1'b1: Active       |

**PMU CLUSTER IDLE CON**

Address: Operational Base(0xFF900000) + offset (0x1020)

| Bit   | Attr | Reset Value | Description                                                                                                                                                 |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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         | auto_gate_mask_cpu_p<br>If enable, BIU_CPU_P corresponding clock can be opened or gated automatically when idle operation.<br>1'b0: Disable<br>1'b1: Enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | idle_req_cpu_p<br>Enable sending bus idle request to NIU_CPU_P by hardware.<br>1'b0: Disable<br>1'b1: Enable                                            |
| 2          | RW          | 0x0                | auto_gate_mask_cpu<br>If enable, BIU_CPU corresponding clock can be opened or gated automatically when idle operation.<br>1'b0: Disable<br>1'b1: Enable |
| 1          | RW          | 0x0                | idle_req_cpu<br>Enable sending bus idle request to NIU_CPU by hardware.<br>1'b0: Disable<br>1'b1: Enable                                                |
| 0          | RO          | 0x0                | reserved                                                                                                                                                |

**PMU CLUSTER IDLE SFTCON**

Address: Operational Base(0xFF900000) + offset (0x1024)

| <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                | idle_req_cpu_p<br>Enable sending bus idle request to NIU_CPU_P by software.<br>1'b0: Disable<br>1'b1: Enable                       |
| 1          | RW          | 0x0                | idle_req_cpu<br>Enable sending bus idle request to NIU_CPU by software.<br>1'b0: Disable<br>1'b1: Enable                           |
| 0          | RO          | 0x0                | reserved                                                                                                                           |

**PMU CORE PWRUP CNT**

Address: Operational Base(0xFF900000) + offset (0x1030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                      |
| 19:0       | RW          | 0x05dc0            | core_pwrup_cnt<br>VD_CORE power up counter. The value is the cycle number counted in clk_pmu. |

**PMU CORE PWRDN CNT**

Address: Operational Base(0xFF900000) + offset (0x1034)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------|
| 19:0       | RW          | 0x05dc0            | core_pwrdown_cnt<br>VD_CORE power down counter. The value is the cycle number counted in clk_pmu. |

**PMU CORE STABLE CNT**

Address: Operational Base(0xFF900000) + offset (0x1038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                           |
| 19:0       | RW          | 0xfffff            | core_stable_cnt<br>VD_CORE power stable counter. The value is the cycle number counted in clk_pmu. |

**PMU CPU0 AUTO PWR CON**

Address: Operational Base(0xFF900000) + offset (0x1040)

| <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                | cpu0_auto_pwrdown_mode<br>CPU0 auto power down mode.<br>1'b0: Auto power down after WFI.<br>1'b1: Auto power down after wakeup.    |
| 3          | RW          | 0x0                | cpu0_sft_wakeup_ena<br>CPU0 software wakeup enable.<br>1'b0: Disable<br>1'b1: Enable                                               |
| 2          | RW          | 0x0                | cpu0_int_mask_ena<br>CPU0 interrupt mask enable.<br>1'b0: Disable<br>1'b1: Enable                                                  |
| 1          | RW          | 0x0                | cpu0_int_wakeup_ena<br>CPU0 interrupt wakeup enable.<br>1'b0: Disable<br>1'b1: Enable                                              |
| 0          | RW          | 0x0                | cpu0_auto_pwrdown_ena<br>CPU0 auto power down enable.<br>1'b0: Disable<br>1'b1: Enable                                             |

**PMU CPU1 AUTO PWR CON**

Address: Operational Base(0xFF900000) + offset (0x1044)

| <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                | cpu1_auto_pwrdown_mode<br>CPU1 auto power down mode.<br>1'b0: Auto power down after WFI.<br>1'b1: Auto power down after wakeup.    |
| 3          | RW          | 0x0                | cpu1_sft_wakeup_ena<br>CPU1 software wakeup enable.<br>1'b0: Disable<br>1'b1: Enable                                               |
| 2          | RW          | 0x0                | cpu1_int_mask_ena<br>CPU1 interrupt mask enable.<br>1'b0: Disable<br>1'b1: Enable                                                  |
| 1          | RW          | 0x0                | cpu1_int_wakeup_ena<br>CPU1 interrupt wakeup enable.<br>1'b0: Disable<br>1'b1: Enable                                              |
| 0          | RW          | 0x0                | cpu1_auto_pwrdown_ena<br>CPU1 auto power down enable.<br>1'b0: Disable<br>1'b1: Enable                                             |

### **PMU CPU2 AUTO PWR CON**

Address: Operational Base(0xFF900000) + offset (0x1048)

| <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                | cpu2_auto_pwrdown_mode<br>CPU2 auto power down mode.<br>1'b0: Auto power down after WFI.<br>1'b1: Auto power down after wakeup.    |
| 3          | RW          | 0x0                | cpu2_sft_wakeup_ena<br>CPU2 software wakeup enable.<br>1'b0: Disable<br>1'b1: Enable                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | cpu2_int_mask_ena<br>CPU2 interrupt mask enable.<br>1'b0: Disable<br>1'b1: Enable      |
| 1          | RW          | 0x0                | cpu2_int_wakeup_ena<br>CPU2 interrupt wakeup enable.<br>1'b0: Disable<br>1'b1: Enable  |
| 0          | RW          | 0x0                | cpu2_auto_pwrdown_ena<br>CPU2 auto power down enable.<br>1'b0: Disable<br>1'b1: Enable |

### **PMU CPU0 PWR SFTCON**

Address: Operational Base(0xFF900000) + offset (0x1050)

| <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                | cpu0_sft_pwrdown_ena<br>CPU0 power down enable by software.<br>1'b0: Disable<br>1'b1: Enable                                       |

### **PMU CPU1 PWR SFTCON**

Address: Operational Base(0xFF900000) + offset (0x1054)

| <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                | cpu1_sft_pwrdown_ena<br>CPU1 power down enable by software.<br>1'b0: Disable<br>1'b1: Enable                                       |

### **PMU CPU2 PWR SFTCON**

Address: Operational Base(0xFF900000) + offset (0x1058)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------|
|            |             |                    | 1'b1: Write access enable                                                                    |
| 15:1       | RO          | 0x0000             | reserved                                                                                     |
| 0          | RW          | 0x0                | cpu2_sft_pwrdown_ena<br>CPU2 power down enable by software.<br>1'b0: Disable<br>1'b1: Enable |

**PMU BIU IDLE CON**

Address: Operational Base(0xFF900000) + offset (0x1100)

| <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_ddr<br>Enable sending bus idle request to BIU_DDR by hardware.<br>1'b0: Disable<br>1'b1: Enable                           |
| 3          | RW          | 0x0                | idle_req_vio<br>Enable sending bus idle request to BIU_VIO by hardware.<br>1'b0: Disable<br>1'b1: Enable                           |
| 2          | RW          | 0x0                | idle_req_lsperi<br>Enable sending bus idle request to BIU_LSPERI by hardware.<br>1'b0: Disable<br>1'b1: Enable                     |
| 1          | RW          | 0x0                | idle_req_hsperi<br>Enable sending idle request to BIU_HSPERI by hardware.<br>1'b0: Disable<br>1'b1: Enable                         |
| 0          | RW          | 0x0                | idle_req_bus<br>Enable sending bus idle request to BIU_BUS by hardware.<br>1'b0: Disable<br>1'b1: Enable                           |

**PMU BIU IDLE SFTCON**

Address: Operational Base(0xFF900000) + offset (0x1110)

| <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_ddr<br>Enable sending bus idle request to BIU_DDR by software.<br>1'b0: Disable<br>1'b1: Enable       |
| 3          | RW          | 0x0                | idle_req_vio<br>Enable sending bus idle request to BIU_VIO by software.<br>1'b0: Disable<br>1'b1: Enable       |
| 2          | RW          | 0x0                | idle_req_lsperi<br>Enable sending bus idle request to BIU_LSPERI by software.<br>1'b0: Disable<br>1'b1: Enable |
| 1          | RW          | 0x0                | idle_req_hsperi<br>Enable sending bus idle request to BIU_HSPERI by software.<br>1'b0: Disable<br>1'b1: Enable |
| 0          | RW          | 0x0                | idle_req_bus<br>Enable sending idle request to BIU_BUS by software.<br>1'b0: Disable<br>1'b1: Enable           |

**PMU BIU IDLE ACK**

Address: Operational Base(0xFF900000) + offset (0x1120)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                                                                |
| 4          | RO          | 0x0                | idle_ack_ddr<br>BIU_DDR bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge       |
| 3          | RO          | 0x0                | idle_ack_vio<br>BIU_VIO bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge       |
| 2          | RO          | 0x0                | idle_ack_lsperi<br>BIU_LSPERI bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge |
| 1          | RO          | 0x0                | idle_ack_hsperi<br>BIU_HSPERI bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge |
| 0          | RO          | 0x0                | idle_ack_bus<br>BIU_BUS bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge       |

**PMU BIU IDLE ST**

Address: Operational Base(0xFF900000) + offset (0x1128)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                              |
| 4          | RO          | 0x0                | idle_ddr<br>BIU_DDR idle state.<br>1'b0: Not idle<br>1'b1: Idle       |
| 3          | RO          | 0x0                | idle_vio<br>BIU_VIO idle state.<br>1'b0: Not idle<br>1'b1: Idle       |
| 2          | RO          | 0x0                | idle_lsperi<br>BIU_LSPERI idle state.<br>1'b0: Not idle<br>1'b1: Idle |
| 1          | RO          | 0x0                | idle_hsperi<br>BIU_HSPERI idle state.<br>1'b0: Not idle<br>1'b1: Idle |
| 0          | RO          | 0x0                | idle_bus<br>BIU_BUS idle state.<br>1'b0: Not idle<br>1'b1: Idle       |

**PMU BIU GATMASK CON**

Address: Operational Base(0xFF900000) + offset (0x1130)

| <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                | auto_gate_mask_ddr<br>If enable, BIU_DDR corresponding clock can be opened or gated automatically when idle operation.<br>1'b0: Disable<br>1'b1: Enable |
| 3          | RW          | 0x0                | auto_gate_mask_vio<br>If enable, BIU_VIO corresponding clock can be opened or gated automatically when idle operation.<br>1'b0: Disable<br>1'b1: Enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | <p>auto_gate_mask_lsperi<br/>If enable, BIU_LSPERI corresponding clock can be opened or gated automatically when idle operation.<br/>1'b0: Disable<br/>1'b1: Enable</p> |
| 1          | RW          | 0x0                | <p>auto_gate_mask_hsperi<br/>If enable, BIU_HSPERI corresponding clock can be opened or gated automatically when idle operation.<br/>1'b0: Disable<br/>1'b1: Enable</p> |
| 0          | RW          | 0x0                | <p>auto_gate_mask_bus<br/>If enable, BIU_BUS corresponding clock can be opened or gated automatically when idle operation.<br/>1'b0: Disable<br/>1'b1: Enable</p>       |

### **PMU BIU GATMASK SFTCON**

Address: Operational Base(0xFF900000) + offset (0x1140)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_enable<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>     |
| 15:5       | RO          | 0x000              | reserved                                                                                                                                         |
| 4          | RW          | 0x0                | <p>sft_gate_mask_ddr<br/>If enable, BIU_DDR corresponding clock can be opened or gated by software.<br/>1'b0: Disable<br/>1'b1: Enable</p>       |
| 3          | RW          | 0x0                | <p>sft_gate_mask_vio<br/>If enable, BIU_VIO corresponding clock can be opened or gated by software.<br/>1'b0: Disable<br/>1'b1: Enable</p>       |
| 2          | RW          | 0x0                | <p>sft_gate_mask_lsperi<br/>If enable, BIU_LSPERI corresponding clock can be opened or gated by software.<br/>1'b0: Disable<br/>1'b1: Enable</p> |
| 1          | RW          | 0x0                | <p>sft_gate_mask_hsperi<br/>If enable, BIU_HSPERI corresponding clock can be opened or gated by software.<br/>1'b0: Disable<br/>1'b1: Enable</p> |

| Bit | Attr | Reset Value | Description                                                                                                                      |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| 0   | RW   | 0x0         | sft_gate_mask_bus<br>If enable, BIU_BUS corresponding clock can be opened or gated by software.<br>1'b0: Disable<br>1'b1: Enable |

## 6.5 Application Notes

### 6.5.1 Hardware Low Power Mode

PMU can work in low power mode by hardware. After setting some power configurations and setting PMU\_PWR\_CON[0] to 1, you can execute the WFI command of CPU, then PMU low power FSM will start to run. In this mode, PMU will manage power resources by hardware, such as send idle request to specified power domain, auto clock switch and clock gating, shut down PLLs, and so on. All of above are configurable by setting corresponding registers.

Also, the WFI status of CPU can be bypass if PMU\_SCU\_PWR\_CON[8] is set to 1.

### 6.5.2 Software Low Power Mode

PMU can work in the low power mode by software. In this application, you can use CPU or MCU to set PMU software power control registers to execute low power procedure.

### 6.5.3 Power Management IO Usage

There are independent power supplies for different voltage domain. You can communicate with external PMIC (Power Management Integrated Circuits) through IO interface.

Table 6-2 Power Management IO Interface

| Module Pin            | Direction | Pin Name | IOMUX Setting |
|-----------------------|-----------|----------|---------------|
| core_pwroff/pmu_sleep | O         | RM_IO    |               |

Notes: I=input, O=output, I/O=input/output, bidirectional. For the configuration of RM\_IO, please refer to chapter "Rockchip Matrix IO".

Setting PMUGRF\_SOC\_CON1[0] to 1 to output pmu\_sleep, also, you can select the polarity by setting PMUGRF\_SOC\_CON1[1]. Setting PMUGRF\_SOC\_CON1[2] to 1 to output core\_pwroff, also, you can select the polarity by setting PMUGRF\_SOC\_CON1[3].

Each voltage domain can generate one power off request. The voltage domain power off request can be generated as below:

- (1) Enable power off control bit: Set corresponding bit to 1 in PMU\_VOL\_GATE\_CON0.
- (2) Power down internal power domain: If there is power domain included in the voltage domain, the power domain should be power down firstly. Else, skip this step.
- (3) Power down voltage domain: Set corresponding bit to 1 in PMU\_PWR\_GATE\_CON0 by hardware power gating or set corresponding bit to 1 in PMU\_PWR\_GATE\_SFTCON0 by software power gating.

### 6.5.4 PMU Debug Information

The PMU internal states could be monitored through pmu\_debug IO in 8-bit UART interface mode. The transmission can be enabled by setting PMU\_INFO\_TX\_CON[8], and the transmission interval time can be set in PMU\_INFO\_TX\_CON[7:0]. The PMU debug information is decoded as follows.

Table 6-3 PMU Debug Information Decode

| Decode Value | PMU State                                         | Description            |
|--------------|---------------------------------------------------|------------------------|
| 2            | CPU power down state                              | PMU_SCU_POWER_STS=4'h1 |
| 5            | CORE transfer idle state                          | PMU_SCU_POWER_STS=4'h4 |
| 6            | CORE power down state                             | PMU_SCU_POWER_STS=4'h5 |
| 8            | Bus low power state                               | PMU_GLB_POWER_STS=4'h4 |
| 9            | DDR enters self-refresh mode for core-clock state | PMU_DDR_POWER_STS=4'h2 |
| 10           | DDR enters retention mode                         | PMU_DDR_POWER_STS=4'h3 |
| 13           | Clock low frequency state                         | PMU_CRU_POWER_STS=4'h1 |

| <b>Decode Value</b> | <b>PMU State</b>                                 | <b>Description</b>     |
|---------------------|--------------------------------------------------|------------------------|
| 14                  | PLL power down state                             | PMU_CRU_POWER_STS=4'h2 |
| 15                  | Input clamp state                                | PMU_CRU_POWER_STS=4'h4 |
| 16                  | Oscillator disable state                         | PMU_CRU_POWER_STS=4'h5 |
| 17                  | Sleep state                                      | PMU_GLB_POWER_STS=4'h8 |
| 18                  | Wake up state                                    | PMU_CRU_POWER_STS=4'h7 |
| 19                  | Oscillator enable state                          | PMU_CRU_POWER_STS=4'h9 |
| 20                  | Input clamp release state                        | PMU_CRU_POWER_STS=4'ha |
| 21                  | Clock high frequency state                       | PMU_CRU_POWER_STS=4'hb |
| 22                  | Wake up reset clear state                        | PMU_CRU_POWER_STS=4'hc |
| 23                  | GPIO switch state                                | PMU_CRU_POWER_STS=4'hd |
| 24                  | PLL power up state                               | PMU_CRU_POWER_STS=4'he |
| 25                  | PWM switch state                                 | PMU_CRU_POWER_STS=4'hf |
| 28                  | DDR exits retention mode                         | PMU_DDR_POWER_STS=4'h7 |
| 29                  | DDR exits self-refresh mode for core-clock state | PMU_DDR_POWER_STS=4'h8 |
| 30                  | Bus active state                                 | PMU_GLB_POWER_STS=4'hc |
| 32                  | CORE wakeup state                                | PMU_SCU_POWER_STS=4'h7 |
| 33                  | CORE power up state                              | PMU_SCU_POWER_STS=4'h8 |
| 34                  | CORE transfer resume state                       | PMU_SCU_POWER_STS=4'h9 |
| 35                  | CPU power up state                               | PMU_SCU_POWER_STS=4'ha |
| 39                  | DDR enters self-refresh for AXI-clock state      | PMU_DDR_POWER_STS=4'h1 |
| 42                  | DDR exits self-refresh mode for AXI-clock state  | PMU_DDR_POWER_STS=4'h9 |
| 43                  | DDR IO High-Z state                              | PMU_DDR_POWER_STS=4'ha |
| 44                  | DDR exits IO High-Z state                        | PMU_DDR_POWER_STS=4'hb |
| Others              | No care                                          | -                      |

## Chapter 7 Internal SRAM

### 7.1 Overview

There is one Internal SRAM in RK3506, named System SRAM. System SRAM can be divided into three 16KB slices, named System SRAM0/1/2. System SRAM0/1/2 can work as AXI slave devices from System Interconnection, it also supports work as TCM from MCU AHB slave interface. System SRAM supports read and write access to provide system fast access data storage.

#### 7.1.1 Features supported

- System SRAM
  - Support 48KB capacity
  - Include System SRAM0/1/2 internal, each of them with 16KB capacity

### 7.2 Block Diagram



Fig.7-1 System SRAM Block Diagram

### 7.3 Function Description

#### 7.3.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

##### Operational Base

| Name                             | Base Address |
|----------------------------------|--------------|
| System SRAM before remap address | 0xffff80000  |
| System SRAM remap address        | 0xffff80000  |
|                                  | 0xfffff0000  |

#### 7.3.2 System SRAM Access Path

The System SRAM AXI slave device interface can be accessed by CPU, MCU, DMAC0, DMAC1, CRYPTO and SPI2, The System SRAM AHB slave device interface can be accessed by MCU.

#### 7.3.3 System SRAM Restricted Configurations Using as TCM

System SRAM0 using as TCM is configured by mcu\_tcm\_sel0 in SGRF\_PMU. User should configure mcu\_tcm\_sel0[0], mcu\_tcm\_sel0[1], mcu\_tcm\_sel0[2] to 1 in sequence when enable to used as TCM and should configure mcu\_tcm\_sel0[2], mcu\_tcm\_sel0[1], mcu\_tcm\_sel0[0] to 0 in sequence when disable to used as TCM.

System SRAM1 using as TCM is configured by mcu\_tcm\_sel1 in SGRF\_PMU. User should configure mcu\_tcm\_sel1[0], mcu\_tcm\_sel1[1], mcu\_tcm\_sel1[2] to 1 in sequence when

enable to used as TCM and should configure mcu\_tcm\_sel1[2], mcu\_tcm\_sel1[1], mcu\_tcm\_sel1[0] to 0 in sequence when disable to used as TCM.

System SRAM2 using as TCM is configured by mcu\_tcm\_sel2 in SGRF\_PMU. User should configure mcu\_tcm\_sel2[0], mcu\_tcm\_sel2[1], mcu\_tcm\_sel2[2] to 1 in sequence when enable to used as TCM and should configure mcu\_tcm\_sel2[2], mcu\_tcm\_sel2[1], mcu\_tcm\_sel2[0] to 0 in sequence when disable to used as TCM.

Rockchip Confidential

## Chapter 8 DMA Controller (DMAC)

### 8.1 Overview

RK3506 supports two Direct Memory Access (DMA) Controllers: DAMC0 and DMAC1. Both are support transfers between memory and memory, peripheral and memory. DMAC is under non-secure state after reset, and the secure state can be changed by configuring SGRF.

DMAC0 supports the following features:

- Support Trust-zone technology
- Support 12 peripheral requests
- Support up to 64bits data size
- Support 6 channels at the same time
- Support up to burst 16
- Support 4 interrupt outputs and 1 abort output
- Supports 32 MFIFO depth

Following table shows the DMAC0 request mapping scheme.

Table 8-1 DMAC0 Request Mapping Table

| Request number | Source                   | Polarity   |
|----------------|--------------------------|------------|
| 0              | SPI0 TX/CAN0_RX/ASRC0_RX | High level |
| 1              | SPI0 RX/CAN1_RX/ASRC0_TX | High level |
| 2              | SPI1 TX/DSMC_TX/ASRC1_RX | High level |
| 3              | SPI1 RX/DSMC_RX/ASRC1_TX | High level |
| 4              | UART0 TX/CAN0_RX         | High level |
| 5              | UART0 RX/CAN1_RX/PDM_RX  | High level |
| 6              | UART1 TX/SPDIF_TX        | High level |
| 7              | UART1 RX/SPDIF_RX        | High level |
| 8              | UART2 TX/DSMC_TX/SAI0_RX | High level |
| 9              | UART2 RX/SAI0_TX         | High level |
| 10             | UART3 TX/DSMC_RX/SAI1_RX | High level |
| 11             | UART3 RX/SAI1_TX         | High level |

DMAC1 supports the following features:

- Support Trust-zone technology
- Support 20 peripheral requests
- Support up to 64bits data size
- Support 8 channels at the same time
- Support up to burst 16
- Support 4 interrupt outputs and 1 abort output
- Support 32 MFIFO depth

Following table shows the DMAC1 request mapping scheme.

Table 8-2 DMAC1 Request Mapping Table

| Request number | Source           | Polarity   |
|----------------|------------------|------------|
| 0              | SAI0 RX          | High level |
| 1              | SAI0 TX          | High level |
| 2              | SAI1 RX          | High level |
| 3              | SAI1 TX          | High level |
| 4              | SAI2 RX          | High level |
| 5              | SAI2 TX          | High level |
| 6              | SAI3 TX          | High level |
| 7              | SAI3 RX          | High level |
| 8              | SAI4 RX          | High level |
| 9              | PDM_RX           | High level |
| 10             | SPDIF_TX/CAN0_RX | High level |
| 11             | SPDIF_RX/CAN1_RX | High level |
| 12             | UART4_TX         | High level |
| 13             | UART4_RX         | High level |

| Request number | Source   | Polarity   |
|----------------|----------|------------|
| 14             | UART5_TX | High level |
| 15             | UART5_RX | High level |
| 16             | ASRC0_RX | High level |
| 17             | ASRC0_TX | High level |
| 18             | ASRC1_RX | High level |
| 19             | ASRC1_TX | High level |

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

## 8.2 Block Diagram

Following figure shows the block diagram of DMAC.



Fig. 8-1 Block diagram of DMAC

As the DMAC supports Trust-zone 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.

## 8.3 Function Description

### 8.3.1 Introduction

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

DMAC0 supports 6 channels and DMAC1 supports 8 channels, each channel is 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 four 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.

### 8.3.2 Operating states

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



Fig. 8-2 DMAC operation states

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

C DMA channel threads only.

M DMA manager thread only.

## 8.4 Register Description

DMAC has two APB interfaces, secure APB and no-secure APB. 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. Secure APB is only accessible from secure master. No-secure APB is accessible both from secure master and no-secure master.

### Operational Base

| Name                             | Base Address |
|----------------------------------|--------------|
| DMAC0 secure APB base address    | 0xFF200000   |
| DMAC0 no-secure APB base address | 0xFF000000   |
| DMAC1 secure APB base address    | 0xFF208000   |
| DMAC1 no-secure APB base address | 0xFF008000   |

### 8.4.1 Registers Summary

| Name          | Offset | Size | Reset Value | Description                         |
|---------------|--------|------|-------------|-------------------------------------|
| DMA_DSR       | 0x0000 | W    | 0x00000000  | DMA Manager Status Register         |
| DMA_DPC       | 0x0004 | W    | 0x00000000  | DMA Program Counter Register        |
| DMA_INTEN     | 0x0020 | W    | 0x00000000  | Interrupt Enable Register           |
| DMA_EVENT_RIS | 0x0024 | W    | 0x00000000  | Event-Interrupt Raw Status Register |
| DMA_INTMIS    | 0x0028 | W    | 0x00000000  | Interrupt Status Register           |
| DMA_INTCLR    | 0x002c | W    | 0x00000000  | Interrupt Clear Register            |

| Name      | Offset | Size | Reset Value | Description                       |
|-----------|--------|------|-------------|-----------------------------------|
| DMA_FSRD  | 0x0030 | W    | 0x00000000  | Fault Status DMA Manager Register |
| DMA_FSRC  | 0x0034 | W    | 0x00000000  | Fault Status DMA Channel Register |
| DMA_FTRD  | 0x0038 | W    | 0x00000000  | Fault Type DMA Manager Register   |
| DMA_FTR0  | 0x0040 | W    | 0x00000000  | Fault Type DMA Channel Register   |
| DMA_FTR1  | 0x0044 | W    | 0x00000000  | Fault Type DMA Channel Register   |
| DMA_FTR2  | 0x0048 | W    | 0x00000000  | Fault Type DMA Channel Register   |
| DMA_FTR3  | 0x004c | W    | 0x00000000  | Fault Type DMA Channel Register   |
| DMA_FTR4  | 0x0050 | W    | 0x00000000  | Fault Type DMA Channel Register   |
| DMA_FTR5  | 0x0054 | W    | 0x00000000  | Fault Type DMA Channel Register   |
| DMA_FTR6  | 0x0058 | W    | 0x00000000  | Fault Type DMA Channel Register   |
| DMA_FTR7  | 0x005c | W    | 0x00000000  | Fault Type DMA Channel Register   |
| DMA_CSR0  | 0x0100 | W    | 0x00000000  | Channel Status Registers          |
| DMA_CPC0  | 0x0104 | W    | 0x00000000  | Channel Program Counter Registers |
| DMA_CSR1  | 0x0108 | W    | 0x00000000  | Channel Status Registers          |
| DMA_CPC1  | 0x010c | W    | 0x00000000  | Channel Program Counter Registers |
| DMA_CSR2  | 0x0110 | W    | 0x00000000  | Channel Status Registers          |
| DMA_CPC2  | 0x0114 | W    | 0x00000000  | Channel Program Counter Registers |
| DMA_CSR3  | 0x0118 | W    | 0x00000000  | Channel Status Registers          |
| DMA_CPC3  | 0x011c | W    | 0x00000000  | Channel Program Counter Registers |
| DMA_CSR4  | 0x0120 | W    | 0x00000000  | Channel Status Registers          |
| DMA_CPC4  | 0x0124 | W    | 0x00000000  | Channel Program Counter Registers |
| DMA_CSR5  | 0x0128 | W    | 0x00000000  | Channel Status Registers          |
| DMA_CPC5  | 0x012c | W    | 0x00000000  | Channel Program Counter Registers |
| DMA_CSR6  | 0x0130 | W    | 0x00000000  | Channel Status Registers          |
| DMA_CPC6  | 0x0134 | W    | 0x00000000  | Channel Program Counter Registers |
| DMA_CSR7  | 0x0138 | W    | 0x00000000  | Channel Status Registers          |
| DMA_CPC7  | 0x013c | W    | 0x00000000  | Channel Program Counter Registers |
| DMA_SAR0  | 0x0400 | W    | 0x00000000  | Source Address Registers          |
| DMA_DAR0  | 0x0404 | W    | 0x00000000  | Destination Address Registers     |
| DMA_CCR0  | 0x0408 | W    | 0x00000000  | Channel Control Registers         |
| DMA_LC0_0 | 0x040c | W    | 0x00000000  | Loop Counter 0 Registers          |
| DMA_LC1_0 | 0x0410 | W    | 0x00000000  | Loop Counter 1 Registers          |

| Name          | Offset | Size | Reset Value | Description                   |
|---------------|--------|------|-------------|-------------------------------|
| DMA_SAR1      | 0x0420 | W    | 0x00000000  | Source Address Registers      |
| DMA_DAR1      | 0x0424 | W    | 0x00000000  | Destination Address Registers |
| DMA_CCR1      | 0x0428 | W    | 0x00000000  | Channel Control Registers     |
| DMA_LC0_1     | 0x042c | W    | 0x00000000  | Loop Counter 0 Registers      |
| DMA_LC1_1     | 0x0430 | W    | 0x00000000  | Loop Counter 1 Registers      |
| DMA_SAR2      | 0x0440 | W    | 0x00000000  | Source Address Registers      |
| DMA_DAR2      | 0x0444 | W    | 0x00000000  | Destination Address Registers |
| DMA_CCR2      | 0x0448 | W    | 0x00000000  | Channel Control Registers     |
| DMA_LC0_2     | 0x044c | W    | 0x00000000  | Loop Counter 0 Registers      |
| DMA_LC1_2     | 0x0450 | W    | 0x00000000  | Loop Counter 1 Registers      |
| DMA_SAR3      | 0x0460 | W    | 0x00000000  | Source Address Registers      |
| DMA_DAR3      | 0x0464 | W    | 0x00000000  | Destination Address Registers |
| DMA_CCR3      | 0x0468 | W    | 0x00000000  | Channel Control Registers     |
| DMA_LC0_3     | 0x046c | W    | 0x00000000  | Loop Counter 0 Registers      |
| DMA_LC1_3     | 0x0470 | W    | 0x00000000  | Loop Counter 1 Registers      |
| DMA_SAR4      | 0x0480 | W    | 0x00000000  | Source Address Registers      |
| DMA_DAR4      | 0x0484 | W    | 0x00000000  | Destination Address Registers |
| DMA_CCR4      | 0x0488 | W    | 0x00000000  | Channel Control Registers     |
| DMA_LC0_4     | 0x048c | W    | 0x00000000  | Loop Counter 0 Registers      |
| DMA_LC1_4     | 0x0490 | W    | 0x00000000  | Loop Counter 1 Registers      |
| DMA_SAR5      | 0x04a0 | W    | 0x00000000  | Source Address Registers      |
| DMA_DAR5      | 0x04a4 | W    | 0x00000000  | Destination Address Registers |
| DMA_CCR5      | 0x04a8 | W    | 0x00000000  | Channel Control Registers     |
| DMA_LC0_5     | 0x04ac | W    | 0x00000000  | Loop Counter 0 Registers      |
| DMA_LC1_5     | 0x04b0 | W    | 0x00000000  | Loop Counter 1 Registers      |
| DMA_SAR6      | 0x04c0 | W    | 0x00000000  | Source Address Registers      |
| DMA_DAR6      | 0x04c4 | W    | 0x00000000  | Destination Address Registers |
| DMA_CCR6      | 0x04c8 | W    | 0x00000000  | Channel Control Registers     |
| DMA_LC0_6     | 0x04cc | W    | 0x00000000  | Loop Counter 0 Registers      |
| DMA_LC1_6     | 0x04d0 | W    | 0x00000000  | Loop Counter 1 Registers      |
| DMA_SAR7      | 0x04e0 | W    | 0x00000000  | Source Address Registers      |
| DMA_DAR7      | 0x04e4 | W    | 0x00000000  | Destination Address Registers |
| DMA_CCR7      | 0x04e8 | W    | 0x00000000  | Channel Control Registers     |
| DMA_LC0_7     | 0x04ec | W    | 0x00000000  | Loop Counter 0 Registers      |
| DMA_LC1_7     | 0x04f0 | W    | 0x00000000  | Loop Counter 1 Registers      |
| DMA_DBGSTATUS | 0xd00  | W    | 0x00000000  | Debug Status Register         |
| DMA_DBGCMD    | 0xd04  | W    | 0x00000000  | Debug Command Register        |
| DMA_DBGINST0  | 0xd08  | W    | 0x00000000  | Debug Instruction-0 Register  |
| DMA_DBGINST1  | 0xd0c  | W    | 0x00000000  | Debug Instruction-1 Register  |
| DMA_CR0       | 0xe00  | W    | 0x00047051  | Configuration Register 0      |
| DMA_CR1       | 0xe04  | W    | 0x00000057  | Configuration Register 1      |
| DMA_CR2       | 0xe08  | W    | 0x00000000  | Configuration Register 2      |
| DMA_CR3       | 0xe0c  | W    | 0x00000000  | Configuration Register 3      |

| Name     | Offset | Size | Reset Value | Description              |
|----------|--------|------|-------------|--------------------------|
| DMA_CR4  | 0x0e10 | W    | 0x00000006  | Configuration Register 4 |
| DMA_CRDn | 0x0e14 | W    | 0x02094733  | Configuration Register   |
| DMA_WD   | 0x0e80 | W    | 0x00000000  | DMA Watchdog Register    |

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

## 8.4.2 Detail Register Description

### DMA\_DSR

Address: **Operational Base** + offset (0x0000)

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

### DMA\_DPC

Address: **Operational Base** + offset (0x0004)

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

### DMA\_INTEN

Address: **Operational Base** + offset (0x0020)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | <p>event_irq_select</p> <p>Bit [N]</p> <p>1'b0: If the DMAC executes DMASEV for the event-interrupt resource N then the DMAC signals event N to all of the threads.</p> <p>Set bit [N] to 0 if your system design does not use IRQ[N] to signal an interrupt request</p> <p>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</p> |

**DMA EVENT RIS**Address: **Operational Base** + offset (0x0024)

| Bit  | Attr | Reset Value | Description                                                                                                                            |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | <p>dmasev_active</p> <p>Bit [N]</p> <p>1'b0: Event N is inactive or IRQ[N] is LOW</p> <p>1'b1: Event N is active or IRQ[N] is HIGH</p> |

**DMA INTMIS**Address: **Operational Base** + offset (0x0028)

| Bit  | Attr | Reset Value | Description                                                                                                                                                       |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | <p>irq_status</p> <p>Bit [N]</p> <p>1'b0: Interrupt N is inactive and therefore IRQ[N] is LOW</p> <p>1'b1: Interrupt N is active and therefore IRQ[N] is HIGH</p> |

**DMA INTCLR**Address: **Operational Base** + offset (0x002c)

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

**DMA FSRD**Address: **Operational Base** + offset (0x0030)

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

**DMA\_FSRC**Address: **Operational Base** + offset (0x0034)

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

**DMA\_FTRD**Address: **Operational Base** + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | Reserved                                                                                                                                                                                                                                                                                                                              |
| 30         | RO          | 0x0                | dbg_instr<br>Memory or from the debug interface:<br>1'b0: Instruction that generated an abort was read from system memory<br>1'b1: Instruction that generated an abort was read from the debug interface                                                                                                                              |
| 29:17      | RO          | 0x0                | Reserved                                                                                                                                                                                                                                                                                                                              |
| 16         | RO          | 0x0                | instr_fetch_err<br>Performs an instruction fetch:<br>1'b0: OKAY response<br>1'b1: EXOKAY, SLVERR, or DECERR response                                                                                                                                                                                                                  |
| 15:6       | RO          | 0x0                | Reserved                                                                                                                                                                                                                                                                                                                              |
| 5          | RO          | 0x0                | mgr_evnt_err<br>1'b0: The DMA manager has appropriate security to execute DMAWFE or DMASEV<br>1'b1: A DMA manager thread in the Non-secure state attempted to execute either:<br><ul style="list-style-type: none"> <li>o DMAWFE to wait for a secure event</li> <li>o DMASEV to create a secure event or secure interrupt</li> </ul> |
| 4          | RO          | 0x0                | dmago_err<br>1'b0: The DMA manager has appropriate security to execute DMAGO<br>1'b1: A 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                                                                                                                                                                                                                                     |

| Bit | Attr | Reset Value | Description                                                             |
|-----|------|-------------|-------------------------------------------------------------------------|
| 0   | RW   | 0x0         | undef_instr<br>1'b0: Defined instruction<br>1'b1: Undefined instruction |

**DMA\_FTR0**Address: **Operational Base** + offset (0x0040)

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

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12   | RO   | 0x0         | <p>mfifo_err<br/>DMA LD<br/>1'b0: MFIFO contains sufficient space<br/>1'b1: MFIFO is too small to hold the data that DMA LD requires<br/>DMA ST<br/>1'b0: MFIFO contains sufficient data<br/>1'b1: MFIFO is too small to store the data to enable DMA ST to complete<br/>This fault is an imprecise abort.</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>                                                                                                                                                  |
| 6    | RO   | 0x0         | <p>ch_periph_err<br/>DMA STP, or DMAFLUSHP with inappropriate security permissions:<br/>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions<br/>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br/>o DMAWFP to wait for a secure peripheral<br/>o DMALDP or DMA STP to notify a secure peripheral<br/>o DMAFLUSHP to flush a secure peripheral<br/>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<br/>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br/>o DMAWFE to wait for a secure event<br/>o DMASEV to create a secure event or secure interrupt<br/>This fault is a precise abort.</p>                                                                                                                   |
| 4:2  | RO   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1    | RO   | 0x0         | <p>operand_invalid<br/>Valid for the configuration of the DMAC:<br/>1'b0: Valid operand<br/>1'b1: Invalid operand<br/>This fault is a precise abort.</p>                                                                                                                                                                                                                                                                                                        |

| Bit | Attr | Reset Value | Description                                                                                               |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------|
| 0   | RO   | 0x0         | undef_instr<br>1'b0: Defined instruction<br>1'b1: Undefined instruction<br>This fault is a precise abort. |

**DMA\_FTR1**Address: **Operational Base** + offset (0x0044)

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

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12   | RO   | 0x0         | <p>mfifo_err<br/>DMA LD<br/>1'b0: MFIFO contains sufficient space<br/>1'b1: MFIFO is too small to hold the data that DMA LD requires<br/>DMA ST<br/>1'b0: MFIFO contains sufficient data<br/>1'b1: MFIFO is too small to store the data to enable DMA ST to complete<br/>This fault is an imprecise abort.</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>                                                                                                                                                  |
| 6    | RO   | 0x0         | <p>ch_periph_err<br/>DMA STP, or DMAFLUSHP with inappropriate security permissions:<br/>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions<br/>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br/>o DMAWFP to wait for a secure peripheral<br/>o DMALDP or DMA STP to notify a secure peripheral<br/>o DMAFLUSHP to flush a secure peripheral<br/>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<br/>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br/>o DMAWFE to wait for a secure event<br/>o DMASEV to create a secure event or secure interrupt<br/>This fault is a precise abort.</p>                                                                                                                   |
| 4:2  | RO   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1    | RO   | 0x0         | <p>operand_invalid<br/>Valid for the configuration of the DMAC:<br/>1'b0: Valid operand<br/>1'b1: Invalid operand<br/>This fault is a precise abort.</p>                                                                                                                                                                                                                                                                                                        |

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

**DMA\_FTR2**Address: **Operational Base** + offset (0x0048)

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

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12   | RO   | 0x0         | <p>mfifo_err<br/>DMA LD<br/>1'b0: MFIFO contains sufficient space<br/>1'b1: MFIFO is too small to hold the data that DMA LD requires<br/>DMA ST<br/>1'b0: MFIFO contains sufficient data<br/>1'b1: MFIFO is too small to store the data to enable DMA ST to complete<br/>This fault is an imprecise abort.</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>                                                                                                                                                  |
| 6    | RO   | 0x0         | <p>ch_periph_err<br/>DMA STP, or DMAFLUSHP with inappropriate security permissions:<br/>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions<br/>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br/>o DMAWFP to wait for a secure peripheral<br/>o DMALDP or DMA STP to notify a secure peripheral<br/>o DMAFLUSHP to flush a secure peripheral<br/>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<br/>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br/>o DMAWFE to wait for a secure event<br/>o DMASEV to create a secure event or secure interrupt<br/>This fault is a precise abort.</p>                                                                                                                   |
| 4:2  | RO   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1    | RO   | 0x0         | <p>operand_invalid<br/>Valid for the configuration of the DMAC:<br/>1'b0: Valid operand<br/>1'b1: Invalid operand<br/>This fault is a precise abort.</p>                                                                                                                                                                                                                                                                                                        |

| Bit | Attr | Reset Value | Description                                                                                               |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------|
| 0   | RO   | 0x0         | undef_instr<br>1'b0: Defined instruction<br>1'b1: Undefined instruction<br>This fault is a precise abort. |

**DMA\_FTR3**Address: **Operational Base** + offset (0x004c)

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

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12   | RO   | 0x0         | <p>mfifo_err<br/>DMA LD<br/>1'b0: MFIFO contains sufficient space<br/>1'b1: MFIFO is too small to hold the data that DMA LD requires<br/>DMA ST<br/>1'b0: MFIFO contains sufficient data<br/>1'b1: MFIFO is too small to store the data to enable DMA ST to complete<br/>This fault is an imprecise abort.</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>                                                                                                                                                  |
| 6    | RO   | 0x0         | <p>ch_periph_err<br/>DMA STP, or DMAFLUSHP with inappropriate security permissions:<br/>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions<br/>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br/>o DMAWFP to wait for a secure peripheral<br/>o DMALDP or DMA STP to notify a secure peripheral<br/>o DMAFLUSHP to flush a secure peripheral<br/>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<br/>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br/>o DMAWFE to wait for a secure event<br/>o DMASEV to create a secure event or secure interrupt<br/>This fault is a precise abort.</p>                                                                                                                   |
| 4:2  | RO   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1    | RO   | 0x0         | <p>operand_invalid<br/>Valid for the configuration of the DMAC:<br/>1'b0: Valid operand<br/>1'b1: Invalid operand<br/>This fault is a precise abort.</p>                                                                                                                                                                                                                                                                                                        |

| Bit | Attr | Reset Value | Description                                                                                               |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------|
| 0   | RO   | 0x0         | undef_instr<br>1'b0: Defined instruction<br>1'b1: Undefined instruction<br>This fault is a precise abort. |

**DMA\_FTR4**Address: **Operational Base** + offset (0x0050)

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

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12   | RO   | 0x0         | <p>mfifo_err<br/>DMA LD<br/>1'b0: MFIFO contains sufficient space<br/>1'b1: MFIFO is too small to hold the data that DMA LD requires DMA ST</p> <p>1'b0: MFIFO contains sufficient data<br/>1'b1: MFIFO is too small to store the data to enable DMA ST to complete</p> <p>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</p> <p>This fault is a precise abort.</p>                                                                                                                                                                                                          |
| 6    | RO   | 0x0         | <p>ch_periph_err<br/>DMA STP, or DMAFLUSHP with inappropriate security permissions:<br/>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions<br/>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:</p> <ul style="list-style-type: none"> <li>o DMAWFP to wait for a secure peripheral</li> <li>o DMALDP or DMA STP to notify a secure peripheral</li> <li>o 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<br/>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:</p> <ul style="list-style-type: none"> <li>o DMAWFE to wait for a secure event</li> <li>o 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:<br/>1'b0: Valid operand<br/>1'b1: Invalid operand</p> <p>This fault is a precise abort.</p>                                                                                                                                                                                                                                                                                                                                                                |

| Bit | Attr | Reset Value | Description                                                                                               |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------|
| 0   | RO   | 0x0         | undef_instr<br>1'b0: Defined instruction<br>1'b1: Undefined instruction<br>This fault is a precise abort. |

**DMA\_FTR5**Address: **Operational Base** + offset (0x0054)

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

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12   | RO   | 0x0         | <p>mfifo_err<br/>DMA LD<br/>1'b0: MFIFO contains sufficient space<br/>1'b1: MFIFO is too small to hold the data that DMA LD requires<br/>DMA ST<br/>1'b0: MFIFO contains sufficient data<br/>1'b1: MFIFO is too small to store the data to enable DMA ST to complete<br/>This fault is an imprecise abort.</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>                                                                                                                                                  |
| 6    | RO   | 0x0         | <p>ch_periph_err<br/>DMA STP, or DMAFLUSHP with inappropriate security permissions:<br/>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions<br/>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br/>o DMAWFP to wait for a secure peripheral<br/>o DMALDP or DMA STP to notify a secure peripheral<br/>o DMAFLUSHP to flush a secure peripheral<br/>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<br/>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br/>o DMAWFE to wait for a secure event<br/>o DMASEV to create a secure event or secure interrupt<br/>This fault is a precise abort.</p>                                                                                                                   |
| 4:2  | RO   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1    | RO   | 0x0         | <p>operand_invalid<br/>Valid for the configuration of the DMAC:<br/>1'b0: Valid operand<br/>1'b1: Invalid operand<br/>This fault is a precise abort.</p>                                                                                                                                                                                                                                                                                                        |

| Bit | Attr | Reset Value | Description                                                                                               |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------|
| 0   | RO   | 0x0         | undef_instr<br>1'b0: Defined instruction<br>1'b1: Undefined instruction<br>This fault is a precise abort. |

**DMA\_FTR6**Address: **Operational Base** + offset (0x0058)

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

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12   | RO   | 0x0         | <p>mfifo_err<br/>DMA LD<br/>1'b0: MFIFO contains sufficient space<br/>1'b1: MFIFO is too small to hold the data that DMA LD requires DMA ST</p> <p>1'b0: MFIFO contains sufficient data<br/>1'b1: MFIFO is too small to store the data to enable DMA ST to complete</p> <p>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</p> <p>This fault is a precise abort.</p>                                                                                                                                                                                                          |
| 6    | RO   | 0x0         | <p>ch_periph_err<br/>DMA STP, or DMAFLUSHP with inappropriate security permissions:<br/>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions<br/>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:</p> <ul style="list-style-type: none"> <li>o DMAWFP to wait for a secure peripheral</li> <li>o DMALDP or DMA STP to notify a secure peripheral</li> <li>o 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<br/>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:</p> <ul style="list-style-type: none"> <li>o DMAWFE to wait for a secure event</li> <li>o 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:<br/>1'b0: Valid operand<br/>1'b1: Invalid operand</p> <p>This fault is a precise abort.</p>                                                                                                                                                                                                                                                                                                                                                                |

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

**DMA\_FTR7**Address: **Operational Base** + offset (0x005c)

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

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12   | RO   | 0x0         | <p>mfifo_err<br/>DMA LD<br/>1'b0: MFIFO contains sufficient space<br/>1'b1: MFIFO is too small to hold the data that DMA LD requires<br/>DMA ST<br/>1'b0: MFIFO contains sufficient data<br/>1'b1: MFIFO is too small to store the data to enable DMA ST to complete<br/>This fault is an imprecise abort.</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>                                                                                                                                                  |
| 6    | RO   | 0x0         | <p>ch_periph_err<br/>DMA STP, or DMAFLUSHP with inappropriate security permissions:<br/>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions<br/>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br/>o DMAWFP to wait for a secure peripheral<br/>o DMALDP or DMA STP to notify a secure peripheral<br/>o DMAFLUSHP to flush a secure peripheral<br/>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<br/>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br/>o DMAWFE to wait for a secure event<br/>o DMASEV to create a secure event or secure interrupt<br/>This fault is a precise abort.</p>                                                                                                                   |
| 4:2  | RO   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1    | RO   | 0x0         | <p>operand_invalid<br/>valid for the configuration of the DMAC:<br/>1'b0: Valid operand<br/>1'b1: Invalid operand<br/>This fault is a precise abort.</p>                                                                                                                                                                                                                                                                                                        |

| Bit | Attr | Reset Value | Description                                                                                               |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------|
| 0   | RO   | 0x0         | undef_instr<br>1'b0: Defined instruction<br>1'b1: Undefined instruction<br>This fault is a precise abort. |

**DMA\_CSR0**Address: **Operational Base** + offset (0x0100)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | RO   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                           |
| 21    | RO   | 0x0         | cns<br>1'b0: DMA channel operates in the Secure state<br>1'b1: DMA channel operates in the Non-secure state                                                                                                                                                                                                                                                        |
| 20:16 | RO   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                           |
| 15    | RO   | 0x0         | dmawfp_periph<br>1'b0: DMAWFP executed with the peripheral operand not set<br>1'b1: DMAWFP executed with the peripheral operand set                                                                                                                                                                                                                                |
| 14    | RO   | 0x0         | dmawfp_b_ns<br>1'b0: DMAWFP executed with the single operand set<br>1'b1: DMAWFP executed with the burst operand set                                                                                                                                                                                                                                               |
| 13:9  | RO   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                           |
| 8:4   | RO   | 0x00        | wakeup_number<br>Indicate the event or peripheral number that the channel is waiting for:<br>5'b00000: DMA channel is waiting for event 0 or peripheral 0<br>5'b00001: DMA channel is waiting for event 1 or peripheral 1<br>5'b00010: DMA channel is waiting for event 2 or peripheral 2<br>...<br>5'b11111: DMA channel is waiting for event 31 or peripheral 31 |
| 3:0   | RO   | 0x0         | channel_status<br>4'b0000: Stopped<br>4'b0001: Executing<br>4'b0010: Cache miss<br>4'b0011: Updating PC<br>4'b0100: Waiting for event<br>4'b0101: At barrier<br>4'b0110: Reserved<br>4'b0111: Waiting for peripheral<br>4'b1000: Killing<br>4'b1001: Completing<br>4'b1010-4'b1101: Reserved<br>4'b1110: Faulting completing<br>4'b1111: Faulting                  |

**DMA\_CPC0**Address: **Operational Base** + offset (0x0104)

| Bit  | Attr | Reset Value | Description                                             |
|------|------|-------------|---------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | pc_chnl<br>Program counter for the DMA channel 0 thread |

**DMA\_CSR1**Address: Operational Base + offset (0x0108)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | RO   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                           |
| 21    | RO   | 0x0         | cns<br>1'b0: DMA channel operates in the Secure state<br>1'b1: DMA channel operates in the Non-secure state                                                                                                                                                                                                                                                        |
| 20:16 | RO   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                           |
| 15    | RO   | 0x0         | dmawfp_periph<br>1'b0: DMAWFP executed with the peripheral operand not set<br>1'b1: DMAWFP executed with the peripheral operand set                                                                                                                                                                                                                                |
| 14    | RO   | 0x0         | dmawfp_b_ns<br>1'b0: DMAWFP executed with the single operand set<br>1'b1: DMAWFP executed with the burst operand set                                                                                                                                                                                                                                               |
| 13:9  | RO   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                           |
| 8:4   | RO   | 0x00        | wakeup_number<br>Indicate the event or peripheral number that the channel is waiting for:<br>5'b00000: DMA channel is waiting for event 0 or peripheral 0<br>5'b00001: DMA channel is waiting for event 1 or peripheral 1<br>5'b00010: DMA channel is waiting for event 2 or peripheral 2<br>...<br>5'b11111: DMA channel is waiting for event 31 or peripheral 31 |
| 3:0   | RO   | 0x0         | channel_status<br>4'b0000: Stopped<br>4'b0001: Executing<br>4'b0010: Cache miss<br>4'b0011: Updating PC<br>4'b0100: Waiting for event<br>4'b0101: At barrier<br>4'b0110: Reserved<br>4'b0111: Waiting for peripheral<br>4'b1000: Killing<br>4'b1001: Completing<br>4'b1010-4'b1101: Reserved<br>4'b1110: Faulting completing<br>4'b1111: Faulting                  |

**DMA\_CPC1**Address: Operational Base + offset (0x010c)

| Bit  | Attr | Reset Value | Description                                             |
|------|------|-------------|---------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | pc_chnl<br>Program counter for the DMA channel 1 thread |

**DMA\_CSR2**Address: Operational Base + offset (0x0110)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | RO   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                           |
| 21    | RO   | 0x0         | cns<br>1'b0: DMA channel operates in the Secure state<br>1'b1: DMA channel operates in the Non-secure state                                                                                                                                                                                                                                                        |
| 20:16 | RO   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                           |
| 15    | RO   | 0x0         | dmawfp_periph<br>1'b0: DMAWFP executed with the peripheral operand not set<br>1'b1: DMAWFP executed with the peripheral operand set                                                                                                                                                                                                                                |
| 14    | RO   | 0x0         | dmawfp_b_ns<br>1'b0: DMAWFP executed with the single operand set<br>1'b1: DMAWFP executed with the burst operand set                                                                                                                                                                                                                                               |
| 13:9  | RO   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                           |
| 8:4   | RO   | 0x00        | wakeup_number<br>indicate the event or peripheral number that the channel is waiting for:<br>5'b00000: DMA channel is waiting for event 0 or peripheral 0<br>5'b00001: DMA channel is waiting for event 1 or peripheral 1<br>5'b00010: DMA channel is waiting for event 2 or peripheral 2<br>...<br>5'b11111: DMA channel is waiting for event 31 or peripheral 31 |
| 3:0   | RO   | 0x0         | channel_status<br>4'b0000: Stopped<br>4'b0001: Executing<br>4'b0010: Cache miss<br>4'b0011: Updating PC<br>4'b0100: Waiting for event<br>4'b0101: At barrier<br>4'b0110: Reserved<br>4'b0111: Waiting for peripheral<br>4'b1000: Killing<br>4'b1001: Completing<br>4'b1010-4'b1101: Reserved<br>4'b1110: Faulting completing<br>4'b1111: Faulting                  |

**DMA\_CPC2**Address: Operational Base + offset (0x0114)

| Bit  | Attr | Reset Value | Description                                             |
|------|------|-------------|---------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | pc_chnl<br>Program counter for the DMA channel 2 thread |

**DMA\_CSR3**Address: Operational Base + offset (0x0118)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | RO   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                           |
| 21    | RO   | 0x0         | cns<br>1'b0: DMA channel operates in the Secure state<br>1'b1: DMA channel operates in the Non-secure state                                                                                                                                                                                                                                                        |
| 20:16 | RO   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                           |
| 15    | RO   | 0x0         | dmawfp_periph<br>1'b0: DMAWFP executed with the peripheral operand not set<br>1'b1: DMAWFP executed with the peripheral operand set                                                                                                                                                                                                                                |
| 14    | RO   | 0x0         | dmawfp_b_ns<br>1'b0: DMAWFP executed with the single operand set<br>1'b1: DMAWFP executed with the burst operand set                                                                                                                                                                                                                                               |
| 13:9  | RO   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                           |
| 8:4   | RO   | 0x00        | wakeup_number<br>indicate the event or peripheral number that the channel is waiting for:<br>5'b00000: DMA channel is waiting for event 0 or peripheral 0<br>5'b00001: DMA channel is waiting for event 1 or peripheral 1<br>5'b00010: DMA channel is waiting for event 2 or peripheral 2<br>...<br>5'b11111: DMA channel is waiting for event 31 or peripheral 31 |
| 3:0   | RO   | 0x0         | channel_status<br>4'b0000: Stopped<br>4'b0001: Executing<br>4'b0010: Cache miss<br>4'b0011: Updating PC<br>4'b0100: Waiting for event<br>4'b0101: At barrier<br>4'b0110: Reserved<br>4'b0111: Waiting for peripheral<br>4'b1000: Killing<br>4'b1001: Completing<br>4'b1010-4'b1101: Reserved<br>4'b1110: Faulting completing<br>4'b1111: Faulting                  |

**DMA\_CPC3**Address: Operational Base + offset (0x011c)

| Bit  | Attr | Reset Value | Description                                             |
|------|------|-------------|---------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | pc_chnl<br>Program counter for the DMA channel 3 thread |

**DMA\_CSR4**Address: Operational Base + offset (0x0120)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | RO   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                           |
| 21    | RO   | 0x0         | cns<br>1'b0: DMA channel operates in the Secure state<br>1'b1: DMA channel operates in the Non-secure state                                                                                                                                                                                                                                                        |
| 20:16 | RO   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                           |
| 15    | RO   | 0x0         | dmawfp_periph<br>1'b0: DMAWFP executed with the peripheral operand not set<br>1'b1: DMAWFP executed with the peripheral operand set                                                                                                                                                                                                                                |
| 14    | RO   | 0x0         | dmawfp_b_ns<br>1'b0: DMAWFP executed with the single operand set<br>1'b1: DMAWFP executed with the burst operand set                                                                                                                                                                                                                                               |
| 13:9  | RO   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                           |
| 8:4   | RO   | 0x00        | wakeup_number<br>indicate the event or peripheral number that the channel is waiting for:<br>5'b00000: DMA channel is waiting for event 0 or peripheral 0<br>5'b00001: DMA channel is waiting for event 1 or peripheral 1<br>5'b00010: DMA channel is waiting for event 2 or peripheral 2<br>...<br>5'b11111: DMA channel is waiting for event 31 or peripheral 31 |
| 3:0   | RO   | 0x0         | channel_status<br>4'b0000: Stopped<br>4'b0001: Executing<br>4'b0010: Cache miss<br>4'b0011: Updating PC<br>4'b0100: Waiting for event<br>4'b0101: At barrier<br>4'b0110: Reserved<br>4'b0111: Waiting for peripheral<br>4'b1000: Killing<br>4'b1001: Completing<br>4'b1010-4'b1101: Reserved<br>4'b1110: Faulting completing<br>4'b1111: Faulting                  |

**DMA\_CPC4**Address: Operational Base + offset (0x0124)

| Bit  | Attr | Reset Value | Description                                             |
|------|------|-------------|---------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | pc_chnl<br>Program counter for the DMA channel 4 thread |

**DMA\_CSR5**Address: Operational Base + offset (0x0128)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | RO   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                           |
| 21    | RO   | 0x0         | cns<br>1'b0: DMA channel operates in the Secure state<br>1'b1: DMA channel operates in the Non-secure state                                                                                                                                                                                                                                                        |
| 20:16 | RO   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                           |
| 15    | RO   | 0x0         | dmawfp_periph<br>1'b0: DMAWFP executed with the peripheral operand not set<br>1'b1: DMAWFP executed with the peripheral operand set                                                                                                                                                                                                                                |
| 14    | RO   | 0x0         | dmawfp_b_ns<br>1'b0: DMAWFP executed with the single operand set<br>1'b1: DMAWFP executed with the burst operand set                                                                                                                                                                                                                                               |
| 13:9  | RO   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                           |
| 8:4   | RO   | 0x00        | wakeup_number<br>indicate the event or peripheral number that the channel is waiting for:<br>5'b00000: DMA channel is waiting for event 0 or peripheral 0<br>5'b00001: DMA channel is waiting for event 1 or peripheral 1<br>5'b00010: DMA channel is waiting for event 2 or peripheral 2<br>...<br>5'b11111: DMA channel is waiting for event 31 or peripheral 31 |
| 3:0   | RO   | 0x0         | channel_status<br>4'b0000: Stopped<br>4'b0001: Executing<br>4'b0010: Cache miss<br>4'b0011: Updating PC<br>4'b0100: Waiting for event<br>4'b0101: At barrier<br>4'b0110: Reserved<br>4'b0111: Waiting for peripheral<br>4'b1000: Killing<br>4'b1001: Completing<br>4'b1010-4'b1101: Reserved<br>4'b1110: Faulting completing<br>4'b1111: Faulting                  |

**DMA\_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 |

**DMA\_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 peripheral operand not set<br>1'b1: DMAWFP executed with the peripheral operand set                                                                                                                                                                                                                                |
| 14         | RO          | 0x0                | dmawfp_b_ns<br>1'b0: DMAWFP executed with the single operand set<br>1'b1: DMAWFP executed with the burst operand set                                                                                                                                                                                                                                               |
| 13:9       | RO          | 0x0                | Reserved                                                                                                                                                                                                                                                                                                                                                           |
| 8:4        | RO          | 0x00               | wakeup_number<br>Indicate the event or peripheral number that the channel is waiting for:<br>5'b00000: DMA channel is waiting for event 0 or peripheral 0<br>5'b00001: DMA channel is waiting for event 1 or peripheral 1<br>5'b00010: DMA channel is waiting for event 2 or peripheral 2<br>...<br>5'b11111: DMA channel is waiting for event 31 or peripheral 31 |
| 3:0        | RO          | 0x0                | channel_status<br>4'b0000: Stopped<br>4'b0001: Executing<br>4'b0010: Cache miss<br>4'b0011: Updating PC<br>4'b0100: Waiting for event<br>4'b0101: At barrier<br>4'b0110: Reserved<br>4'b0111: Waiting for peripheral<br>4'b1000: Killing<br>4'b1001: Completing<br>4'b1010-4'b1101: Reserved<br>4'b1110: Faulting completing<br>4'b1111: Faulting                  |

**DMA\_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 |

**DMA\_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 peripheral operand not set<br>1'b1: DMAWFP executed with the peripheral operand set                                                                                                                                                                                                                                |
| 14         | RO          | 0x0                | dmawfp_b_ns<br>1'b0: DMAWFP executed with the single operand set<br>1'b1: DMAWFP executed with the burst operand set                                                                                                                                                                                                                                               |
| 13:9       | RO          | 0x0                | Reserved                                                                                                                                                                                                                                                                                                                                                           |
| 8:4        | RO          | 0x00               | wakeup_number<br>indicate the event or peripheral number that the channel is waiting for:<br>5'b00000: DMA channel is waiting for event 0 or peripheral 0<br>5'b00001: DMA channel is waiting for event 1 or peripheral 1<br>5'b00010: DMA channel is waiting for event 2 or peripheral 2<br>...<br>5'b11111: DMA channel is waiting for event 31 or peripheral 31 |
| 3:0        | RO          | 0x0                | channel_status<br>4'b0000: Stopped<br>4'b0001: Executing<br>4'b0010: Cache miss<br>4'b0011: Updating PC<br>4'b0100: Waiting for event<br>4'b0101: At barrier<br>4'b0110: Reserved<br>4'b0111: Waiting for peripheral<br>4'b1000: Killing<br>4'b1001: Completing<br>4'b1010-4'b1101: Reserved<br>4'b1110: Faulting completing<br>4'b1111: Faulting                  |

**DMA\_CPC7**Address: Operational Base + offset (0x013c)

| Bit  | Attr | Reset Value | Description                                             |
|------|------|-------------|---------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | pc_chnl<br>Program counter for the DMA channel 7 thread |

**DMA SAR0**Address: **Operational Base** + offset (0x0400)

| Bit  | Attr | Reset Value | Description                                              |
|------|------|-------------|----------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | src_addr<br>Address of the source data for DMA channel 0 |

**DMA DAR0**Address: **Operational Base** + offset (0x0404)

| Bit  | Attr | Reset Value | Description                                                   |
|------|------|-------------|---------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | dst_addr<br>Address of the destination data for DMA channel 0 |

**DMA CCR0**Address: **Operational Base** + offset (0x0408)

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

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21:18 | RO   | 0x0         | <p>dst_burst_len</p> <p>the destination data:</p> <p>4'b0000: 1 data transfer</p> <p>4'b0001: 2 data transfers</p> <p>4'b0010: 3 data transfers</p> <p>...</p> <p>4'b1111: 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'b000: Writes 1 byte per beat</p> <p>3'b001: Writes 2 bytes per beat</p> <p>3'b010: Writes 4 bytes per beat</p> <p>3'b011: Writes 8 bytes per beat</p> <p>3'b100: Writes 16 bytes per beat</p> <p>3'b101-3'b111: 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.</p> <p>1'b1: Incrementing-address burst. The DMAC signals AWBURST[0] HIGH.</p>                                                                                                                                                                                                                                                            |
| 13:11 | RO   | 0x0         | <p>src_cache_ctrl</p> <p>Bit [13]</p> <p>1'b0: ARCACHE[2] is LOW</p> <p>1'b1: ARCACHE[2] is HIGH</p> <p>Bit [12]</p> <p>1'b0: ARCACHE[1] is LOW</p> <p>1'b1: ARCACHE[1] is HIGH</p> <p>Bit [11]</p> <p>1'b0: ARCACHE[0] is LOW</p> <p>1'b1: ARCACHE[0] is HIGH</p>                                                                                                                                                      |
| 10:8  | RO   | 0x0         | <p>src_prot_ctrl</p> <p>Bit [10]</p> <p>1'b0: ARPROT[2] is LOW</p> <p>1'b1: ARPROT[2] is HIGH</p> <p>Bit [9]</p> <p>1'b0: ARPROT[1] is LOW</p> <p>1'b1: ARPROT[1] is HIGH</p> <p>Bit [8]</p> <p>1'b0: ARPROT[0] is LOW</p> <p>1'b1: ARPROT[0] is HIGH</p>                                                                                                                                                               |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                    |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4 | RO   | 0x0         | <p>src_burst_len<br/>4'b0000: 1 data transfer<br/>4'b0001: 2 data transfers<br/>4'b0010: 3 data transfers<br/>...<br/>4'b1111: 16 data transfers</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'b000: Reads 1 byte per beat<br/>3'b001: Reads 2 bytes per beat<br/>3'b010: Reads 4 bytes per beat<br/>3'b011: Reads 8 bytes per beat<br/>3'b100: Reads 16 bytes per beat<br/>3'b101-3'b111: Reserved</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>                                                                                                                                                                                                                                         |

**DMA LC0\_0**Address: Operational Base + offset (0x040c)

| Bit  | Attr | Reset Value | Description                                          |
|------|------|-------------|------------------------------------------------------|
| 31:8 | RO   | 0x0         | Reserved                                             |
| 7:0  | RO   | 0x00        | loop_counter_iterations<br>Loop counter 0 iterations |

**DMA LC1\_0**Address: Operational Base + offset (0x0410)

| Bit  | Attr | Reset Value | Description                                          |
|------|------|-------------|------------------------------------------------------|
| 31:8 | RO   | 0x0         | Reserved                                             |
| 7:0  | RO   | 0x00        | loop_counter_iterations<br>Loop counter 1 iterations |

**DMA SAR1**Address: Operational Base + offset (0x0420)

| Bit  | Attr | Reset Value | Description                                              |
|------|------|-------------|----------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | src_addr<br>Address of the source data for DMA channel 1 |

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

**DMA 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                                                                                                              |
| 21:18      | RO          | 0x0                | dst_burst_len<br>the destination data:<br>4'b0000: 1 data transfer<br>4'b0001: 2 data transfers<br>4'b0010: 3 data transfers<br>...<br>4'b1111: 16 data transfers<br>The total number of bytes that the DMAC writes out of the MFIFO when it executes a DMAST instruction is the product of dst_burst_len and dst_burst_size. |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17:15 | RO   | 0x0         | <p>dst_burst_size<br/>           3'b000: Writes 1 byte per beat<br/>           3'b001: Writes 2 bytes per beat<br/>           3'b010: Writes 4 bytes per beat<br/>           3'b011: Writes 8 bytes per beat<br/>           3'b100: Writes 16 bytes per beat<br/>           3'b101-3'b111: Reserved</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'b0000: 1 data transfer<br/>           4'b0001: 2 data transfers<br/>           4'b0010: 3 data transfers<br/>           ...<br/>           4'b1111: 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>                                                                                               |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:1 | RO   | 0x0         | <p>src_burst_size<br/>           3'b000: Reads 1 byte per beat<br/>           3'b001: Reads 2 bytes per beat<br/>           3'b010: Reads 4 bytes per beat<br/>           3'b011: Reads 8 bytes per beat<br/>           3'b100: Reads 16 bytes per beat<br/>           3'b101-3'b111: Reserved</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>                                                                                                                                                                                                                                                                                     |

**DMA LC0 1**Address: **Operational Base** + offset (0x042c)

| Bit  | Attr | Reset Value | Description                                                             |
|------|------|-------------|-------------------------------------------------------------------------|
| 31:8 | RO   | 0x0         | Reserved                                                                |
| 7:0  | RO   | 0x00        | <p>loop_counter_iterations<br/>           Loop counter 0 iterations</p> |

**DMA LC1 1**Address: **Operational Base** + offset (0x0430)

| Bit  | Attr | Reset Value | Description                                                             |
|------|------|-------------|-------------------------------------------------------------------------|
| 31:8 | RO   | 0x0         | Reserved                                                                |
| 7:0  | RO   | 0x00        | <p>loop_counter_iterations<br/>           Loop counter 1 iterations</p> |

**DMA SAR2**Address: **Operational Base** + offset (0x0440)

| Bit  | Attr | Reset Value | Description                                                                 |
|------|------|-------------|-----------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | <p>src_addr<br/>           Address of the source data for DMA channel 2</p> |

**DMA DAR2**Address: **Operational Base** + offset (0x0444)

| Bit  | Attr | Reset Value | Description                                                                      |
|------|------|-------------|----------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | <p>dst_addr<br/>           Address of the destination data for DMA channel 2</p> |

**DMA CCR2**Address: **Operational Base** + offset (0x0448)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | RO   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                 |
| 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'b0000: 1 data transfer<br/>4'b0001: 2 data transfers<br/>4'b0010: 3 data transfers<br/>...<br/>4'b1111: 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'b000: Writes 1 byte per beat<br/>3'b001: Writes 2 bytes per beat<br/>3'b010: Writes 4 bytes per beat<br/>3'b011: Writes 8 bytes per beat<br/>3'b100: Writes 16 bytes per beat<br/>3'b101-3'b111: Reserved</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>                                                                                                                                                                                                                                                |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:11 | RO   | 0x0         | <p>src_cache_ctrl</p> <p>Bit [13]</p> <p>1'b0: ARCACHE[2] is LOW</p> <p>1'b1: ARCACHE[2] is HIGH</p> <p>Bit [12]</p> <p>1'b0: ARCACHE[1] is LOW</p> <p>1'b1: ARCACHE[1] is HIGH</p> <p>Bit [11]</p> <p>1'b0: ARCACHE[0] is LOW</p> <p>1'b1: ARCACHE[0] is HIGH</p>                                                                                                                                               |
| 10:8  | RO   | 0x0         | <p>src_prot_ctrl</p> <p>Bit [10]</p> <p>1'b0: ARPROT[2] is LOW</p> <p>1'b1: ARPROT[2] is HIGH</p> <p>Bit [9]</p> <p>1'b0: ARPROT[1] is LOW</p> <p>1'b1: ARPROT[1] is HIGH</p> <p>Bit [8]</p> <p>1'b0: ARPROT[0] is LOW</p> <p>1'b1: ARPROT[0] is HIGH</p>                                                                                                                                                        |
| 7:4   | RO   | 0x0         | <p>src_burst_len</p> <p>4'b0000: 1 data transfer</p> <p>4'b0001: 2 data transfers</p> <p>4'b0010: 3 data transfers</p> <p>...</p> <p>4'b1111: 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</p> <p>3'b000: Reads 1 byte per beat</p> <p>3'b001: Reads 2 bytes per beat</p> <p>3'b010: Reads 4 bytes per beat</p> <p>3'b011: Reads 8 bytes per beat</p> <p>3'b100: Reads 16 bytes per beat</p> <p>3'b101-3'b111: 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</p> <p>1'b0: Fixed-address burst. The DMAC signals ARBURST[0] LOW.</p> <p>1'b1: Incrementing-address burst. The DMAC signals ARBURST[0] HIGH.</p>                                                                                                                                                                                                                                                     |

**DMA\_LC0\_2**

Address: **Operational Base** + offset (0x044c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:8       | RO          | 0x0                | Reserved                                             |
| 7:0        | RO          | 0x00               | loop_counter_iterations<br>Loop counter 0 iterations |

**DMA LC1\_2**Address: **Operational Base** + offset (0x0450)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:8       | RO          | 0x0                | Reserved                                             |
| 7:0        | RO          | 0x00               | loop_counter_iterations<br>Loop counter 1 iterations |

**DMA SAR3**Address: **Operational Base** + offset (0x0460)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | src_addr<br>Address of the source data for DMA channel 3 |

**DMA DAR3**Address: **Operational Base** + offset (0x0464)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | dst_addr<br>Address of the destination data for DMA channel 3 |

**DMA CCR3**Address: **Operational Base** + offset (0x0468)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | Reserved                                                                                                                                                                                                                |
| 27:25      | RO          | 0x0                | dst_cache_ctrl<br>Bit [27]<br>1'b0: AWCACHE[3] is LOW<br>1'b1: AWCACHE[3] is HIGH<br>Bit [26]<br>1'b0: AWCACHE[1] is LOW<br>1'b1: AWCACHE[1] is HIGH<br>Bit [25]<br>1'b0: AWCACHE[0] is LOW<br>1'b1: AWCACHE[0] is HIGH |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24:22 | RO   | 0x0         | <p>dst_prot_ctrl</p> <p>Bit [24]</p> <p>1'b0: AWPROT[2] is LOW</p> <p>1'b1: AWPROT[2] is HIGH</p> <p>Bit [23]</p> <p>1'b0: AWPROT[1] is LOW</p> <p>1'b1: AWPROT[1] is HIGH</p> <p>Bit [22]</p> <p>1'b0: AWPROT[0] is LOW</p> <p>1'b1: AWPROT[0] is HIGH</p>                                                                                                                                                             |
| 21:18 | RO   | 0x0         | <p>dst_burst_len</p> <p>the destination data:</p> <p>4'b0000: 1 data transfer</p> <p>4'b0001: 2 data transfers</p> <p>4'b0010: 3 data transfers</p> <p>...</p> <p>4'b1111: 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'b000: Writes 1 byte per beat</p> <p>3'b001: Writes 2 bytes per beat</p> <p>3'b010: Writes 4 bytes per beat</p> <p>3'b011: Writes 8 bytes per beat</p> <p>3'b100: Writes 16 bytes per beat</p> <p>3'b101-3'b111: 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.</p> <p>1'b1: Incrementing-address burst. The DMAC signals AWBURST[0] HIGH.</p>                                                                                                                                                                                                                                                            |
| 13:11 | RO   | 0x0         | <p>src_cache_ctrl</p> <p>Bit [13]</p> <p>1'b0: ARCACHE[2] is LOW</p> <p>1'b1: ARCACHE[2] is HIGH</p> <p>Bit [12]</p> <p>1'b0: ARCACHE[1] is LOW</p> <p>1'b1: ARCACHE[1] is HIGH</p> <p>Bit [11]</p> <p>1'b0: ARCACHE[0] is LOW</p> <p>1'b1: ARCACHE[0] is HIGH</p>                                                                                                                                                      |

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                   |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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'b0000: 1 data transfer<br>4'b0001: 2 data transfers<br>4'b0010: 3 data transfers<br>...<br>4'b1111: 16 data transfers<br>The total number of bytes that the DMAC 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'b000: Reads 1 byte per beat<br>3'b001: Reads 2 bytes per beat<br>3'b010: Reads 4 bytes per beat<br>3'b011: Reads 8 bytes per beat<br>3'b100: Reads 16 bytes per beat<br>3'b101-3'b111: Reserved<br>The total number of bytes that the DMAC reads into the MFIFO 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.                                                                                                                                                                                                                                 |

**DMA LC0\_3**Address: **Operational Base** + offset (0x046c)

| Bit  | Attr | Reset Value | Description                                          |
|------|------|-------------|------------------------------------------------------|
| 31:8 | RO   | 0x0         | Reserved                                             |
| 7:0  | RO   | 0x00        | loop_counter_iterations<br>Loop counter 0 iterations |

**DMA LC1\_3**Address: **Operational Base** + offset (0x0470)

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

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

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

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

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21:18 | RO   | 0x0         | <p>dst_burst_len</p> <p>the destination data:</p> <p>4'b0000: 1 data transfer</p> <p>4'b0001: 2 data transfers</p> <p>4'b0010: 3 data transfers</p> <p>...</p> <p>4'b1111: 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'b000: Writes 1 byte per beat</p> <p>3'b001: Writes 2 bytes per beat</p> <p>3'b010: Writes 4 bytes per beat</p> <p>3'b011: Writes 8 bytes per beat</p> <p>3'b100: Writes 16 bytes per beat</p> <p>3'b101-3'b111: 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.</p> <p>1'b1: Incrementing-address burst. The DMAC signals AWBURST[0] HIGH.</p>                                                                                                                                                                                                                                                            |
| 13:11 | RO   | 0x0         | <p>src_cache_ctrl</p> <p>Bit [13]</p> <p>1'b0: ARCACHE[2] is LOW</p> <p>1'b1: ARCACHE[2] is HIGH</p> <p>Bit [12]</p> <p>1'b0: ARCACHE[1] is LOW</p> <p>1'b1: ARCACHE[1] is HIGH</p> <p>Bit [11]</p> <p>1'b0: ARCACHE[0] is LOW</p> <p>1'b1: ARCACHE[0] is HIGH</p>                                                                                                                                                      |
| 10:8  | RO   | 0x0         | <p>src_prot_ctrl</p> <p>Bit [10]</p> <p>1'b0: ARPROT[2] is LOW</p> <p>1'b1: ARPROT[2] is HIGH</p> <p>Bit [9]</p> <p>1'b0: ARPROT[1] is LOW</p> <p>1'b1: ARPROT[1] is HIGH</p> <p>Bit [8]</p> <p>1'b0: ARPROT[0] is LOW</p> <p>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'b0000: 1 data transfer<br/>4'b0001: 2 data transfers<br/>4'b0010: 3 data transfers<br/>...<br/>4'b1111: 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'b000: Reads 1 byte per beat<br/>3'b001: Reads 2 bytes per beat<br/>3'b010: Reads 4 bytes per beat<br/>3'b011: Reads 8 bytes per beat<br/>3'b100: Reads 16 bytes per beat<br/>3'b101-3'b111: Reserved</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>                                                                                                                                                                                                                                         |

**DMA 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               | loop_counter_iterations<br>Loop counter 0 iterations |

**DMA 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               | loop_counter_iterations<br>Loop counter 1 iterations |

**DMA SAR5**Address: Operational Base + offset (0x04a0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                               |
|------------|-------------|--------------------|------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p>src_addr<br/>Address of the source data for DMA channel 5</p> |

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

**DMA 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'b0000: 1 data transfer<br>4'b0001: 2 data transfers<br>4'b0010: 3 data transfers<br>...<br>4'b1111: 16 data transfers<br>The total number of bytes that the DMAC writes out of the MFIFO when it executes a DMAST instruction is the product of dst_burst_len and dst_burst_size. |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17:15 | RO   | 0x0         | <p>dst_burst_size<br/>           3'b000: Writes 1 byte per beat<br/>           3'b001: Writes 2 bytes per beat<br/>           3'b010: Writes 4 bytes per beat<br/>           3'b011: Writes 8 bytes per beat<br/>           3'b100: Writes 16 bytes per beat<br/>           3'b101-3'b111: Reserved</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'b0000: 1 data transfer<br/>           4'b0001: 2 data transfers<br/>           4'b0010: 3 data transfers<br/>           ...<br/>           4'b1111: 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>                                                                                               |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:1 | RO   | 0x0         | <p>src_burst_size<br/>           3'b000: Reads 1 byte per beat<br/>           3'b001: Reads 2 bytes per beat<br/>           3'b010: Reads 4 bytes per beat<br/>           3'b011: Reads 8 bytes per beat<br/>           3'b100: Reads 16 bytes per beat<br/>           3'b101-3'b111: Reserved</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>                                                                                                                                                                                                                                                                                     |

**DMA LC0 5**Address: **Operational Base** + offset (0x04ac)

| Bit  | Attr | Reset Value | Description                                                             |
|------|------|-------------|-------------------------------------------------------------------------|
| 31:8 | RO   | 0x0         | Reserved                                                                |
| 7:0  | RO   | 0x00        | <p>loop_counter_iterations<br/>           Loop counter 0 iterations</p> |

**DMA LC1 5**Address: **Operational Base** + offset (0x04b0)

| Bit  | Attr | Reset Value | Description                                                             |
|------|------|-------------|-------------------------------------------------------------------------|
| 31:8 | RO   | 0x0         | Reserved                                                                |
| 7:0  | RO   | 0x00        | <p>loop_counter_iterations<br/>           Loop counter 1 iterations</p> |

**DMA SAR6**Address: **Operational Base** + offset (0x04c0)

| Bit  | Attr | Reset Value | Description                                                                 |
|------|------|-------------|-----------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | <p>src_addr<br/>           Address of the source data for DMA channel 6</p> |

**DMA DAR6**Address: **Operational Base** + offset (0x04c4)

| Bit  | Attr | Reset Value | Description                                                                      |
|------|------|-------------|----------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | <p>dst_addr<br/>           Address of the destination data for DMA channel 6</p> |

**DMA CCR6**Address: **Operational Base** + offset (0x04c8)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | RO   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                 |
| 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'b0000: 1 data transfer<br/>4'b0001: 2 data transfers<br/>4'b0010: 3 data transfers<br/>...<br/>4'b1111: 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'b000: Writes 1 byte per beat<br/>3'b001: Writes 2 bytes per beat<br/>3'b010: Writes 4 bytes per beat<br/>3'b011: Writes 8 bytes per beat<br/>3'b100: Writes 16 bytes per beat<br/>3'b101-3'b111: Reserved</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>                                                                                                                                                                                                                                                |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:11 | RO   | 0x0         | <p>src_cache_ctrl</p> <p>Bit [13]</p> <p>1'b0: ARCACHE[2] is LOW</p> <p>1'b1: ARCACHE[2] is HIGH</p> <p>Bit [12]</p> <p>1'b0: ARCACHE[1] is LOW</p> <p>1'b1: ARCACHE[1] is HIGH</p> <p>Bit [11]</p> <p>1'b0: ARCACHE[0] is LOW</p> <p>1'b1: ARCACHE[0] is HIGH</p>                                                                                                                                               |
| 10:8  | RO   | 0x0         | <p>src_prot_ctrl</p> <p>Bit [10]</p> <p>1'b0: ARPROT[2] is LOW</p> <p>1'b1: ARPROT[2] is HIGH</p> <p>Bit [9]</p> <p>1'b0: ARPROT[1] is LOW</p> <p>1'b1: ARPROT[1] is HIGH</p> <p>Bit [8]</p> <p>1'b0: ARPROT[0] is LOW</p> <p>1'b1: ARPROT[0] is HIGH</p>                                                                                                                                                        |
| 7:4   | RO   | 0x0         | <p>src_burst_len</p> <p>4'b0000: 1 data transfer</p> <p>4'b0001: 2 data transfers</p> <p>4'b0010: 3 data transfers</p> <p>...</p> <p>4'b1111: 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</p> <p>3'b000: Reads 1 byte per beat</p> <p>3'b001: Reads 2 bytes per beat</p> <p>3'b010: Reads 4 bytes per beat</p> <p>3'b011: Reads 8 bytes per beat</p> <p>3'b100: Reads 16 bytes per beat</p> <p>3'b101-3'b111: 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</p> <p>1'b0: Fixed-address burst. The DMAC signals ARBURST[0] LOW.</p> <p>1'b1: Incrementing-address burst. The DMAC signals ARBURST[0] HIGH.</p>                                                                                                                                                                                                                                                     |

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

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

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

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

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

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24:22 | RO   | 0x0         | <p>dst_prot_ctrl</p> <p>Bit [24]</p> <p>1'b0: AWPROT[2] is LOW</p> <p>1'b1: AWPROT[2] is HIGH</p> <p>Bit [23]</p> <p>1'b0: AWPROT[1] is LOW</p> <p>1'b1: AWPROT[1] is HIGH</p> <p>Bit [22]</p> <p>1'b0: AWPROT[0] is LOW</p> <p>1'b1: AWPROT[0] is HIGH</p>                                                                                                                                                             |
| 21:18 | RO   | 0x0         | <p>dst_burst_len</p> <p>the destination data:</p> <p>4'b0000: 1 data transfer</p> <p>4'b0001: 2 data transfers</p> <p>4'b0010: 3 data transfers</p> <p>...</p> <p>4'b1111: 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'b000: Writes 1 byte per beat</p> <p>3'b001: Writes 2 bytes per beat</p> <p>3'b010: Writes 4 bytes per beat</p> <p>3'b011: Writes 8 bytes per beat</p> <p>3'b100: Writes 16 bytes per beat</p> <p>3'b101-3'b111: 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.</p> <p>1'b1: Incrementing-address burst. The DMAC signals AWBURST[0] HIGH.</p>                                                                                                                                                                                                                                                            |
| 13:11 | RO   | 0x0         | <p>src_cache_ctrl</p> <p>Bit [13]</p> <p>1'b0: ARCACHE[2] is LOW</p> <p>1'b1: ARCACHE[2] is HIGH</p> <p>Bit [12]</p> <p>1'b0: ARCACHE[1] is LOW</p> <p>1'b1: ARCACHE[1] is HIGH</p> <p>Bit [11]</p> <p>1'b0: ARCACHE[0] is LOW</p> <p>1'b1: ARCACHE[0] is HIGH</p>                                                                                                                                                      |

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                   |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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'b0000: 1 data transfer<br>4'b0001: 2 data transfers<br>4'b0010: 3 data transfers<br>...<br>4'b1111: 16 data transfers<br>The total number of bytes that the DMAC 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'b000: Reads 1 byte per beat<br>3'b001: Reads 2 bytes per beat<br>3'b010: Reads 4 bytes per beat<br>3'b011: Reads 8 bytes per beat<br>3'b100: Reads 16 bytes per beat<br>3'b101-3'b111: Reserved<br>The total number of bytes that the DMAC reads into the MFIFO 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.                                                                                                                                                                                                                                 |

**DMA LC0\_7**Address: **Operational Base** + offset (0x04ec)

| Bit  | Attr | Reset Value | Description                                          |
|------|------|-------------|------------------------------------------------------|
| 31:8 | RO   | 0x0         | Reserved                                             |
| 7:0  | RO   | 0x00        | loop_counter_iterations<br>Loop counter 0 iterations |

**DMA LC1\_7**Address: **Operational Base** + offset (0x04f0)

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

**DMA\_DBGSTATUS**Address: **Operational Base** + offset (0x0d00)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                    |
|------------|-------------|--------------------|---------------------------------------|
| 31:1       | RO          | 0x0                | Reserved                              |
| 0          | RO          | 0x0                | dbgstatus<br>1'b0: Idle<br>1'b1: Busy |

**DMA\_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 DBGINST [1:0] Registers contain<br>2'b01: Reserved<br>2'b10: Reserved<br>2'b11: Reserved |

**DMA\_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                                                             |

**DMA\_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 |

**DMA\_CRO**Address: **Operational Base** + offset (0x0e00)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22      | RO          | 0x0                | Reserved                                                                                                                                                                                                  |
| 21:17      | RO          | 0x02               | num_events<br>5'b00000: 1 interrupt output, IRQ[0]<br>5'b00001: 2 interrupt outputs, IRQ[1:0]<br>5'b00010: 3 interrupt outputs, IRQ[2:0]<br>...<br>5'b11111: 32 interrupt outputs, IRQ[31:0]              |
| 16:12      | RO          | 0x07               | num_periph_req<br>5'b00000: 1 peripheral request interface<br>5'b00001: 2 peripheral request interfaces<br>5'b00010: 3 peripheral request interfaces<br>...<br>5'b11111: 32 peripheral request interfaces |
| 11:7       | RO          | 0x0                | Reserved                                                                                                                                                                                                  |
| 6:4        | RO          | 0x5                | num_chnls<br>3'b000: 1 DMA channel<br>3'b001: 2 DMA channels<br>3'b010: 3 DMA channels<br>...<br>3'b111: 8 DMA channels                                                                                   |
| 3          | RO          | 0x0                | Reserved                                                                                                                                                                                                  |
| 2          | RO          | 0x0                | 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               |

**DMA 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          | 0x5                | num_i_cache_lines<br>4'b0000: 1 i-cache line<br>4'b0001: 2 i-cache lines<br>4'b0010: 3 i-cache lines<br>...<br>4'b1111: 16 i-cache lines        |
| 3          | RO          | 0x0                | Reserved                                                                                                                                        |
| 2:0        | RO          | 0x7                | i_cache_len<br>3'b000-3'b001: Reserved<br>3'b010: 4 bytes<br>3'b011: 8 bytes<br>3'b100: 16 bytes<br>3'b101: 32 bytes<br>3'b110-3'b111: Reserved |

**DMA CR2**Address: **Operational Base** + offset (0x0e08)

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

**DMA CR3**Address: **Operational Base** + offset (0x0e0c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | ins<br>Bit [N]<br>1'b0: Assigns event<N> or IRQ[N] to the Secure state<br>1'b1: Assigns event<N> or IRQ[N] to the Non-secure state |

**DMA CR4**Address: **Operational Base** + offset (0x0e10)

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

**DMA 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          | 0x020              | <p>data_buffer_dep</p> <p>10'b0000000000: 1 line</p> <p>10'b0000000001: 2 lines</p> <p>...</p> <p>10'b1111111111: 1024 lines</p>                                    |
| 19:16      | RO          | 0x9                | <p>rd_q_dep</p> <p>4'b0000: 1 line</p> <p>4'b0001: 2 lines</p> <p>...</p> <p>4'b1111: 16 lines</p>                                                                  |
| 15         | RO          | 0x0                | Reserved                                                                                                                                                            |
| 14:12      | RO          | 0x4                | <p>rd_cap</p> <p>3'b000: 1</p> <p>3'b001: 2</p> <p>...</p> <p>3'b111: 8</p>                                                                                         |
| 11:8       | RO          | 0x7                | <p>wr_q_dep</p> <p>4'b0000: 1 line</p> <p>4'b0001: 2 lines</p> <p>...</p> <p>4'b1111: 16 lines</p>                                                                  |
| 7          | RO          | 0x0                | Reserved                                                                                                                                                            |
| 6:4        | RO          | 0x3                | <p>wr_cap</p> <p>3'b000: 1</p> <p>3'b001: 2</p> <p>...</p> <p>3'b111: 8</p>                                                                                         |
| 3          | RO          | 0x0                | Reserved                                                                                                                                                            |
| 2:0        | RO          | 0x3                | <p>data_width</p> <p>3'b000: Reserved</p> <p>3'b001: Reserved</p> <p>3'b010: 32-bit</p> <p>3'b011: 64-bit</p> <p>3'b100: 128-bit</p> <p>3'b101-3'b111: Reserved</p> |

**DMA 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                | <p>wd_irq_only</p> <p>1'b0: The DMAC aborts all of the contributing DMA channels and sets irq_abort HIGH</p> <p>1'b1: The DMAC sets irq_abort HIGH</p> |

## 8.5 Timing Diagram

Following figure shows the relationship between dma\_req and dma\_ack.



Fig. 8-3 DMAC request and acknowledge timing

## 8.6 Interface Description

### 8.6.1 DMAC boot interfaces

DMAC has the following tie-off signals. It can be configured by SGRF register. (Please refer to the chapter to find how to configure)

Table 8-3 DMAC0 boot interface

| Interface       | Reset value | Control source           |
|-----------------|-------------|--------------------------|
| boot_addr       | 0x0         | Tie 0                    |
| boot_from_pc    | 0x0         | Tie 0                    |
| boot_manager_ns | 0x1         | SGRF_DMAC0_CON3[0]       |
| boot_irq_ns     | 0xfffff     | SGRF_DMAC0_CON0[11:0]    |
| boot_periph_ns  | 0xfffff     | SGRF_DMAC_BUS_CON1[11:0] |

Table 8-4 DMAC1 boot interface

| Interface       | Reset value | Control source                                |
|-----------------|-------------|-----------------------------------------------|
| boot_addr       | 0x0         | Tie 0                                         |
| boot_from_pc    | 0x0         | Tie 0                                         |
| boot_manager_ns | 0x1         | SGRF_DMAC1_CON3[0]                            |
| boot_irq_ns     | 0xfffff     | SGRF_DMAC1_CON0[15:0]                         |
| boot_periph_ns  | 0xfffff     | {SGRF_DMAC1_CON2[3:0], SGRF_DMAC1_CON1[15:0]} |

#### **boot\_addr**

Configures the address location that contains the first instruction the DMAC executes, when it exits from reset.

#### **boot\_from\_pc**

Controls the location in which the DMAC executes its initial instruction, after it exits from reset:

1'b0: DMAC waits for an instruction from either APB interface

1'b1: DMA manager thread executes the instruction that is located at the address from boot\_addr

#### **boot\_manager\_ns**

When the DMAC exits from reset, this signal controls the security state of the DMA manager thread:

1'b0: Assigns DMA manager to the secure state

1'b1: 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: If boot\_irq\_ns[x] is low, the DMAC assigns event<x> or IRQ[x] to the secure state.

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

If boot\_periph\_ns[x] is low, the DMAC assigns peripheral request interface x to the secure state.

If boot\_periph\_ns[x] is high, the DMAC assigns peripheral request interface x to the non-secure state.

### **8.6.2 DMAC IRQ output configure**

Both DMAC0 and DMAC1 have 4 interrupt outputs, the details logic refer to the table below.

Table 8-5 DMAC interrupt interface

| Interface       | Signal logic                    | maskx source        |
|-----------------|---------------------------------|---------------------|
| DMAC0_IRQ       | dmac0_intr[5:0]                 |                     |
| DMAC0_MASK0_IRQ | ((~mask0[5:0])&dmac0_intr[5:0]) | GRF_SOC_CON38[5:0]  |
| DMAC0_MASK1_IRQ | ((~mask1[5:0])&dmac0_intr[5:0]) | GRF_SOC_CON38[13:8] |
| DMAC0_MASK2_IRQ | ((~mask2[5:0])&dmac0_intr[5:0]) | GRF_SOC_CON39[5:0]  |
| DMAC1_IRQ       | dmac1_intr[7:0]                 |                     |
| DMAC1_MASK0_IRQ | ((~mask0[7:0])&dmac1_intr[7:0]) | GRF_SOC_CON39[15:8] |
| DMAC1_MASK1_IRQ | ((~mask1[7:0])&dmac1_intr[7:0]) | GRF_SOC_CON40[7:0]  |
| DMAC1_MASK2_IRQ | ((~mask2[7:0])&dmac1_intr[7:0]) | GRF_SOC_CON40[15:8] |

### **8.6.3 DMAC peripheral request**

Some of the DMAC0/1 peripheral request interfaces are configurable for selecting different source.

Table 8-6 DMAC peripheral request

| Interface      | Signal logic             | Control source       |
|----------------|--------------------------|----------------------|
| DMAC0_CH0_REQ  | SPI0 TX/CAN0_RX/ASRC0_RX | GRF_SOC_CON42[1:0]   |
| DMAC0_CH1_REQ  | SPI0 RX/CAN1_RX/ASRC0_TX | GRF_SOC_CON42[3:2]   |
| DMAC0_CH2_REQ  | SPI1 TX/DSMC_TX/ASRC1_RX | GRF_SOC_CON42[5:4]   |
| DMAC0_CH3_REQ  | SPI1 RX/DSMC_RX/ASRC1_TX | GRF_SOC_CON42[7:6]   |
| DMAC0_CH4_REQ  | UART0 TX/CAN0_RX         | GRF_SOC_CON42[9:8]   |
| DMAC0_CH5_REQ  | UART0 RX/CAN1_RX/PDM_RX  | GRF_SOC_CON42[11:10] |
| DMAC0_CH6_REQ  | UART1 TX/SPDIF_TX        | GRF_SOC_CON42[13:12] |
| DMAC0_CH7_REQ  | UART1 RX/SPDIF_RX        | GRF_SOC_CON42[15:14] |
| DMAC0_CH8_REQ  | UART2 TX/DSMC_TX/SAI0_RX | GRF_SOC_CON43[1:0]   |
| DMAC0_CH9_REQ  | UART2 RX/SAI0_TX         | GRF_SOC_CON43[3:2]   |
| DMAC0_CH10_REQ | UART3 TX/DSMC_RX/SAI1_RX | GRF_SOC_CON43[5:4]   |
| DMAC0_CH11_REQ | UART3 RX/SAI1_TX         | GRF_SOC_CON43[7:6]   |
| DMAC1_CH10_REQ | SPDIF_TX/CAN0_RX         | GRF_SOC_CON43[9:8]   |
| DMAC1_CH11_REQ | SPDIF_RX/CAN1_RX         | GRF_SOC_CON43[11:10] |

## **8.7 Application Notes**

### **8.7.1 Using the APB slave interfaces**

You must ensure that you use the appropriate APB interface, depending on the security state in which the boot\_manager\_ns initializes the DMAC to operate. For example, if the DMAC is in the secure state, you must issue the instruction using the secure APB interface, otherwise the DMAC ignores the instruction. You can use the secure APB interface, or the non-secure APB interface, to start or restart a DMA channel when the DMAC is in the non-secure state.

The necessary steps to start a DMA channel thread using the debug instruction registers as following:

1. Create a program for the DMA channel.
2. Store the program in a region of system memory.
3. Poll the DBGSTATUS register to ensure that debug is idle, that is, the dbgstatus bit is 0.
4. Write to the 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 description. You must set these four bytes to the address of the first instruction in the program, which was written to system memory in step 2.
6. Writing zero to the DBGCMD Register. The DMAC starts the DMA channel thread and sets the dbgstatus bit to 1.

## **8.7.2 Security usage**

### **● DMA manager thread is in the secure state**

If the DNS bit is 0, the DMA manager thread operates in the secure state and it only performs secure instruction fetches. When a DMA manager thread in the secure state processes:

#### **DMAGO**

It uses the status of the ns bit, to set the security state of the DMA channel thread by writing to the CNS bit for that channel.

#### **DMAWFE**

It halts execution of the thread until the event occurs. When the event occurs, the DMAC continues execution of the thread, irrespective of the security state of the corresponding INS bit.

#### **DMASEV**

It sets the corresponding bit in the INT\_EVENT\_RIS Register, irrespective of the security state of the corresponding INS bit.

### **DMA manager thread is in the Non-secure state**

If the DNS bit is 1, the DMA manager thread operates in the non-secure state, and it only performs non-secure instruction fetches. When a DMA manager thread in the non-secure state processes:

#### **DMAGO**

The DMAC uses the status of the ns bit, to control if it starts a DMA channel thread.

If ns = 0, the DMAC does not start a DMA channel thread and instead it:

1. Executes a NOP.
2. Sets the FSRD Register, see Fault Status DMA Manager.
3. Sets the dmago\_err bit in the FTRD Register, see Fault Type DMA Manager Register.
4. Moves the DMA manager to the Faulting state.

If ns = 1, the DMAC starts a DMA channel thread in the non-secure state and programs the CNS bit to be non-secure.

#### **DMAWFE**

The DMAC uses the status of the corresponding INS bit, in the CR3 Register, to control if it waits for the event.

If INS = 0, the event is in the secure state. The DMAC:

1. Executes a NOP.
2. Sets the FSRD Register, see Fault Status DMA Manager Register.
3. Sets the mgr\_evnt\_err bit in the FTRD Register, see Fault Type DMA Manager Register.
4. Moves the DMA manager to the Faulting state.

If INS = 1, the event is in the Non-secure state. The DMAC halts execution of the thread and waits for the event to occur.

#### **DMASEV**

The DMAC uses the status of the corresponding INS bit, in the CR3 Register, to control if it creates the event-interrupt.

If INS = 0, the event-interrupt resource is in the secure state. The DMAC:

1. Executes a NOP.
2. Sets the FSRD Register, see Fault Status DMA Manager Register.
3. Sets the mgr\_evnt\_err bit in the FTRD Register, see Fault Type DMA Manager Register.

4. Moves the DMA manager to the Faulting state.

If INS = 1, the event-interrupt resource is in the Non-secure state. The DMAC creates the event-interrupt.

**DMA channel thread is in the secure state**

When the CNS bit is 0, the DMA channel thread is programmed to operate in the secure state and it only performs secure instruction fetches.

When a DMA channel thread in the secure state processes the following instructions:

**DMAWFE**

The DMAC halts execution of the thread until the event occurs. When the event occurs, the DMAC continues execution of the thread, irrespective of the security state of the corresponding INS bit, in the CR3 Register.

**DMASEV**

The DMAC creates the event-interrupt, irrespective of the security state of the corresponding INS bit, in the CR3 Register.

**DMAWFP**

The DMAC halts execution of the thread until the peripheral signals a DMA request. When this occurs, the DMAC continues execution of the thread, irrespective of the security state of the corresponding PNS bit, in the CR4 Register.

**DMALDP, DMASTP**

The DMAC sends a message to the peripheral to communicate that data transfer is complete, irrespective of the security state of the corresponding PNS bit, in the CR4 Register.

**DMAFLUSHP**

The DMAC clears the state of the peripheral and sends a message to the peripheral to resend its level status, irrespective of the security state of the corresponding PNS bit, in the CR4 Register.

When a DMA channel thread is in the secure state, it enables the DMAC to perform secure and non-secure AXI accesses.

**● DMA channel thread is in the Non-secure state**

When the CNS bit is 1, the DMA channel thread is programmed to operate in the non-secure state and it only performs non-secure instruction fetches.

When a DMA channel thread in the Non-secure state processes the following instructions:

**DMAWFE**

The DMAC uses the status of the corresponding INS bit, in the CR3 Register, to control if it waits for the event.

If INS = 0, the event is in the secure state. The DMAC:

1. Executes a NOP.
2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register.
3. Sets the ch\_evnt\_err bit in the FTRn Register, see Fault Type DMA Channel Registers.
4. Moves the DMA channel to the Faulting completing state.

If INS = 1, the event is in the non-secure state. The DMAC halts execution of the thread and waits for the event to occur.

**DMASEV**

The DMAC uses the status of the corresponding INS bit, in the CR3 Register, to control if it creates the event.

If INS = 0, the event-interrupt resource is in the Secure state. The DMAC:

1. Executes a NOP.
2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register.
3. Sets the ch\_evnt\_err bit in the FTRn Register, see Fault Type DMA Channel Registers.
4. Moves the DMA channel to the Faulting completing state.

If INS = 1, the event-interrupt resource is in the Non-secure state. The DMAC creates the event-interrupt.

**DMAWFP**

The DMAC uses the status of the corresponding PNS bit, in the CR4 Register, to control if it

waits for the peripheral to signal a request.

If PNS = 0, the peripheral is in the Secure state. The DMAC:

1. Executes a NOP.
2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register.
3. Sets the ch\_periph\_err bit in the FTRn Register, see Fault Type DMA Channel Registers.
4. Moves the DMA channel to the Faulting completing state.

If PNS = 1, the peripheral is in the Non-secure state. The DMAC halts execution of the thread and waits for the peripheral to signal a request.

#### **DMALDP, DMASTP**

The DMAC uses the status of the corresponding PNS bit, in the CR4 Register, to control if it sends an acknowledgement to the peripheral.

If PNS = 0, the peripheral is in the secure state. The DMAC:

1. Executes a NOP.
2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register.
3. Sets the ch\_periph\_err bit in the FTRn Register, see Fault Type DMA Channel Registers.
4. Moves the DMA channel to the Faulting completing state.

If PNS = 1, the peripheral is in the Non-secure state. The DMAC sends a message to the peripheral to communicate when the data transfer is complete.

#### **DMAFLUSHP**

The DMAC uses the status of the corresponding PNS bit, in the CR4 Register, to control if it sends a flush request to the peripheral.

If PNS = 0, the peripheral is in the secure state. The DMAC:

1. Executes a NOP.
2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register.
3. Sets the ch\_periph\_err bit in the FTRn Register, see Fault Type DMA Channel Registers.
4. Moves the DMA channel to the Faulting completing state.

If PNS = 1, the peripheral is in the Non-secure state. The DMAC clears the state of the peripheral and sends a message to the peripheral to resend its level status.

When a DMA channel thread is in the Non-secure state, and a DMAMOV CCR instruction attempts to program the channel to perform a secure AXI transaction, the DMAC:

1. Executes a DMANOP.
2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register.
3. Sets the ch\_rdwr\_err bit in the FTRn Register, see Fault Type DMA Channel Registers.
4. Moves the DMA channel thread to the Faulting completing state.

### **8.7.3 Programming restrictions**

#### **Fixed unaligned bursts**

The DMAC does not support fixed unaligned bursts. If you program the following conditions, the DMAC treats this as a programming error:

Unaligned read

- src\_inc field is 0 in the CCRn Register
- the SARn Register contains an address that is not aligned to the size of data that the src\_burst\_size field contain

Unaligned write

- dst\_inc field is 0 in the CCRn Register
- the DARn Register contains an address that is not aligned to the size of data that the dst\_burst\_size field contains

#### **Endian swap size restrictions**

If you program the endian\_swap\_size field in the CCRn Register, to enable a DMA channel to perform an endian swap then you must set the corresponding SARn Register and the corresponding DARn Register to contain an address that is aligned to the value that the endian\_swap\_size field contains.

#### **Updating DMA channel control registers during a DMA cycle restriction**

Prior to the DMAC executing a sequence of DMALD and DMAST instructions, the values you

program in to the CCRn Register, SARn Register, and DARn Register control the data byte lane manipulation that the DMAC performs when it transfers the data from the source address to the destination address. You'd better not update these registers during a DMA cycle.

### **Resource sharing between DMA channels**

DMA channel programs share the MFIFO data storage resource. You must not start a set of concurrently running DMA channel programs with a resource requirement that exceeds the configured size of the MFIFO. If you exceed this limit then the DMAC might lock up and generate a Watchdog abort.

### **8.7.4 Unaligned transfers may be corrupted**

For a configuration with more than one channel, if any of channels 1 to 7 is performing transfers between certain types of misaligned source and destination addresses, then the output data may be corrupted by the action of channel 0.

Data corruption might occur if all of the following are true:

1. Two beats of AXI read data are received for one of channels 1 to 7.
2. Source and destination address alignments mean that each read data beat is 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-330 do not split data in this way, so are NOT vulnerable to data corruption from this defect.

The following cases are not vulnerable to data corruption because they do not split data:

- Byte lane offset between source and destination addresses is 0 when source and destination addresses have the same byte lane alignment, the offset is 0 and a wrap operation that splits data cannot occur.
- Byte lane offset between source and destination addresses is a multiple of source size.

Table 8-7 Source size in CCRn

| <b>Source size in CCRn</b> | <b>Allowed offset between SARn and DARn</b> |
|----------------------------|---------------------------------------------|
| SS8                        | Any offset allowed.                         |
| SS16                       | 0,2,4,6,8,10,12,14                          |
| SS32                       | 0,4,8,12                                    |
| SS64                       | 0,8                                         |

### **8.7.5 Interrupt shares between channel**

As the DMAC does not record which channel (or list of channels) have asserted an interrupt. So it will depend on your program and whether any of the visible information for that program can be used to determine progress, and help identify the interrupt source.

There are 4 likely information sources that can be used to determine the progress made by a program:

- Program counter (PC)
- Source address
- Destination address
- Loop counters (LC)

For example, a program might emit an interrupt each time that it iterates around a loop. In this case, the interrupt service routine (ISR) would need to store the loop value of each channel when it is called, and then compare against the new value when it is next called. A change in value would indicate that the program has progressed.

The ISR must be carefully written to ensure that no interrupts are lost. The sequence of operations is as follows:

1. Disable interrupts

2. Immediately clear the interrupt in DMA-330
3. Check the relevant registers for both channels to determine which must be serviced
4. Take appropriate action for the channels
5. Re-enable interrupts and exit ISR

### **8.7.6 Instruction sets**

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

### **8.7.7 Assembler directives**

In this document, only DMMADNH instruction is took as an example to show the way the instruction assembled. For the other instructions, please refer to pl330\_trm.pdf.

#### **DMAADNH**

Add Negative Halfword adds an immediate negative 16-bit value to the SARn Register or DARn Register, for the DMA channel thread. This enables the DMAC to support 2D DMA operations, or reading or writing an area of memory in a different order to naturally incrementing addresses. See Source Address Registers and Destination Address Registers. The immediate unsigned 16-bit value is one-extended to 32 bits, to create a value that is the two's complement representation of a negative number between -65536 and -1, before the DMAC adds it to the address using 32-bit addition. The DMAC discards the carry bit so that addresses wrap from 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 8-9 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

SARn Register and sets ra to 0.

DAR

DARn Register and sets ra to 1.

<16-bit immediate>

The immediate value to be added to the <address\_register>.

You should specify the 16-bit immediate as the number that is to be represented in the instruction encoding. For example, DMAADNH DAR, 0xFFFF0 causes the value 0xFFFFFFFF0 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.

Rockchip Confidential

## Chapter 9 DMA2DDR

### 9.1 Overview

As an external memory, DDR plays an important role on SOC system. Testing DDR device, determine the DDR grain yield, to eliminate errors in data transmission is very important. Through this module mainly realize the DDR memory test, it still supports memory copy and eye diagram scanning function.

#### 9.1.1 Features

The DMA2DDR supports the following features:

- Support one DMA channel
- Embedded a 128 bitx16 data FIFO storage space for the memory copy of the data
- Support the Word, 2 Word, 4 Word data transmitted bits wide
- Support SINGLE, INCR4, INCR8, INCR16 four bus data transmission mode
- Support data transfer complete interrupt and error interrupt
- Support test data value configuration of X, the length of X is 16 word
- Support comparison data configuration, and comparison data location configurable
- Support three kinds of method of error data processing
  - Software trigger to complete data transmission
  - Direct terminate data transmission
  - Ignore error to complete data transmission
- Support test address increasing/decreasing configurations, require transport address burst length alignment
- Support seven test pattern configuration: WW mode, W2W mode, RR mode, RC mode, RC2RC mode, RCW mode and RW mode
- Support reporting after the interruption of fault data error address, error data and error byte/word counter

### 9.2 Architecture

This section describes the functions and behavior under various conditions.



Fig. 9-1 DMA2DDR architecture

#### 9.2.1 Block Diagram

The DMA2DDR comprises with:

- DMA2DDR register configuration block
- DMA2DDR engine block

- DMA2DDR FIFO block
- DMA2DDR sig\_sync block
- DMA2DDR axi\_master block

## 9.2.2 Block Descriptions

### DMA2DDR register configuration block

DMA2DDR register configuration block is used to configure the parameters of dma2ddr. This module includes all the registers which are necessary for dma2ddr working.

### DMA2DDR engine block

DMA2DDR engine block is the main block of DMA2DDR module. According to the configured message, this module makes the corresponding data processing which test needed, it has write, read and compare functions of data process.

### DMA2DDR FIFO block

The dma2ddr FIFO is used to store read data in RW mode, RC mode, RCW mode and RC2RC mode.

### DMA2DDR sig\_sync block

The sig\_sync block is used to handle the signals from different clock domains.

### DMA2DDR axi\_master block

The axi\_master block is used to implement the functions of the AXI master and communicate with engine block.

## 9.3 Register description

### 9.3.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

**Operational Base**

| Name                            | Base Address |
|---------------------------------|--------------|
| DMA2DDR secure base address     | 0x403A0000   |
| DMA2DDR non-secure base address | 0x503A0000   |

### 9.3.2 Registers Summary

| Name             | Offset | Size | Reset Value | Description                |
|------------------|--------|------|-------------|----------------------------|
| DMA2DDR_TMODE    | 0x0000 | W    | 0x00000000  | Test Mode Register         |
| DMA2DDR_TIADDR00 | 0x0004 | W    | 0x00000000  | Address Register 00        |
| DMA2DDR_TIADDR01 | 0x0008 | W    | 0x00000000  | Address Register 01        |
| DMA2DDR_TLENGTH0 | 0x000C | W    | 0x00000000  | Length Register 0          |
| DMA2DDR_TIADDR10 | 0x0014 | W    | 0x00000000  | Address Register 10        |
| DMA2DDR_TIADDR11 | 0x0018 | W    | 0x00000000  | Address Register 11        |
| DMA2DDR_TLENGTH1 | 0x001C | W    | 0x00000000  | Length Register 1          |
| DMA2DDR_WADDR0   | 0x0024 | W    | 0x00000000  | Write Address 0            |
| DMA2DDR_WADDR1   | 0x0028 | W    | 0x00000000  | Write Address 1            |
| DMA2DDR_TCTL     | 0x002C | W    | 0x00000000  | Control Register           |
| DMA2DDR_EDFLAG   | 0x0030 | W    | 0x00000000  | Error Location Register    |
| DMA2DDR_EDLOC    | 0x0034 | W    | 0x00000000  | Data Location Register     |
| DMA2DDR_EADDR0   | 0x0038 | W    | 0x00000000  | Current Address Register 0 |
| DMA2DDR_EADDR1   | 0x003C | W    | 0x00000000  | Current Address Register 1 |
| DMA2DDR_EDATA0   | 0x0040 | W    | 0x00000000  | Current Data Register 0    |
| DMA2DDR_EDATA1   | 0x0044 | W    | 0x00000000  | Current Data Register 1    |
| DMA2DDR_EDATA2   | 0x0048 | W    | 0x00000000  | Current Data Register 2    |

| Name              | Offset | Size | Reset Value | Description                 |
|-------------------|--------|------|-------------|-----------------------------|
| DMA2DDR_EDATA3    | 0x004C | W    | 0x00000000  | Current Data Register 3     |
| DMA2DDR_INTEN     | 0x0050 | W    | 0x00000000  | Interrupt Enable Register   |
| DMA2DDR_INTST     | 0x0054 | W    | 0x00000000  | Interrupt Status Register   |
| DMA2DDR_INTCL     | 0x0058 | W    | 0x00000000  | Interrupt Clear Register    |
| DMA2DDR_TSFT      | 0x005C | W    | 0x00000000  | Soft Trigger Register       |
| DMA2DDR_TDATA00   | 0x0060 | W    | 0x00000000  | Input Data Register 00      |
| DMA2DDR_TDATA01   | 0x0064 | W    | 0x00000000  | Input Data Register 01      |
| DMA2DDR_TDATA02   | 0x0068 | W    | 0x00000000  | Input Data Register 02      |
| DMA2DDR_TDATA03   | 0x006C | W    | 0x00000000  | Input Data Register 03      |
| DMA2DDR_TDATA10   | 0x0070 | W    | 0x00000000  | Input Data Register 10      |
| DMA2DDR_TDATA11   | 0x0074 | W    | 0x00000000  | Input Data Register 11      |
| DMA2DDR_TDATA12   | 0x0078 | W    | 0x00000000  | Input Data Register 12      |
| DMA2DDR_TDATA13   | 0x007C | W    | 0x00000000  | Input Data Register 13      |
| DMA2DDR_TDATA20   | 0x0080 | W    | 0x00000000  | Input Data Register 20      |
| DMA2DDR_TDATA21   | 0x0084 | W    | 0x00000000  | Input Data Register 21      |
| DMA2DDR_TDATA22   | 0x0088 | W    | 0x00000000  | Input Data Register 22      |
| DMA2DDR_TDATA23   | 0x008C | W    | 0x00000000  | Input Data Register 23      |
| DMA2DDR_TDATA30   | 0x0090 | W    | 0x00000000  | Input Data Register 30      |
| DMA2DDR_TDATA31   | 0x0094 | W    | 0x00000000  | Input Data Register 31      |
| DMA2DDR_TDATA32   | 0x0098 | W    | 0x00000000  | Input Data Register 32      |
| DMA2DDR_TDATA33   | 0x009C | W    | 0x00000000  | Input Data Register 33      |
| DMA2DDR_TRCDATA00 | 0x00A0 | W    | 0x00000000  | Background Data Register 00 |
| DMA2DDR_TRCDATA01 | 0x00A4 | W    | 0x00000000  | Background Data Register 01 |
| DMA2DDR_TRCDATA02 | 0x00A8 | W    | 0x00000000  | Background Data Register 02 |
| DMA2DDR_TRCDATA03 | 0x00AC | W    | 0x00000000  | Background Data Register 03 |
| DMA2DDR_TRCDATA10 | 0x00B0 | W    | 0x00000000  | Background Data Register 10 |
| DMA2DDR_TRCDATA11 | 0x00B4 | W    | 0x00000000  | Background Data Register 11 |
| DMA2DDR_TRCDATA12 | 0x00B8 | W    | 0x00000000  | Background Data Register 12 |
| DMA2DDR_TRCDATA13 | 0x00BC | W    | 0x00000000  | Background Data Register 13 |
| DMA2DDR_TRCDATA20 | 0x00C0 | W    | 0x00000000  | Background Data Register 20 |
| DMA2DDR_TRCDATA21 | 0x00C4 | W    | 0x00000000  | Background Data Register 21 |
| DMA2DDR_TRCDATA22 | 0x00C8 | W    | 0x00000000  | Background Data Register 22 |
| DMA2DDR_TRCDATA23 | 0x00CC | W    | 0x00000000  | Background Data Register 23 |
| DMA2DDR_TRCDATA30 | 0x00D0 | W    | 0x00000000  | Background Data Register 30 |
| DMA2DDR_TRCDATA31 | 0x00D4 | W    | 0x00000000  | Background Data Register 31 |
| DMA2DDR_TRCDATA32 | 0x00D8 | W    | 0x00000000  | Background Data Register 32 |
| DMA2DDR_TRCDATA33 | 0x00DC | W    | 0x00000000  | Background Data Register 33 |
| DMA2DDR_TDMAST    | 0x00E0 | W    | 0x00000000  | Status Register             |
| DMA2DDR_TEN       | 0x00E4 | W    | 0x00000000  | Enable Register             |
| DMA2DDR_EDBCNT    | 0x00E8 | W    | 0x00000000  | Data Byte Counter Register  |
| DMA2DDR_EDBFLAG   | 0x00EC | W    | 0x00000000  | Data Flag Register 0        |
| DMA2DDR_EWCNT     | 0x00F0 | W    | 0x00000000  | Data Word Counter Register  |
| DMA2DDR_EDWFLAG   | 0x00F4 | W    | 0x00000000  | Data Flag Register 1        |

| Name               | Offset | Size | Reset Value | Description                          |
|--------------------|--------|------|-------------|--------------------------------------|
| DMA2DDR TRCDATA00M | 0x00F8 | W    | 0x00000000  | Background Data Location Register 00 |
| DMA2DDR TRCDATA01M | 0x00FC | W    | 0x00000000  | Background Data Location Register 01 |
| DMA2DDR TRCDATA02M | 0x0100 | W    | 0x00000000  | Background Data Location Register 02 |
| DMA2DDR TRCDATA03M | 0x0104 | W    | 0x00000000  | Background Data Location Register 03 |
| DMA2DDR TRCDATA10M | 0x0108 | W    | 0x00000000  | Background Data Location Register 10 |
| DMA2DDR TRCDATA11M | 0x010C | W    | 0x00000000  | Background Data Location Register 11 |
| DMA2DDR TRCDATA12M | 0x0110 | W    | 0x00000000  | Background Data Location Register 12 |
| DMA2DDR TRCDATA13M | 0x0114 | W    | 0x00000000  | Background Data Location Register 13 |
| DMA2DDR TRCDATA20M | 0x0118 | W    | 0x00000000  | Background Data Location Register 20 |
| DMA2DDR TRCDATA21M | 0x011C | W    | 0x00000000  | Background Data Location Register 21 |
| DMA2DDR TRCDATA22M | 0x0120 | W    | 0x00000000  | Background Data Location Register 22 |
| DMA2DDR TRCDATA23M | 0x0124 | W    | 0x00000000  | Background Data Location Register 23 |
| DMA2DDR TRCDATA30M | 0x0128 | W    | 0x00000000  | Background Data Location Register 30 |
| DMA2DDR TRCDATA31M | 0x012C | W    | 0x00000000  | Background Data Location Register 31 |
| DMA2DDR TRCDATA32M | 0x0130 | W    | 0x00000000  | Background Data Location Register 32 |
| DMA2DDR TRCDATA33M | 0x0134 | W    | 0x00000000  | Background Data Location Register 33 |

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

Double WORD (64 bits) access

### 9.3.3 Detail Registers Description

#### DMA2DDR TMODE

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:3 | RO   | 0x00000000  | reserved    |

| Bit | Attr | Reset Value | Description                                                                                                                                                            |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0 | RW   | 0x0         | tmode<br>Test mode selection<br>3'b000: WW mode<br>3'b001: W2W mode<br>3'b010: RR mode<br>3'b011: RC mode<br>3'b100: RCW mode<br>3'b101: RW mode<br>3'b110: RC2RC mode |

**DMA2DDR TIADDR00**Address: **Operational Base** + offset (0x0004)

| Bit  | Attr | Reset Value | Description                                                                                      |
|------|------|-------------|--------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | iaddr00<br>Initial address0[31:0] for DMA2DDR test, this address is used for all the test modes. |

**DMA2DDR TIADDR01**Address: **Operational Base** + offset (0x0008)

| Bit  | Attr | Reset Value | Description                                                                                       |
|------|------|-------------|---------------------------------------------------------------------------------------------------|
| 31:3 | RO   | 0x00000000  | reserved                                                                                          |
| 2:0  | RW   | 0x0         | iaddr01<br>Initial address0[34:32] for DMA2DDR test, this address is used for all the test modes. |

**DMA2DDR TLENGTH0**Address: **Operational Base** + offset (0x000C)

| Bit  | Attr | Reset Value | Description                                                      |
|------|------|-------------|------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | tlengh0<br>The total test length for address0. The unit is word. |

**DMA2DDR TIADDR10**Address: **Operational Base** + offset (0x0014)

| Bit  | Attr | Reset Value | Description                                                                                                          |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | iaddr10<br>Initial address1[31:0] for DMA2DDR test, this address is just used for W2W mode, RC2RC mode and RCW mode. |

**DMA2DDR TIADDR11**Address: **Operational Base** + offset (0x0018)

| Bit  | Attr | Reset Value | Description                                                                                                           |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------|
| 31:3 | RO   | 0x00000000  | reserved                                                                                                              |
| 2:0  | RW   | 0x0         | iaddr11<br>Initial address1[34:32] for DMA2DDR test, this address is just used for W2W mode, RC2RC mode and RCW mode. |

**DMA2DDR\_TLENGTH1**Address: **Operational Base** + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | tlength1<br>The total test length for address1. The unit is word. |

**DMA2DDR\_WADDR0**Address: **Operational Base** + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | waddr0<br>Write address[31:0] for DMA2DDR test, this address is just used for RW mode. |

**DMA2DDR\_WADDR1**Address: **Operational Base** + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                                                |
| 2:0        | RW          | 0x0                | waddr1<br>Write address[34:32] for DMA2DDR test, this address is just used for RW mode. |

**DMA2DDR\_TCTL**Address: **Operational Base** + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                   |
| 30:7       | RW          | 0x0000000          | slen<br>The length of DMA2DDR single time. The unit is word.<br>This register should be configured in RC2RC/W2W/RCW mode.<br>When slen=0, it means the length equals burst length. Except for 0, the minimum value should be 2*BL*SIZE(BL is burst length which is from tburst, and SIZE is bus size which is from tsize). |
| 6:5        | RW          | 0x0                | edctrl<br>Error data deal method.<br>2'b00: Stop the transmission<br>2'b01: Wait the software trigger to continue the transmission<br>2'b10: Ignore error data until transmission done<br>This register should be configured in RC/RC2RC/RCW mode, indicate the deal method when error data detected.                      |
| 4          | RW          | 0x0                | torder<br>The order of address arrangement.<br>1'b0: Ascending order<br>1'b1: Descending order                                                                                                                                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:2        | RW          | 0x0                | tburst<br>Burst length of DMA2DDR in transfer.<br>2'b00: Single transfer<br>2'b01: Incremental 4 transfers<br>2'b10: Incremental 8 transfers<br>2'b11: Incremental 16 transfers |
| 1:0        | RW          | 0x0                | tsize<br>Byte size of DMA2DDR in transfer.<br>2'b00: 4(1Word)<br>2'b01: 8(2Word)<br>2'b10: 16(4Word)<br>2'b11: Reserved                                                         |

**DMA2DDR\_EDFLAG**Address: **Operational Base** + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 15:0       | RO          | 0x0000             | eflag<br>Indicate error data location in the burst.<br>16'h1: Error in the first beat in this burst<br>16'h2: Error in the second beat in this burst<br>16'h4: Error in the third beat in this burst<br>16'h8: Error in the fourth beat in this burst<br>16'h10: Error in the fifth beat in this burst<br>16'h20: Error in the sixth beat in this burst<br>16'h40: Error in the seventh beat in this burst<br>16'h80: Error in the eighth beat in this burst<br>16'h100: Error in the ninth beat in this burst<br>16'h200: Error in the tenth beat in this burst<br>16'h400: Error in the eleventh beat in this burst<br>16'h800: Error in the twelfth beat in this burst<br>16'h1000: Error in the thirteenth beat in this burst<br>16'h2000: Error in the fourteenth beat in this burst<br>16'h4000: Error in the fifteenth beat in this burst<br>16'h8000: Error in the sixteenth beat in this burst |

**DMA2DDR\_EDLOC**Address: **Operational Base** + offset (0x0034)

| <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       | RW          | 0x0000             | <p>edloc<br/>Configured beat location which the data you needed in burst.</p> <p>16'h1: Data location in the first beat in this burst<br/>16'h2: Data location in the second beat in this burst<br/>16'h4: Data location in the third beat in this burst<br/>16'h8: Data location in the fourth beat in this burst<br/>16'h10: Data location in the fifth beat in this burst<br/>16'h20: Data location in the sixth beat in this burst<br/>16'h40: Data location in the seventh beat in this burst<br/>16'h80: Data location in the eighth beat in this burst<br/>16'h100: Data location in the ninth beat in this burst<br/>16'h200: Data location in the tenth beat in this burst<br/>16'h400: Data location in the eleventh beat in this burst<br/>16'h800: Data location in the twelfth beat in this burst<br/>16'h1000: Data location in the thirteenth beat in this burst<br/>16'h2000: Data location in the fourteenth beat in this burst<br/>16'h4000: Data location in the fifteenth beat in this burst<br/>16'h8000: Data location in the sixteenth beat in this burst</p> |

**DMA2DDR\_EADDR0**Address: **Operational Base** + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | eaddr0<br>Current address[31:0] which data error detected. |

**DMA2DDR\_EADDR1**Address: **Operational Base** + offset (0x003C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                    |
| 2:0        | RO          | 0x0                | eaddr1<br>Current address[34:32] which data error detected. |

**DMA2DDR\_EDATA0**Address: **Operational Base** + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | edata0<br>Detected error data[31:0] situated in which DMA2DDR_EDLOC configured. |

**DMA2DDR\_EDATA1**Address: **Operational Base** + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | edata1<br>Detected error data[63:32] situated in which DMA2DDR_EDLOC configured. |

**DMA2DDR\_EDATA2**Address: **Operational Base** + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | edata2<br>Detected error data[95:64] situated in which DMA2DDR_EDLOC configured. |

**DMA2DDR\_EDATA3**Address: **Operational Base** + offset (0x004C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | edata3<br>Detected error data[127:96] situated in which DMA2DDR_EDLOC configured. |

**DMA2DDR\_INTEN**Address: **Operational Base** + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                                                                 |
| 2          | RW          | 0x0                | cpinten<br>Completed interrupt enable.<br>1'b0: Disable the interrupt<br>1'b1: Enable the interrupt      |
| 1          | RW          | 0x0                | reinten<br>Error response interrupt enable.<br>1'b0: Disable the interrupt<br>1'b1: Enable the interrupt |
| 0          | RW          | 0x0                | deinten<br>Data error interrupt enable.<br>1'b0: Disable the interrupt<br>1'b1: Enable the interrupt     |

**DMA2DDR\_INTST**Address: **Operational Base** + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                                                                |
| 2          | RO          | 0x0                | cpintst<br>Completed interrupt status.<br>1'b0: Interrupt is inactive<br>1'b1: Interrupt is active      |
| 1          | RO          | 0x0                | reintst<br>Error response interrupt status.<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>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 0          | RO          | 0x0                | deintst<br>Data error interrupt status.<br>1'b0: Interrupt is inactive<br>1'b1: Interrupt is active |

**DMA2DDR\_INTCL**Address: **Operational Base** + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                    |
| 2          | W1C         | 0x0                | cpintcl<br>Completed interrupt clear, write 1 clear 0.      |
| 1          | W1C         | 0x0                | reintcl<br>Error response interrupt clear, write 1 clear 0. |
| 0          | W1C         | 0x0                | deintcl<br>Data error interrupt clear, write 1 clear 0.     |

**DMA2DDR\_TSFT**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                | soften<br>Software trigger DMA2DDR working when data error interrupt happened.<br>1'b0: Software trigger enable<br>1'b1: Software trigger disable |

**DMA2DDR\_TDATA00**Address: **Operational Base** + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | tdata00<br>Input data0 bits [31:0] for DMA2DDR test in WW/W2W/RCW modes. |

**DMA2DDR\_TDATA01**Address: **Operational Base** + offset (0x0064)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | tdata01<br>Input data0 bits [63:32] for DMA2DDR test in WW/W2W/RCW modes. |

**DMA2DDR\_TDATA02**Address: **Operational Base** + offset (0x0068)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | tdata02<br>Input data0 bits [95:64] for DMA2DDR test in WW/W2W/RCW modes. |

**DMA2DDR TDATA03**Address: **Operational Base** + offset (0x006C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | tdata03<br>Input data0 bits [127:96] for DMA2DDR test in WW/W2W/RCW modes. |

**DMA2DDR TDATA10**Address: **Operational Base** + offset (0x0070)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | tdata10<br>Input data1 bits [31:0] for DMA2DDR test in WW/W2W/RCW modes. |

**DMA2DDR TDATA11**Address: **Operational Base** + offset (0x0074)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | tdata11<br>Input data1 bits [63:32] for DMA2DDR test in WW/W2W/RCW modes. |

**DMA2DDR TDATA12**Address: **Operational Base** + offset (0x0078)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | tdata12<br>Input data1 bits [95:64] for DMA2DDR test in WW/W2W/RCW modes. |

**DMA2DDR TDATA13**Address: **Operational Base** + offset (0x007C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | tdata13<br>Input data0 bits [127:96] for DMA2DDR test in WW/W2W/RCW modes. |

**DMA2DDR TDATA20**Address: **Operational Base** + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | tdata20<br>Input data2 bits [31:0] for DMA2DDR test in WW/W2W/RCW modes. |

**DMA2DDR\_TDATA21**Address: **Operational Base** + offset (0x0084)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | tdata21<br>Input data2 bits [63:32] for DMA2DDR test in WW/W2W/RCW modes. |

**DMA2DDR\_TDATA22**Address: **Operational Base** + offset (0x0088)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | tdata22<br>Input data2 bits [95:64] for DMA2DDR test in WW/W2W/RCW modes. |

**DMA2DDR\_TDATA23**Address: **Operational Base** + offset (0x008C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | tdata23<br>Input data2 bits [127:96] for DMA2DDR test in WW/W2W/RCW modes. |

**DMA2DDR\_TDATA30**Address: **Operational Base** + offset (0x0090)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | tdata30<br>Input data3 bits [31:0] for DMA2DDR test in WW/W2W/RCW modes. |

**DMA2DDR\_TDATA31**Address: **Operational Base** + offset (0x0094)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | tdata31<br>Input data3 bits [63:32] for DMA2DDR test in WW/W2W/RCW modes. |

**DMA2DDR\_TDATA32**Address: **Operational Base** + offset (0x0098)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | tdata32<br>Input data3 bits [95:64] for DMA2DDR test in WW/W2W/RCW modes. |

**DMA2DDR\_TDATA33**Address: **Operational Base** + offset (0x009C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | tdata33<br>Input data3 bits [127:96] for DMA2DDR test in WW/W2W/RCW modes. |

**DMA2DDR TRCDATA00**Address: **Operational Base** + offset (0x00A0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trcdata00<br>Background data0 bits [31:0] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA01**Address: **Operational Base** + offset (0x00A4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trcdata01<br>Background data0 bits [63:32] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA02**Address: **Operational Base** + offset (0x00A8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trcdata02<br>Background data0 bits [95:64] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA03**Address: **Operational Base** + offset (0x00AC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trcdata03<br>Background data0 bits [127:96] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA10**Address: **Operational Base** + offset (0x00B0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trcdata10<br>Background data1 bits [31:0] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA11**Address: **Operational Base** + offset (0x00B4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trcdata11<br>Background data1 bits [63:32] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA12**Address: **Operational Base** + offset (0x00B8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trCDATA12<br>Background data1 bits [95:64] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA13**Address: **Operational Base** + offset (0x00BC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trCDATA13<br>Background data0 bits [127:96] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA20**Address: **Operational Base** + offset (0x00C0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trCDATA20<br>Background data2 bits [31:0] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA21**Address: **Operational Base** + offset (0x00C4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trCDATA21<br>Background data2 bits [63:32] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA22**Address: **Operational Base** + offset (0x00C8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trCDATA22<br>Background data2 bits [95:64] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA23**Address: **Operational Base** + offset (0x00CC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trCDATA23<br>Background data2 bits [127:96] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA30**Address: **Operational Base** + offset (0x00D0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trcdata30<br>Background data3 bits [31:0] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA31**Address: **Operational Base** + offset (0x00D4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trcdata31<br>Background data3 bits [63:32] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA32**Address: **Operational Base** + offset (0x00D8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trcdata32<br>Background data3 bits [95:64] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA33**Address: **Operational Base** + offset (0x00DC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trcdata33<br>Background data3 bits [127:96] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TDMAST**Address: **Operational Base** + offset (0x00E0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                 |
| 0          | RO          | 0x0                | workst<br>DMA2DDR current work status.<br>1'b0: DMA2DDR is idle<br>1'b1: DMA2DDR is busy |

**DMA2DDR TEN**Address: **Operational Base** + offset (0x00E4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                                              |
| 0          | R/W SC      | 0x0                | ten<br>DMA2DDR work enable bit. This bit should be configurable at last.<br>It means all the DMA test registers has been configured.<br>1'b0: Disable<br>1'b1: Enable |

**DMA2DDR EDBCNT**

Address: **Operational Base** + offset (0x00E8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | ebcnt<br>Indicated error data byte count only when DMA2DDR_TCTL[6:5]=2'b10. |

**DMA2DDR\_EDBFLAG**Address: **Operational Base** + offset (0x00EC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                        |
| 15:0       | RO          | 0x0000             | lbfalg<br>Indicates data flag which right or wrong by byte unit when DMA2DDR_TCTL[6:5]=2'b10 in the whole transmission.<br>1'b1: Data is wrong in this byte<br>1'b0: Data is right in this byte |

**DMA2DDR\_EWCNT**Address: **Operational Base** + offset (0x00F0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | ewcnt<br>Indicated error data word count only when DMA2DDR_TCTL[6:5]=2'b10. |

**DMA2DDR\_EDWFLAG**Address: **Operational Base** + offset (0x00F4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 3:0        | RO          | 0x0                | lwflag<br>This register include two situation depends on DMA2DDR_TCTL[6]<br>1. DMA2DDR_TCTL[6]=1 Indicates data flag which right or wrong by word unit in the whole transmission.<br>2. DMA2DDR_TCTL[6]=0 Indicates data flag which right or wrong by word unit about current dma2ddr_edata0-dma2ddr_edata3, bit[0] mapping to dma2ddr_edata0, and so on.<br>1'b1: Data is wrong in this word.<br>1'b0: Data is right in this word. |

**DMA2DDR\_TRCDATA00M**Address: **Operational Base** + offset (0x00F8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trcdata00m<br>Background data0 read compare location enable bits [31:0] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR\_TRCDATA01M**Address: **Operational Base** + offset (0x00FC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trcdata01m<br>Background data0 read compare location enable bits [63:32] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA02M**Address: **Operational Base** + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trcdata02m<br>Background data0 read compare location enable bits [95:64] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA03M**Address: **Operational Base** + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trcdata03m<br>Background data0 read compare location enable bits [127:96] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA10M**Address: **Operational Base** + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trcdata10m<br>Background data1 read compare location enable bits [31:0] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA11M**Address: **Operational Base** + offset (0x010C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trcdata11m<br>Background data1 read compare location enable bits [63:32] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA12M**Address: **Operational Base** + offset (0x0110)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trcdata12m<br>Background data1 read compare location enable bits [95:64] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA13M**Address: **Operational Base** + offset (0x0114)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trcdata13m<br>Background data1 read compare location enable bits [127:96] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA20M**Address: **Operational Base** + offset (0x0118)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trCDATA20m<br>Background data2 read compare location enable bits [31:0] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA21M**Address: **Operational Base** + offset (0x011C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trCDATA21m<br>Background data2 read compare location enable bits [63:32] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA22M**Address: **Operational Base** + offset (0x0120)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trCDATA22m<br>Background data2 read compare location enable bits [95:64] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA23M**Address: **Operational Base** + offset (0x0124)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trCDATA23m<br>Background data2 read compare location enable bits [127:96] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA30M**Address: **Operational Base** + offset (0x0128)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trCDATA30m<br>Background data3 read compare location enable bits [31:0] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA31M**Address: **Operational Base** + offset (0x012C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trCDATA31m<br>Background data3 read compare location enable bits [63:32] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA32M**Address: **Operational Base** + offset (0x0130)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trcdata32m<br>Background data3 read compare location enable bits [95:64] for RC operation in RC2RC/RC/RCW modes. |

**DMA2DDR TRCDATA33M**Address: **Operational Base** + offset (0x0134)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | trcdata33m<br>Background data3 read compare location enable bits [127:96] for RC operation in RC2RC/RC/RCW modes. |

**9.4 Application Notes**

Register configuration should follow:

- (1) DMA2DDR\_TEN should be configured in the end.
- (2) When you use different test modes, the need for a particular configuration register is important, especially DMA2DDR\_TCTL register. Inappropriate configuration will lead to the transmission error, you can reference DMA2DDR instruction when using it in different test mode.

## Chapter 10 TIMER

### 10.1 Overview

TIMER is a programmable timer peripheral. It is usually used for generating a timing interrupt. There are two types of TIMER which are different in channel number. Both of them can be configured as a count-up or count-down timer.

TIMER supports the following features:

- Support two timer mode: free-running and user-defined
- Support two count mode: count-up and count-down
- Support configuration of loading count value
- Support mask interrupt

### 10.2 Block Diagram

Fig. 10-1 shows the block diagram of TIMER:



Fig. 10-1 TIMER Block Diagram

### 10.3 Function Description

#### 10.3.1 TIMER Clock

The frequency of counting clock is switched between 100MHz and 24MHz.

#### 10.3.2 Timer Mode

##### ● User-defined Count Mode

TIMER loads TIMER\_TIMERn\_LOAD\_COUNT1 and TIMER\_TIMERn\_LOAD\_COUNT0 registers (for count-down TIMER) or zero (for count-up TIMER) as initial value. When the TIMER counts down to 0 (for count-down TIMER) or counts up to the value in TIMER\_TIMERn\_LOAD\_COUNT1 and TIMER\_TIMERn\_LOAD\_COUNT0 (for count-up TIMER), it will not automatically reload the count value register. User need to disable timer firstly and follow the programming sequence to make timer work again.

##### ● Free-running Count Mode

TIMER loads the TIMER\_TIMERn\_LOAD\_COUNT1 and TIMER\_TIMERn\_LOAD\_COUNT0 (for count-down TIMER) or zero (for count-up TIMER) register as initial value. TIMER will automatically reload the count value register, when timer counts down to 0 (for count-down TIMER) or counts up to the value in TIMER\_TIMERn\_LOAD\_COUNT1 and

TIMER\_TIMERn\_LOAD\_COUNT0 (for count-up TIMER).

## 10.4 Register Description

### 10.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

| Operational Base |              |
|------------------|--------------|
| Name             | Base Address |
| TIMER0_CH0       | 0xff250000   |
| TIMER0_CH1       | 0xff251000   |
| TIMER0_CH2       | 0xff252000   |
| TIMER0_CH3       | 0xff253000   |
| TIMER0_CH4       | 0xff254000   |
| TIMER0_CH5       | 0xff255000   |
| TIMER1_CH0       | 0xff258000   |
| TIMER1_CH1       | 0xff259000   |
| TIMER1_CH2       | 0xff25a000   |
| TIMER1_CH3       | 0xff25b000   |
| TIMER1_CH4       | 0xff25c000   |
| TIMER1_CH5       | 0xff25d000   |

### 10.4.2 Registers Summary

| Name                              | Offset | Size | Reset Value | Description                                  |
|-----------------------------------|--------|------|-------------|----------------------------------------------|
| TIMER 6CH TIMERn LOAD COUNT0      | 0x0000 | W    | 0x00000000  | Low 32 bits value to be loaded into Timer0   |
| TIMER 6CH TIMERn LOAD COUNT1      | 0x0004 | W    | 0x00000000  | High 32 bits value to be loaded into Timer0. |
| TIMER 6CH TIMERn CURRENT VALUE0   | 0x0008 | W    | 0x00000000  | Low 32 bits of current value of Timer0.      |
| TIMER 6CH TIMERn CURRENT VALUE1   | 0x000C | W    | 0x00000000  | High 32 bits of current value of Timer0.     |
| TIMER 6CH TIMERn CONTROL          | 0x0010 | W    | 0x00000000  | Timer Control Register                       |
| TIMER 6CH TIMERn INTERRUPT STATUS | 0x0018 | W    | 0x00000000  | Timer Interrupt Status Register              |
| TIMER 6CH TIMERn Revision         | 0x001C | W    | 0x2AF60000  | Timer Version Register                       |

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

### 10.4.3 Detail Registers Description

#### TIMER 6CH TIMERn LOAD COUNT0

Address: **Operational Base** + offset (0x0000)

| Bit  | Attr | Reset Value | Description                   |
|------|------|-------------|-------------------------------|
| 31:0 | RW   | 0x00000000  | count0<br>Load count low bits |

#### TIMER 6CH TIMERn LOAD COUNT1

Address: **Operational Base** + offset (0x0004)

| Bit  | Attr | Reset Value | Description                    |
|------|------|-------------|--------------------------------|
| 31:0 | RW   | 0x00000000  | count1<br>Load count high bits |

#### TIMER 6CH TIMERn CURR VALUE0

Address: **Operational Base** + offset (0x0008)

| Bit  | Attr | Reset Value | Description                            |
|------|------|-------------|----------------------------------------|
| 31:0 | RW   | 0x00000000  | current_value0<br>Current_cnt_low bits |

**TIMER 6CH TIMERn CURR VALUE1**Address: **Operational Base** + offset (0x000C)

| Bit  | Attr | Reset Value | Description                             |
|------|------|-------------|-----------------------------------------|
| 31:0 | RW   | 0x00000000  | current_value1<br>Current_cnt_high bits |

**TIMER 6CH TIMERn CONTROL**Address: **Operational Base** + offset (0x0010)

| Bit  | Attr | Reset Value | Description                                                                          |
|------|------|-------------|--------------------------------------------------------------------------------------|
| 31:4 | RO   | 0x00000000  | reserved                                                                             |
| 3    | RW   | 0x0         | count_mode<br>Count mode<br>1'b0: Count up counter<br>1'b1: Count down counter       |
| 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 count mode |
| 0    | RW   | 0x0         | timer_en<br>Timer enable<br>1'b0: Disable<br>1'b1: Enable                            |

**TIMER 6CH TIMERn INTSTATUS**Address: **Operational Base** + offset (0x0018)

| Bit  | Attr | Reset Value | Description                                                                                                            |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x00000000  | reserved                                                                                                               |
| 0    | RW   | 0x0         | int_pd<br>This register contains the interrupt status for Timer.<br>Write 1 to this register will clear the interrupt. |

**TIMER 6CH TIMERn REVISION**Address: **Operational Base** + offset (0x001C)

| Bit   | Attr | Reset Value | Description                                                                                    |
|-------|------|-------------|------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x2af6      | svn_revision<br>SVN revision: 16'd10998.                                                       |
| 15:9  | RO   | 0x00        | reserved                                                                                       |
| 8     | RO   | 0x0         | ch_type<br>Indicate the timer count mode<br>1'b0: Count up counter<br>1'b1: Count down counter |
| 7:0   | RO   | 0x00        | reserved                                                                                       |

## 10.5 Application Notes

### 10.5.1 Clock and Reset

There are two different clock domain in TIMER: working clock and APB clock. The frequency of these clocks are as below:

Table 10-1 Clock Source and Frequency

| Module | Clock Name | Clock Source                                                                                            | Frequency    |
|--------|------------|---------------------------------------------------------------------------------------------------------|--------------|
| TIMER0 | clk_timer0 | xin_osc0_func/clk_gpll_div_100m /clk_deepslow/clk_core_pvtpll_logic/<br>sai0_mclk_io_in/sai0_sclk_io_in | 100M/24M/32K |
|        | clk_timer1 | xin_osc0_func/clk_gpll_div_100m /clk_deepslow/clk_core_pvtpll_logic/<br>sai1_mclk_io_in/sai1_sclk_io_in | 100M/24M/32K |
|        | clk_timer2 | xin_osc0_func/clk_gpll_div_100m /clk_deepslow/clk_core_pvtpll_logic/<br>sai2_mclk_io_in/sai2_sclk_io_in | 100M/24M/32K |
|        | clk_timer3 | xin_osc0_func/clk_gpll_div_100m /clk_deepslow/clk_core_pvtpll_logic/<br>sai3_mclk_io_in/sai3_sclk_io_in | 100M/24M/32K |
|        | clk_timer4 | xin_osc0_func/clk_gpll_div_100m /clk_deepslow/clk_core_pvtpll_logic/<br>mclk_asrc0                      | 100M/24M/32K |
|        | clk_timer5 | xin_osc0_func/clk_gpll_div_100m /clk_deepslow/clk_core_pvtpll_logic/<br>mclk_asrc1                      | 100M/24M/32K |
| TIMER1 | clk_timer0 | xin_osc0_func/clk_gpll_div_100m /clk_deepslow/clk_core_pvtpll_logic/<br>sai0_mclk_io_in/sai0_sclk_io_in | 100M/24M/32K |
|        | clk_timer1 | xin_osc0_func/clk_gpll_div_100m /clk_deepslow/clk_core_pvtpll_logic/<br>sai1_mclk_io_in/sai1_sclk_io_in | 100M/24M/32K |
|        | clk_timer2 | xin_osc0_func/clk_gpll_div_100m /clk_deepslow/clk_core_pvtpll_logic/<br>sai2_mclk_io_in/sai2_sclk_io_in | 100M/24M/32K |
|        | clk_timer3 | xin_osc0_func/clk_gpll_div_100m /clk_deepslow/clk_core_pvtpll_logic/<br>sai3_mclk_io_in/sai3_sclk_io_in | 100M/24M/32K |
|        | clk_timer4 | xin_osc0_func/clk_gpll_div_100m /clk_deepslow/clk_core_pvtpll_logic/<br>mclk_asrc0                      | 100M/24M/32K |
|        | clk_timer5 | xin_osc0_func/clk_gpll_div_100m /clk_deepslow/clk_core_pvtpll_logic/<br>mclk_asrc1                      | 100M/24M/32K |

Note that except for `xin_osc0_func/clk_gpll_div_100m/clk_deepslow`, the frequency of the other clock sources will change. Please refer to Chapter CRU for detail.  
When user disables the timer enables bit (bit 0 of `TIMER_TIMERn_CONTROL`), 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-configure registers when `timer_en` is low.



Fig. 10-2 Timing between timer\_en and timer\_clk

### 10.5.2 Programming Flow

1. Initialize the TIMER by the `TIMER_TIMERn_CONTROL` register:
  - (1) Disable the timer by writing a "0" to the timer enable bit (bit 0). Accordingly, the `timer_en` output signal is de-asserted.
  - (2) Program the timer mode—free-running or user-defined—by writing a "0" or "1" respectively, to the timer mode bit (bit 1).
  - (3) Program the counting mode—count-up or count-down—by writing a "0" or "1" respectively to the count mode bit (bit 3).
  - (4) Set the interrupt mask as either masked or not masked by writing a "0" or "1" respectively, to the timer interrupt mask bit (bit 2).
2. Load the timer count value into the `TIMER_TIMERn_LOAD_COUNT1` and `TIMER_TIMERn_LOAD_COUNT0` register.
3. Enable the TIMER by writing a "1" to bit 0 of `TIMER_TIMERn_CONTROL`.



Fig. 10-3 Timer Usage Flow

## Chapter 11 HPTIMER

### 11.1 Overview

HPTIMER is a programmable timer peripheral which has special calibration function. This component is an APB slave device, and can provide count value for CPU directly.

HPTIMER supports the following features:

- Support three timer mode: normal mode, hardware adjust mode and software adjust mode
- Support two counting mode at normal mode: free-running and user-defined
- Support configuration of loading count value at normal mode
- Support several mask interrupts at different timer mode
- Support calibrate back to exact count value without software calculation in hardware adjust mode
- Support calibrate back to exact count value with software-aided calculation in software adjust mode
- Support common multiple configuration of slow and fast clock period
- Support providing count value for CPU use

### 11.2 Block Diagram

The following figure shows the block diagram of HPTIMER:



Fig. 11-1 HPTIMER Block Diagram

#### Register Block(REG)

This block contains several registers which are used for timer configuration, status checking and interrupt generation.

#### High-Speed Counter(HS\_CNT)

This block contains two main counters which are working at high speed clock rate, one is used for record the current counter value that can update to CPU, the other is used to generate timing interrupt.

#### Low-Speed Counter(LS\_CNT)

This block also contains two main counters, the different is that these counters are working at low speed clock rate, one counter is used to record the current counter value at low power mode, the other one is used as a reference counter for anti-attack.

### 11.3 Function Description

#### 11.3.1 TIMER Clock

The clock frequency of clk\_32k is 32KHz, and the clock frequency of clk\_timer can be switched among 100MHz, 24MHz and 32KHz.

#### 11.3.2 Timer Mode

##### ● Normal Mode

At this mode, HPTIMER works as a normal incremental timer. After configuration of load count, interrupt enable, and control bit. The counter will counts from 0 to load count value step by step, and generate an interrupt when the counter value reaches the load count value. If the count mode is configured as free-running, then the counter will reload to zero,

after reaching the load count, and begin a new counting loop.

### ● Hardware Adjust Mode

At this mode, HPTIMER works as a special incremental timer with automatic calibration by hardware.

When system is working at normal mode, the counter in high clock domain(hs\_cnt) will count up normally. And the counter in low clock domain(ls\_cnt) will count plus T24\_GCD every T32\_GCD low clock period. Since that, the hs\_cnt and the ls\_cnt will represent the same counter value at every T32\_GCD low clock period.

When system enter low power mode, the clock frequency of hs\_cnt will also switch to low frequency, but thanks to the ls\_cnt, the counter value of current time will not lost. And after system recover from low power mode, the counter value of ls\_cnt will automatic calibrate to hs\_cnt.

### ● Software Adjust Mode

At this mode, HPTIMER works as a special incremental timer with calibration by software. Which means software can calibrate the counter value as you wish. The hardware will record the counter value when system enter to and recover from low power mode. And software should get this two begin and end counter values to calculate the lost time during the low power mode, and make a compensation to get the correct system time.

## 11.4 Register Description

### 11.4.1 Registers Summary

| Name                       | Offset | Size | Reset Value | Description                                       |
|----------------------------|--------|------|-------------|---------------------------------------------------|
| HPTIMER REVISION           | 0x0000 | W    | 0x2AF60201  | HPTIMER Version Register                          |
| HPTIMER CTRL               | 0x0004 | W    | 0x000000000 | HPTIMER Control Register                          |
| HPTIMER INTR EN            | 0x0008 | W    | 0x000000000 | Interrupt Mask Register                           |
| HPTIMER T24 GCD            | 0x000C | W    | 0x000000000 | Common Multiple Divide 24MHz                      |
| HPTIMER T32 GCD            | 0x0010 | W    | 0x000000000 | Common Multiple Divide 32KHz                      |
| HPTIMER LOAD COUNT0        | 0x0014 | W    | 0x000000000 | Low 32bits of load count value                    |
| HPTIMER LOAD COUNT1        | 0x0018 | W    | 0x000000000 | High 32bits of load count value                   |
| HPTIMER T24 DELAT CO UNT0  | 0x001C | W    | 0x000000000 | Low 32bits of 24MHz clock delay time count value  |
| HPTIMER T24 DELAT CO UNT1  | 0x0020 | W    | 0x000000000 | High 32bits of 24MHz clock delay time count value |
| HPTIMER CURR 32K VAL UE0   | 0x0024 | W    | 0x000000000 | Low 32bits of current ls_cnt value                |
| HPTIMER CURR 32K VAL UE1   | 0x0028 | W    | 0x000000000 | High 32bits of current ls_cnt value               |
| HPTIMER CURR TIMER V ALUE0 | 0x002C | W    | 0x000000000 | Low 32bits of current hs_cnt value                |
| HPTIMER CURR TIMER V ALUE1 | 0x0030 | W    | 0x000000000 | High 32bits of current hs_cnt value               |
| HPTIMER T24 32BEGIN0       | 0x0034 | W    | 0x000000000 | Low 32 bits of low power begin counter value      |
| HPTIMER T24 32BEGIN1       | 0x0038 | W    | 0x000000000 | High 32 bits of low power begin counter value     |
| HPTIMER T32 24END0         | 0x003C | W    | 0x000000000 | Low 32 bits of low power end counter value        |
| HPTIMER T32 24END1         | 0x0040 | W    | 0x000000000 | High 32 bits of low power end counter value       |
| HPTIMER RECORD VALUE VALID | 0x0044 | W    | 0x000000000 | Record count value valid                          |
| HPTIMER SYNC REQ           | 0x0048 | W    | 0x000000000 | Synchronize request control                       |
| HPTIMER INTR STATUS        | 0x004C | W    | 0x000000000 | Interrupt Status Register                         |

| Name                           | Offset | Size | Reset Value | Description                                                      |
|--------------------------------|--------|------|-------------|------------------------------------------------------------------|
| HPTIMER CURR ATATK 32K VALUE0  | 0x0054 | W    | 0x00000000  | Low 32bits of current ATATK counter value                        |
| HPTIMER CURR ATATK 32K VALUE1  | 0x0058 | W    | 0x00000000  | High 32bits of current ATATK counter value                       |
| HPTIMER LOAD COUNT0 32K        | 0x005C | W    | 0x00000000  | Low 32bits of load count 32k value                               |
| HPTIMER LOAD COUNT1 32K        | 0x0060 | W    | 0x00000000  | High 32bits of load count 32k value                              |
| HPTIMER CURR COMP H VALUE0     | 0x0064 | W    | 0x00000000  | Low 32bits of hs_cnt value when hardware synchronization enable  |
| HPTIMER CURR COMP H VALUE1     | 0x0068 | W    | 0x00000000  | High 32bits of hs_cnt value when hardware synchronization enable |
| HPTIMER CURR COMP L VALUE0     | 0x006C | W    | 0x00000000  | Low 32bits of ls_cnt value when hardware synchronization enable  |
| HPTIMER CURR COMP L VALUE1     | 0x0070 | W    | 0x00000000  | High 32bits of ls_cnt value when hardware synchronization enable |
| HPTIMER CURR COMP H 32K VALUE0 | 0x0074 | W    | 0x00000000  | Low 32bits of hs_cnt value when compensation enable              |
| HPTIMER CURR COMP H 32K VALUE1 | 0x0078 | W    | 0x00000000  | High 32bits of hs_cnt value when compensation enable             |
| HPTIMER CURR COMP L 32K VALUE0 | 0x007C | W    | 0x00000000  | Low 32bits of ls_cnt value when compensation enable              |
| HPTIMER CURR COMP L 32K VALUE1 | 0x0080 | W    | 0x00000000  | High 32bits of ls_cnt value when compensation enable             |

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

#### 11.4.2 Detail Registers Description

##### HPTIMER REVISION

Address: Operational Base(0xFF980000) + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                    |
|-------|------|-------------|--------------------------------------------------------------------------------|
| 31:16 | RO   | 0x2af6      | svn_revision<br>SVN revision<br>16'd10998                                      |
| 15:10 | RO   | 0x00        | reserved                                                                       |
| 9:8   | RO   | 0x2         | ch_type<br>Channel 0 is a low power recovery self-correction count up counter. |
| 7:0   | RO   | 0x01        | ip_function<br>IP function.<br>16'd1                                           |

##### HPTIMER CTRL

Address: Operational Base(0xFF980000) + offset (0x0004)

| Bit   | Attr | Reset Value | Description                                                                                                                                             |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_enable<br>Write enable of the lower 16bit<br>1'b0: Disable<br>1'b1: Enable                                                                        |
| 15:8  | RO   | 0x00        | reserved                                                                                                                                                |
| 7     | RW   | 0x0         | hs_cnt_auto_hold<br>Auto hold the hs_cnt at hard ware adjust mode when system enter low power mode<br>1'b0: Disable auto hold<br>1'b1: Enable auto hold |

| Bit | Attr | Reset Value | Description                                                                                                                                                   |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6   | RW   | 0x0         | hp_init_mode<br>Control the hs_cnt initial mode<br>1'b0: hs_cnt will begin count together with ls_cnt<br>1'b1: hs_cnt will not wait for ls_cnt                |
| 5   | RW   | 0x0         | extra_cnt_ctrl<br>Control the extra counter<br>1'b0: Disable<br>1'b1: Enable                                                                                  |
| 4   | RW   | 0x0         | atack_cnt_ctrl<br>Control the anti-attack counter<br>1'b0: Enable<br>1'b1: Disable                                                                            |
| 3   | RW   | 0x0         | count_mode<br>Timer count mode<br>1'b0: Free-running mode<br>1'b1: User-defined count mode                                                                    |
| 2:1 | RW   | 0x0         | timer_mode<br>Select timer as which timer mode<br>2'b00: Normal timer<br>2'b01: Adjust timer with hardware adjust<br>2'b10: Adjust timer with software adjust |
| 0   | RW   | 0x0         | timer_en<br>Timer enable<br>1'b0: Disable<br>1'b1: Enable                                                                                                     |

**HPTIMER INTR EN**

Address: Operational Base(0xFF980000) + offset (0x0008)

| Bit  | Attr | Reset Value | Description                                                                                                       |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------|
| 31:5 | RO   | 0x00000000  | reserved                                                                                                          |
| 4    | RW   | 0x0         | extra_count_reach_intr_en<br>Extra timer count reach load_count interrupt enable<br>1'b0: Disable<br>1'b1: Enable |
| 3    | RW   | 0x0         | count_reach_32k_intr_en<br>Low speed count reach interrupt enable<br>1'b0: Disable<br>1'b1: Enable                |
| 2    | RW   | 0x0         | sync_done_intr_en<br>Synchronization done interrupt enable<br>1'b0: Disable<br>1'b1: Enable                       |
| 1    | RO   | 0x0         | reserved                                                                                                          |
| 0    | RW   | 0x0         | count_reach_intr_en<br>High speed count reach load_count interrupt enable<br>1'b0: Disable<br>1'b1: Enable        |

**HPTIMER T24 GCD**

Address: Operational Base(0xFF980000) + offset (0x000C)

| Bit  | Attr | Reset Value | Description                                                                                                           |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | t24_gcd<br>The least common multiple of 24MHz (100MHz) and 32KHz clock cycles divided by 24MHz (100MHz) clock cycles. |

**HPTIMER T32 GCD**

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

| Bit  | Attr | Reset Value | Description                                                                                                  |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | t32_gcd<br>The least common multiple of 24MHz (100MHz) and 32KHz clock cycles divided by 32KHz clock cycles. |

**HPTIMER LOAD COUNT0**

Address: Operational Base(0xFF980000) + offset (0x0014)

| Bit  | Attr | Reset Value | Description                                    |
|------|------|-------------|------------------------------------------------|
| 31:0 | RW   | 0x00000000  | load_count0<br>Low 32bits of load count value. |

**HPTIMER LOAD COUNT1**

Address: Operational Base(0xFF980000) + offset (0x0018)

| Bit  | Attr | Reset Value | Description                                     |
|------|------|-------------|-------------------------------------------------|
| 31:0 | RW   | 0x00000000  | load_count1<br>High 32bits of load count value. |

**HPTIMER T24 DELAT COUNT0**

Address: Operational Base(0xFF980000) + offset (0x001C)

| Bit  | Attr | Reset Value | Description                                                                |
|------|------|-------------|----------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | t24_delay_time_count0<br>Low 32bits of 24MHz clock delay time count value. |

**HPTIMER T24 DELAT COUNT1**

Address: Operational Base(0xFF980000) + offset (0x0020)

| Bit  | Attr | Reset Value | Description                                                                 |
|------|------|-------------|-----------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | t24_delay_time_count1<br>High 32bits of 24MHz clock delay time count value. |

**HPTIMER CURR 32K VALUE0**

Address: Operational Base(0xFF980000) + offset (0x0024)

| Bit  | Attr | Reset Value | Description                                               |
|------|------|-------------|-----------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | current_32k_value0<br>Low 32bits of current ls_cnt value. |

**HPTIMER CURR 32K VALUE1**

Address: Operational Base(0xFF980000) + offset (0x0028)

| Bit  | Attr | Reset Value | Description                                                |
|------|------|-------------|------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | current_32k_value1<br>High 32bits of current ls_cnt value. |

**HPTIMER CURR TIMER VALUE0**

Address: Operational Base(0xFF980000) + offset (0x002C)

| Bit  | Attr | Reset Value | Description                                           |
|------|------|-------------|-------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | current_value0<br>Low 32bits of current hs_cnt value. |

**HPTIMER CURR TIMER VALUE1**

Address: Operational Base(0xFF980000) + offset (0x0030)

| Bit  | Attr | Reset Value | Description                                            |
|------|------|-------------|--------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | current_value1<br>High 32bits of current hs_cnt value. |

**HPTIMER T24 32BEGIN0**

Address: Operational Base(0xFF980000) + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | t24_32begin0<br>Low 32 bits of hs_cnt value when 24MHz (100MHz) clock switches to 32KHz clock. |

**HPTIMER T24\_32BEGIN1**

Address: Operational Base(0xFF980000) + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | t24_32begin1<br>High 32 bits of hs_cnt value when 24MHz (100MHz) clock switches to 32KHz clock. |

**HPTIMER T32\_24END0**

Address: Operational Base(0xFF980000) + offset (0x003C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | t32_24end0<br>Low 32 bits of hs_cnt value when 32KHz clock switches to 24MHz (100MHz) clock. |

**HPTIMER T32\_24END1**

Address: Operational Base(0xFF980000) + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | t32_24end1<br>High 32 bits of hs_cnt value when 32KHz clock switches to 24MHz (100MHz) clock. |

**HPTIMER RECORD VALUE VALID**

Address: Operational Base(0xFF980000) + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                 |
| 3          | W1 C        | 0x0                | curr_comp_value_32k_valid<br>CURR_COMP_*_32K_VALUE valid<br>1'b0: Invalid<br>1'b1: Valid |
| 2          | W1 C        | 0x0                | curr_comp_value_valid<br>CURR_COMP_*_VALUE valid<br>1'b0: Invalid<br>1'b1: Valid         |
| 1          | W1 C        | 0x0                | t32_24end_valid<br>T32_24END value valid<br>1'b0: Invalid<br>1'b1: Valid                 |
| 0          | W1 C        | 0x0                | t24_32begin_valid<br>T24_32BEGIN value valid<br>1'b0: Invalid<br>1'b1: Valid             |

**HPTIMER SYNC REQ**

Address: Operational Base(0xFF980000) + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable of the lower 16bit<br>1'b0: Disable<br>1'b1: Enable |
| 15:10      | RO          | 0x00               | reserved                                                                         |

| Bit | Attr   | Reset Value | Description                                                                                                                                                                                                                                                                                                    |
|-----|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9   | RW     | 0x0         | hw_sync_disable<br>1'b0: Enable synchronization<br>1'b1: Disable synchronization<br>When this bit is set to 1'b1, than no matter the value of hs_cnt and ls_cnt, the synchronization will not be executed.                                                                                                     |
| 8   | RW     | 0x0         | hw_sync_en<br>Control the sync logic of hs_cnt<br>1'b0: Disable<br>1'b1: Enable<br>When enable this bit, hardware will record the value of hs_cnt and ls_cnt at the time that a hw_sync_req occurs. And if the value of hs_cnt is larger than ls_cnt, then the synchronization to hs_cnt will not be executed. |
| 7   | RO     | 0x0         | reserved                                                                                                                                                                                                                                                                                                       |
| 6   | RW     | 0x0         | hw_sync_compensation_en<br>Enable the compensation to ls_cnt after a hw_sync_req occurs, the hardware will compare the value of hs_cnt and ls_cnt, if hs_cnt is larger than ls_cnt, then the different will be compensated to ls_cnt.<br>1'b0: Disable<br>1'b1: Enable                                         |
| 5   | RW     | 0x0         | low_power_compensation_en<br>Enable the compensation to ls_cnt at the time that system enter the low power state, the hardware will compare the value of hs_cnt and ls_cnt, if hs_cnt is larger than ls_cnt, then the different will be compensated to ls_cnt.<br>1'b0: Disable<br>1'b1: Enable                |
| 4   | RW     | 0x0         | compensation_en<br>Control the compensation logic of ls_cnt<br>1'b0: Disable<br>1'b1: Enable<br>When enable this bit, hardware will record the value of hs_cnt and ls_cnt at the time that system enter low power state.                                                                                       |
| 3:2 | RO     | 0x0         | reserved                                                                                                                                                                                                                                                                                                       |
| 1   | R/W SC | 0x0         | hw_sync_req<br>Hs_cnt synchronize request by hardware, which means synchronize hs_cnt by ls_cnt value                                                                                                                                                                                                          |
| 0   | R/W SC | 0x0         | sw_sync_req<br>Hs_cnt synchronize request by software, which means directly compensate T24_DELAT_COUNT to hs_cnt                                                                                                                                                                                               |

**HPTIMER INTR STATUS**

Address: Operational Base(0xFF980000) + offset (0x004C)

| Bit  | Attr | Reset Value | Description                                                                                               |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------|
| 31:5 | RO   | 0x00000000  | reserved                                                                                                  |
| 4    | W1 C | 0x0         | extra_count_reach<br>Extra cnt reach the load count value                                                 |
| 3    | W1 C | 0x0         | count_reach_32k<br>Ls_cnt counter value is more than load_count_32k-t24_gcd, and less than load_count_32k |
| 2    | W1 C | 0x0         | sync_done<br>hs_cnt synchronization done                                                                  |
| 1    | RO   | 0x0         | reserved                                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                           |
|------------|-------------|--------------------|--------------------------------------------------------------|
| 0          | W1<br>C     | 0x0                | count_reach<br>Normal counter: hs_cnt reach load_count value |

#### **HPTIMER CURR ATATK 32K VALUE0**

Address: Operational Base(0xFF980000) + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                               |
| 0          | RO          | 0x0                | current_atatk_32k_value0<br>Low 32bits of current atatk_cnt_32k value. |

#### **HPTIMER CURR ATATK 32K VALUE1**

Address: Operational Base(0xFF980000) + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                |
| 0          | RO          | 0x0                | current_atatk_32k_value1<br>High 32bits of current atatk_cnt_32k value. |

#### **HPTIMER LOAD COUNT0 32K**

Address: Operational Base(0xFF980000) + offset (0x005C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | load_count0_32k<br>Low 32bits of load count 32k value. |

#### **HPTIMER LOAD COUNT1 32K**

Address: Operational Base(0xFF980000) + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | load_count1_32k<br>High 32bits of load count 32k value. |

#### **HPTIMER CURR COMP H VALUE0**

Address: Operational Base(0xFF980000) + offset (0x0064)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | curr_comp_h_value0<br>Low 32bits of curr_comp_h_value, which indicate the record value of hs_cnt when a hw_sync_req occurs. |

#### **HPTIMER CURR COMP H VALUE1**

Address: Operational Base(0xFF980000) + offset (0x0068)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | curr_comp_h_value1<br>High 32bits of curr_comp_h_value, which indicate the record value of hs_cnt when a hw_sync_req occurs. |

#### **HPTIMER CURR COMP L VALUE0**

Address: Operational Base(0xFF980000) + offset (0x006C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | curr_comp_l_value0<br>Low 32bits of curr_comp_l_value, which indicate the record value of ls_cnt when a hw_sync_req occurs. |

#### **HPTIMER CURR COMP L VALUE1**

Address: Operational Base(0xFF980000) + offset (0x0070)

| Bit  | Attr | Reset Value | Description                                                                                                                  |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | curr_comp_l_value1<br>High 32bits of curr_comp_l_value, which indicate the record value of ls_cnt when a hw_sync_req occurs. |

**HPTIMER CURR COMP H 32K VALUE0**

Address: Operational Base(0xFF980000) + offset (0x0074)

| Bit  | Attr | Reset Value | Description                                                                                                                                     |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | curr_comp_h_32k_value0<br>Low 32bits of curr_comp_h_32k_value, which indicate the record value of hs_cnt when system enter the low power state. |

**HPTIMER CURR COMP H 32K VALUE1**

Address: Operational Base(0xFF980000) + offset (0x0078)

| Bit  | Attr | Reset Value | Description                                                                                                                                      |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | curr_comp_h_32k_value1<br>High 32bits of curr_comp_h_32k_value, which indicate the record value of hs_cnt when system enter the low power state. |

**HPTIMER CURR COMP L 32K VALUE0**

Address: Operational Base(0xFF980000) + offset (0x007C)

| Bit  | Attr | Reset Value | Description                                                                                                                                     |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | curr_comp_l_32k_value0<br>Low 32bits of curr_comp_l_32k_value, which indicate the record value of ls_cnt when system enter the low power state. |

**HPTIMER CURR COMP L 32K VALUE1**

Address: Operational Base(0xFF980000) + offset (0x0080)

| Bit  | Attr | Reset Value | Description                                                                                                                                      |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | curr_comp_l_32k_value1<br>High 32bits of curr_comp_l_32k_value, which indicate the record value of ls_cnt when system enter the low power state. |

## 11.5 Application Notes

### 11.5.1 Clock and Reset

There are two different clock domains in HPTIMER: clk\_timer, clk\_32k. The frequency of these clocks are as below:

Table 11-1 Clock Frequency

| Clock Name | Clock Source   |
|------------|----------------|
| clk_timer  | 100M/24M/32KHz |
| clk_32k    | 32KHz          |

The clock clk\_timer can switch to three different frequencies according to different mode. In normal working mode, HPTIMER is working at 100MHz or 24MHz, and the exact working frequency is depending on user needs. In low power mode, HPTIMER is working at 32K. hp\_sel is clock control bit to switch between 100MHz and 24MHz, which is related to CRU\_PMUCLKSEL\_CON0. And lp\_ena is clock control bit to switch between 100M/24MHz and 32KHz, which is related to PMU\_CRU\_PWR\_CON0[14].



Fig. 11-2 Clock Selection of clk\_timer

Please refer to chapter CRU and GRF for detail.

### 11.5.2 Programming Flow

- **Normal Mode**

1. Initialize the HPTIMER by the HPTIMER\_CTRL register:
  - (1) Disable the HPTIMER by writing a '0' to the timer enable bit (bit 0). Accordingly, the timer\_hp\_en output signal is de-asserted.
  - (2) Program the timer mode, normal mode by writing a 0x0 to the timer mode bits (bit 1 to bit 2).
  - (3) Program the count mode, free-running or user-defined by writing a '0' or '1' to the count mode bit (bit 3).
2. Load the HPTIMER count value into the HPTIMER\_LOAD\_COUNT1 and HPTIMER\_LOAD\_COUNT0 register.
3. Enable the HPTIMER by writing a '1' to bit 0 of HPTIMER\_CTRL.

If you want to do another count, repeat steps 1 to 3. These bits need to be written with the corresponding write enable bit in the higher 16 bits set to "1", as described in section 1.4.

- **Hardware Adjust Mode**

1. Initialize the HPTIMER by the HPTIMER\_CTRL register:
  - (1) Disable the HPTIMER by writing a '0' to the timer enable bit (bit 0). Accordingly, the timer\_hp\_en output signal is de-asserted.
  - (2) Program the timer mode, normal mode by writing a 0x1 to the timer mode bits (bit 1 to bit 2).
  - (3) Program the count mode, free-running or user-defined by writing a '0' or '1' to the count mode bit (bit 3).
2. Initialize the HPTIMER by the HPTIMER\_INTR\_STATUS register. Write 0x1d to HPTIMER\_INTR\_STATUS register to clear HPTIMER\_INTR\_STATUS register.
3. Configure the HPTIMER GCD register.
  - (1) Divide the least common multiple of clk\_timer and clk\_32k clock cycle by clk\_timer clock cycle and configure it in HPTIMER\_T24\_GCD register.
  - (2) Divide the least common multiple of clk\_timer and clk\_32k clock cycle by clk\_32k clock cycle and configure it in HPTIMER\_T32\_GCD register.
4. Enable the HPTIMER by writing a '1' to bit 0 of HPTIMER\_CTRL.
5. Configure the PMU\_CRU\_PWR\_CON0 to assert lp\_ena before the chip enters low power consumption mode.
6. The chip enters and exits the low power consumption mode at any time in between.
7. Configure the PMU\_CRU\_PWR\_CON0 to de-assert lp\_ena after the chip exits low power consumption mode.
8. Read out the INTR\_STATUS register until the sync\_done bit segment (bit 2) is '1', indicating that the HPTIMER count is adjusted.
9. Write 0x4 to HPTIMER\_INTR\_STATUS register to clear HPTIMER\_INTR\_STATUS register.

If the chip enters and exits the low power consumption mode again, repeat steps 6 to 9. Some bits need to be written with the corresponding write enable bit in the higher 16 bits set to "1", as described in section 1.4.

- **Software Adjust Mode**

1. Initialize the HPTIMER by the HPTIMER\_CTRL register:
  - (1) Disable the HPTIMER by writing a '0' to the timer enable bit (bit 0). Accordingly, the timer\_hp\_en output signal is de-asserted.

- (2) Program the timer mode, normal mode by writing a 0x2 to the timer mode bits (bit 1 to bit 2).
- (3) Program the count mode, free-running or user-defined by writing a '0' or '1' to the count mode bit (bit 3).
2. Initialize the HPTIMER by the HPTIMER\_INTR\_STATUS and BEGIN\_END\_VALID register. Write 0x1d to HPTIMER\_INTR\_STATUS register to clear HPTIMER\_INTR\_STATUS register. write 0x3 to RECORD\_VALUE\_VALID register to clear RECORD\_VALUE\_VALID register.
3. Enable the HPTIMER by writing a '1' to bit 0 of HPTIMER\_CTRL.
4. Configure the PMU0GRF to assert lp\_ena before the chip enters low power consumption mode.
5. The chip enters and exits the low power consumption mode at any time in between.
6. Configure the PMU0GRF to deassert lp\_ena after the chip exits low power consumption mode.
7. Read out RECORD\_VALUE\_VALID register until the value of it is 0x3, which indicates that the chip has entered and exited the low power consumption mode, then you can adjust the timer count value. Then write 0x3 to RECORD\_VALUE\_VALID register to clear the register.
8. The count value of HPTIMER compensation.
  - (1) Read out HPTIMER\_T24\_32BEGIN1, TIMER\_HP\_T24\_32BEGIN0, HPTIMER\_T32\_24END1 and HPTIMER\_T32\_24END0 register.
  - (2) configure HPTIMER\_T24\_DELAT\_COUNT1 and HPTIMER\_T24\_DELAT\_COUNT0 registers to compensate for the count values according to the values of these registers read out above.
  - (3) Write 0x1 to HPTIMER\_SYNC\_REQ register to start compensation counting.
  - (4) Read out the INTR\_STATUS register until the sync\_done bit segment (bit 2) is '1', indicating that the compensation count is completed.
9. Write 0x5 to HPTIMER\_INTR\_STATUS register to clear HPTIMER\_INTR\_STATUS register.

If the chip enters and exits the low power consumption mode again, repeat steps 5 to 8. Some bits need to be written with the corresponding write enable bit in the higher 16 bits set to "1", as described in section 1.4.

### ● **Hardware Compensation Configuration**

The hardware compensation configurations are all related to the HPTIMER\_SYNC\_REQ register.

1. When compensation\_en(bit 4) of HPTIMER\_SYNC\_REQ is asserted, then the hardware will record the value of hs\_cnt and ls\_cnt at the time that system enters low power mode, and the record value will be stored at HPTIMER\_CURR\_COMP\_\*\_32K\_VALUE.
2. When low\_power\_compensation\_en(bit 5) of HPTIMER\_SYNC\_REQ is asserted, then the hardware will compare the value of hs\_cnt and ls\_cnt at the time that system enters low power mode. And if hs\_cnt is greater than ls\_cnt at this time, the different will be compensated to ls\_cnt.
3. When hw\_sync\_compensation\_en(bit 6) of HPTIMER\_SYNC\_REQ is asserted, then the hardware will compare the value of hs\_cnt and ls\_cnt at the time that hardware synchronization occurs. And if hs\_cnt is larger than ls\_cnt at this time, the different will be compensated to ls\_cnt.
4. When hw\_sync\_en(bit 7) of TIMRE\_HP\_SYNC\_REQ is asserted, then the hardware will record the value of hs\_cnt and ls\_cnt at the time that hardware synchronization occurs, and the record value will be stored at HPTIMER\_CURR\_COMP\_\*\_VALUE. The other hand, if the value of hs\_cnt is greater than ls\_cnt, then the synchronization to hs\_cnt will not be executed.
5. When hw\_sync\_disable(bit 8) of HPTIMER\_SYNC\_REQ is asserted, then no matter the value of hs\_cnt and ls\_cnt, the synchronization will not be executed.

### ● **Low Power Mode Wakeup**

This function is used at hardware adjust mode, the programing flow is mainly as hardware adjust mode.

1. Configure HPTIMER to hardware adjust mode.

2. Configure the HPTIMER GCD register.
3. Enable the HPTIMER by writing a '1' to bit 0 of HPTIMER\_CTRL.
4. Prepare to enter low power mode:
  - (1) Configure PMU to set HPTIMER as wake up source.
  - (2) Configure the bit 3 of HPTIMER\_INTR\_EN to set count reach interrupt enable at 32K.
  - (3) Configure the HPTIMER\_LOAD\_COUNT1\_32K and HPTIMER\_LOAD\_COUNT0\_32K to set the wake up time. (note that user must configure HPTIMER\_LOAD\_COUNT0\_32K at last)
5. Configure the PMU0GRF to assert lp\_ena before the chip enters low power consumption mode.
6. Wait for HPTIMER to wake up system.
7. Configure the PMU0GRF to de-assert lp\_ena after the chip exits low power consumption mode.
8. Read out the INTR\_STATUS register and write 0x8 to HPTIMER\_INTR\_STATUS register to clear count reach 32k interrupt.
9. Read out the INTR\_STATUS register until the sync\_done bit segment (bit 2) is '1', indicating that the HPTIMER count is adjusted.
10. Write 0x4 to HPTIMER\_INTR\_STATUS register to clear HPTIMER\_INTR\_STATUS register.

If the chip enters and exits the low power consumption mode again, repeat steps 4 to 10.

#### ● **High Performance Timing Interrupt**

HPTIMER provides a 32-bits High performance counter to generate timing interrupt at hardware adjust mode.

1. Configure HPTIMER to hardware adjust mode.
2. Configure the HPTIMER\_LOAD\_COUNT0 to set the load count.
3. Configure bit 4 of HPTIMER\_INTR\_EN to enable interrupt.
4. Configure bit 5 of HPTIMER\_CTRL to enable the hyper performance counter to work.
5. Wait for the interrupt generate.
6. Write '1' to bit 4 of HPTIMER\_INTR\_STATUS to clear the interrupt status.

When the count mode of timer is configured to free-running, then the interrupt will assert every load count time, otherwise the interrupt will generate only one time.

## Chapter 12 Watchdog Timer (WDT)

### 12.1 Overview

Watchdog Timer (WDT) is an APB slave peripheral that can be used to prevent system lockup that caused by conflicting parts or programs in a SOC. The WDT would generate interrupt or reset signal when its counter reaches zero, then a reset controller would reset the system.

WDT supports the following features:

- 32 bits APB bus width
- WDT counter's clock can be chosen from 24MHz or 32KHz clock
- 32 bits WDT counter width
- Counter counts down from a preset value to 0 to indicate the occurrence of a timeout
- WDT can perform two types of operations when timeout occurs:
  - Generate a system reset
  - First generate an interrupt and if this is not cleared by the service routine by the time a second timeout occurs then generate a system reset
- Programmable reset pulse length
- Total 16 defined ranges of main timeout period
- There are 2 WDTs: WDT0/1
- All the 2 WDTs can drive CRU to generate global software reset

### 12.2 Block Diagram



Fig. 12-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.

### 12.3 Function Description

#### 12.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 APB clock 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.

### 12.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. 12-2 WDT Operation Flow (RMOD=1)

## 12.4 Register Description

### 12.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

| Operational Base |              |
|------------------|--------------|
| Name             | Base Address |
| WDT0             | 0xFF260000   |
| WDT1             | 0xFF268000   |

## 12.4.2 Registers Summary

| Name     | Offset | Size | Reset Value | Description                    |
|----------|--------|------|-------------|--------------------------------|
| WDT CR   | 0x0000 | W    | 0x00000008  | Control Register               |
| WDT TORR | 0x0004 | W    | 0x00000000  | Timeout Range Register         |
| WDT CCVR | 0x0008 | W    | 0x0000FFFF  | Current Counter Value Register |
| 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, **DW**- Double WORD (64 bits) access

## 12.4.3 Detail Registers Description

### WDT CR

Address: **Operational Base** + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | RO   | 0x00000000  | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 4:2  | RW   | 0x2         | <p>rst_pluse_length<br/>           This is used to select the number of APB clock cycles for which the system reset stays asserted.<br/>           3'b000: 2 pclk cycles<br/>           3'b001: 4 pclk cycles<br/>           3'b010: 8 pclk cycles<br/>           3'b011: 16 pclk cycles<br/>           3'b100: 32 pclk cycles<br/>           3'b101: 64 pclk cycles<br/>           3'b110: 128 pclk cycles<br/>           3'b111: 256 pclk cycles</p> |
| 1    | RW   | 0x0         | <p>resp_mode<br/>           Selects the output response generated to a timeout.<br/>           1'b0: Generate a system reset.<br/>           1'b1: First generate an interrupt and if it is not cleared by the time a second timeout occurs then generate a system reset.</p>                                                                                                                                                                          |
| 0    | RW   | 0x0         | <p>en<br/>           This bit is used to enable and disable the WDT. When disabled, the counter does not decrement. Thus, no interrupt or system reset are generated. Once this bit has been enabled, it can be cleared only by a system reset.<br/>           1'b0: WDT disabled.<br/>           1'b1: WDT enabled.</p>                                                                                                                               |

### WDT TORR

Address: **Operational Base** + offset (0x0004)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | RO   | 0x00000000  | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 3:0  | RW   | 0x0         | <p>timeout_period<br/>           This field is used to select the timeout period from which the watchdog counter restarts. A change of the timeout period takes effect only after the next counter restart (kick).<br/>           The range of values available for a 32-bit watchdog counter are:<br/>           4'b0000: 0x0000ffff<br/>           4'b0001: 0x0001ffff<br/>           4'b0010: 0x0003ffff<br/>           4'b0011: 0x0007ffff<br/>           4'b0100: 0x000fffff<br/>           4'b0101: 0x001fffff<br/>           4'b0110: 0x003fffff</p> |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                             |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 4'b0111: 0x007fffff<br>4'b1000: 0x00fffff<br>4'b1001: 0x01fffff<br>4'b1010: 0x03fffff<br>4'b1011: 0x07fffff<br>4'b1100: 0x0fffffff<br>4'b1101: 0x1fffffff<br>4'b1110: 0x3fffffff<br>4'b1111: 0x7fffffff |

**WDT\_CCVR**Address: **Operational Base** + offset (0x0008)

| Bit  | Attr | Reset Value | Description                                                                                                                           |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x0000ffff  | cur_cnt<br>This register, when read, is the current value of the internal counter. This value is read coherently whenever it is read. |

**WDT\_CRR**Address: **Operational Base** + offset (0x000C)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                       |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0000000   | reserved                                                                                                                                                                                                                          |
| 7:0  | WO   | 0x00        | cnt_restart<br>This register is used to restart the WDT counter. As a safety feature to prevent accidental restarts, the value 0x76 must be written. A restart also clears the WDT interrupt. Reading this register returns zero. |

**WDT\_STAT**Address: **Operational Base** + offset (0x0010)

| Bit  | Attr | Reset Value | Description                                                                                                                                         |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x00000000  | reserved                                                                                                                                            |
| 0    | RO   | 0x0         | status<br>This register shows the interrupt status of the WDT.<br>1'b1: Interrupt is active regardless of polarity.<br>1'b0: Interrupt is inactive. |

**WDT\_EOI**Address: **Operational Base** + offset (0x0014)

| Bit  | Attr | Reset Value | Description                                                                                 |
|------|------|-------------|---------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x00000000  | reserved                                                                                    |
| 0    | RO   | 0x0         | int_clr<br>This can be used to clear the interrupt without restarting the watchdog counter. |

## Chapter 13 Mailbox

### 13.1 Overview

The Mailbox module is a simple APB peripheral that allows MCU and CPU 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 4 mailbox groups, each group includes one data word, one command word register and one flag bit that can represent one interrupt
- Support interrupts to MCU and CPU
- Support two type of interrupt: TX done and RX done
- Support two trigger mode for TX done interrupt

### 13.2 Block Diagram



Fig. 13-1 Mailbox Block Diagram

### 13.3 Function Description

#### 13.3.1 TX Done Interrupt

- Regard CPU as the “AP” side of the Mailbox. The 4 groups TX done interrupt to CPU is:
  - Enabled when MAILBOX\_B2A\_INTEN.b2a\_tx\_done\_inten is set to 1 and the corresponding IRQ is enabled in GIC of CPU.
  - Generated when
    - there are writing operation to corresponding MAILBOX\_B2A\_CMD\_i and MAILBOX\_B2A\_DAT\_i orderly in normal mode.
    - there are writing operation to corresponding MAILBOX\_B2A\_CMD\_i in fast trigger mode.
  - Cleared when writing 1 to corresponding MAILBOX\_B2A\_STATUS.b2a\_tx\_done\_int.
- Regard MCU as the “BB” side of the Mailbox. The 4 groups TX done interrupt to MCU is:
  - Enabled when MAILBOX\_A2B\_INTEN.a2b\_tx\_done\_inten is set to 1 and the corresponding IRQ is enabled in INTC of MCU.
  - Generated when
    - there are writing operation to corresponding MAILBOX\_A2B\_CMD\_i and MAILBOX\_A2B\_DAT\_i orderly.
    - there are writing operation to corresponding MAILBOX\_A2B\_CMD\_i in fast

trigger mode.

- Cleared when writing 1 to corresponding MAILBOX\_A2B\_STATUS.a2b\_tx\_done\_int.

### **13.3.2 RX Done Interrupt**

- Regard CPU as the “AP” side of the Mailbox. The 4 groups RX done interrupt to CPU is:
  - Enabled when MAILBOX\_B2A\_INTEN.b2a\_rx\_done\_inten is set to 1 and the corresponding IRQ is enabled in GIC of CPU.
  - Generated when “BB” side clear the corresponding TX done interrupt by write 1 to MAILBOX\_A2B\_STATUS.a2b\_tx\_done\_int.
  - Cleared when writing 1 to the corresponding MAILBOX\_B2A\_STATUS.b2a\_rx\_done\_int.
- Regard MCU as the “BB” side of the Mailbox. The 4 groups RX done interrupt to MCU is:
  - Enabled when MAILBOX\_A2B\_INTEN.a2b\_rx\_done\_inten is set to 1 and the corresponding IRQ is enabled in INTC of MCU.
  - Generated when “AP” side clear the corresponding TX done interrupt by write 1 to MAILBOX\_B2A\_STATUS.b2a\_tx\_done\_int.
  - Cleared when writing 1 to the corresponding MAILBOX\_A2B\_STATUS.a2b\_rx\_done\_int.
- You can also regard CPU as the “BB” side of the Mailbox and regard MCU as the “AP” side of the Mailbox. The configuration flow is similar.
- Note that there are two ways for MAILBOX's interrupt to reach the MCU:
  - The interrupt is sent to the MCU through INTMUX, which needs to be configured accordingly. For details, see Cortex-M0 Chapter.
  - Interrupts are sent to the MCU via the GRF-controlled mux by selecting 1 of 8 (four interrupts each for AP and BB). For details, see SOC\_CON13 in the General Register Files (GRF) Chapter.

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

**Operational Base**

| <b>Name</b> | <b>Base Address</b> |
|-------------|---------------------|
| MAILBOX_CH0 | 0xFF290000          |
| MAILBOX_CH1 | 0xFF291000          |
| MAILBOX_CH2 | 0xFF292000          |
| MAILBOX_CH3 | 0xFF293000          |

### **13.4.2 Registers Summary**

| <b>Name</b>        | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                            |
|--------------------|---------------|-------------|--------------------|-----------------------------------------------|
| MAILBOX_A2B_INTEN  | 0x0000        | W           | 0x000000100        | AP to BB Interrupt Enable Register for Groupx |
| MAILBOX_A2B_STATUS | 0x0004        | W           | 0x000000000        | AP to BB Interrupt Status Register for Groupx |
| MAILBOX_A2B_CMD    | 0x0008        | W           | 0x000000000        | AP to BB Command x Register                   |
| MAILBOX_A2B_DATA   | 0x000C        | W           | 0x000000000        | AP to BB Data x Register                      |
| MAILBOX_B2A_INTEN  | 0x0010        | W           | 0x000000100        | BB to AP Interrupt Enable Register for Groupx |
| MAILBOX_B2A_STATUS | 0x0014        | W           | 0x000000000        | BB to AP Interrupt Status Register for Groupx |
| MAILBOX_B2A_CMD    | 0x0018        | W           | 0x000000000        | BB to AP Command x Register                   |
| MAILBOX_B2A_DATA   | 0x001C        | W           | 0x000000000        | BB to AP Data x Register                      |

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

### 13.4.3 Detail Registers Description

#### MAILBOX A2B INTEN

Address: **Operational Base** + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                 |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_enable<br>Write enable for low bit<br>1'b0: Disable<br>1'b1: Enable                                                                                                                   |
| 15:9  | RO   | 0x00        | reserved                                                                                                                                                                                    |
| 8     | RW   | 0x1         | a2b_trig_modex<br>Interrupt trigger mode for a2b_tx_done_int of groupx.<br>1'b0: Write CMD then generate interrupt<br>1'b1: Write CMD firstly, then Write DATA, and then generate interrupt |
| 7:2   | RO   | 0x00        | reserved                                                                                                                                                                                    |
| 1     | RW   | 0x0         | a2b_rx_done_inten<br>Interrupt enable for a2b_rx_done_int of groupx.<br>1'b0: Disable<br>1'b1: Enable                                                                                       |
| 0     | RW   | 0x0         | a2b_tx_done_inten<br>Interrupt enable for a2b_tx_done_int of groupx.<br>1'b0: Disable<br>1'b1: Enable                                                                                       |

#### MAILBOX A2B STATUS

Address: **Operational Base** + offset (0x0004)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                         |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | RO   | 0x00000000  | reserved                                                                                                                                                                                                                                                                                                                                                                            |
| 1    | W1C  | 0x0         | a2b_rx_done_int<br>AP rx_done interrupt status of groupx.<br>This interrupt will be set when AP clear the b2a_tx_done_int, and can be used to inform BB that the next message can be sent by BB. Clear the interrupt by writing 1 to this bit.<br>1'b0: Interrupt is inactive<br>1'b1: Interrupt is active                                                                          |
| 0    | W1C  | 0x0         | a2b_tx_done_int<br>AP tx_done interrupt status of groupx.<br>This interrupt will be set when AP write to A2B_CMD at fast trigger mode or when AP write to A2B_DATA at normal trigger mode. This interrupt can be used to inform BB that the new message from AP is ready. Clear the interrupt by writing 1 to this bit.<br>1'b0: Interrupt is inactive<br>1'b1: Interrupt is active |

#### MAILBOX A2B CMD

Address: **Operational Base** + offset (0x0008)

| Bit  | Attr | Reset Value | Description                   |
|------|------|-------------|-------------------------------|
| 31:0 | RW   | 0x00000000  | command<br>Command x register |

#### MAILBOX A2B DATA

Address: **Operational Base** + offset (0x000C)

| Bit  | Attr | Reset Value | Description             |
|------|------|-------------|-------------------------|
| 31:0 | RW   | 0x00000000  | data<br>Data x register |

**MAILBOX\_B2A\_INTEN**Address: **Operational Base** + offset (0x0010)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                 |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_enable<br>Write enable for low bit<br>1'b0: Disable<br>1'b1: Enable                                                                                                                   |
| 15:9  | RO   | 0x00        | reserved                                                                                                                                                                                    |
| 8     | RW   | 0x1         | b2a_trig_modex<br>Interrupt trigger mode for b2a_tx_done_int of groupx.<br>1'b0: Write CMD then generate interrupt<br>1'b1: Write CMD firstly, then Write DATA, and then generate interrupt |
| 7:2   | RO   | 0x00        | reserved                                                                                                                                                                                    |
| 1     | RW   | 0x0         | b2a_rx_done_inten<br>Interrupt enable for b2a_rx_done_int of groupx.<br>1'b0: Disable<br>1'b1: Enable                                                                                       |
| 0     | RW   | 0x0         | b2a_tx_done_inten<br>Interrupt enable for b2a_tx_done_int of groupx.<br>1'b0: Disable<br>1'b1: Enable                                                                                       |

**MAILBOX\_B2A\_STATUS**Address: **Operational Base** + offset (0x0014)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                         |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | RO   | 0x00000000  | reserved                                                                                                                                                                                                                                                                                                                                                                            |
| 1    | W1C  | 0x0         | b2a_rx_done_int<br>BB rx_done interrupt status of groupx.<br>This interrupt will be set when BB clear the a2b_tx_done_int, and can be used to inform AP that the next message can be sent.<br>Clear the interrupt by writing 1 to this bit.<br>1'b0: Interrupt is inactive<br>1'b1: Interrupt is active                                                                             |
| 0    | W1C  | 0x0         | b2a_tx_done_int<br>BB tx_done interrupt status of groupx.<br>This interrupt will be set when BB write to B2A_CMD at fast trigger mode or when BB write to B2A_DATA at normal trigger mode. This interrupt can be used to inform AP that the new message from BB is ready. Clear the interrupt by writing 1 to this bit.<br>1'b0: Interrupt is inactive<br>1'b1: Interrupt is active |

**MAILBOX\_B2A\_CMD**Address: **Operational Base** + offset (0x0018)

| Bit  | Attr | Reset Value | Description                   |
|------|------|-------------|-------------------------------|
| 31:0 | RW   | 0x00000000  | command<br>Command x register |

**MAILBOX\_B2A\_DATA**

Address: **Operational Base** + offset (0x001C)

| Bit  | Attr | Reset Value | Description             |
|------|------|-------------|-------------------------|
| 31:0 | RW   | 0x00000000  | data<br>Data x register |

## 13.5 Application Notes

- TX done interrupt is usually used to inform the receiver that the CMD and DATA is ready. It supports two trigger mode:
  - Normal mode
    1. Configure bit 8 of MAILBOX\_\*\_INTEN to '1'(\* stands for "A2B" or "B2A")
    2. Configure bit 0 of MAILBOX\_\*\_INTEN to '1'
    3. Write the MAILBOX\_\*\_CMD firstly
    4. Then write the MAILBOX\_\*\_DATA
    5. And then generate a TX done interrupt
  - Write to the MAILBOX\_\*\_CMD register before writing to the MAILBOX\_\*\_DATA register. If wrong order is used, then the interrupt cannot be generated successfully.
  - Fast trigger mode
    1. Configure bit 8 of MAILBOX\_\*\_INTEN to '0'
    2. Configure bit 0 of MAILBOX\_\*\_INTEN to '1'
    3. Write the MAILBOX\_\*\_CMD
    4. And then generate a TX done interrupt
  - If you want to clear the interrupt, you can read out the MAILBOX\_\*\_STATUS register and writing 1 to corresponding bit.
- RX done interrupt is usually used to inform the sender that the receiver has read out the CMD and DATA. It is triggered when the receiver has cleared the corresponding TX done interrupt:
  - AP to BB (assume TX done interrupt is set to normal mode)
    1. AP configure bit 1 of MAILBOX\_B2A\_INTEN to '1'
    2. BB configure bit 8 of MAILBOX\_A2B\_INTEN to '1'
    3. BB configure bit 0 of MAILBOX\_A2B\_INTEN to '1'
    4. AP write the MAILBOX\_A2B\_CMD
    5. AP write the MAILBOX\_A2B\_DATA
    6. Bit 0 of MAILBOX\_A2B\_STATUS is automatically set to '1' and TX done interrupt to BB is generated
    7. BB receive the TX done interrupt and read out the message
    8. BB write '1' to bit 0 of MAILBOX\_A2B\_STATUS
    9. And then bit 1 of MAILBOX\_B2A\_STATUS is automatically set to '1' and RX done interrupt to AP is generated
    10. AP receive the RX done interrupt which indicate BB has read out the message
    11. AP write '1' to bit 1 of MAILBOX\_B2A\_STATUS
    12. AP can start a new transfer

## Chapter 14 SARADC

### 14.1 Overview

The ADC is a 4-channel single-ended 10-bit Successive Approximation Register (SAR) A/D Converter. It uses the supply and ground as its reference which avoids the use of any external reference. The input range is typically 0V to 1.8V.

SARADC controller supports the following features:

- Support single mode and series conversion mode
- In single mode, the conversion operates once each software is accessed
- In series conversion, the controller samples each channel then loops until the software stops conversion
- High/low threshold can be set, higher/lower/between high-low-threshold interrupt can be enabled

### 14.2 Block Diagram

SARADC block is shown in Fig. 14-1. This includes:

- APB Interface
- Control FSM
- SARADC PHY

The software can configure the SARADC controller by APB interface, then the inter FSM will communicate with SARADC PHY for limited timing requests.



Fig. 14-1 SARADC Block Diagram

### 14.3 Function Description

SARADC block includes controller and PHY, user cannot directly access SARADC PHY. Software access the SARADC through SARADC controller by APB interface. SARADC controller will sample the conversion result from SARADC PHY.

### 14.4 Register Description

#### 14.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

#### 14.4.2 Registers Summary

| Name            | Offset | Size | Reset Value | Description        |
|-----------------|--------|------|-------------|--------------------|
| SARADC_CONV_CON | 0x0000 | W    | 0x00000000  | Conversion control |

| Name              | Offset | Size | Reset Value | Description                                             |
|-------------------|--------|------|-------------|---------------------------------------------------------|
| SARADC_T_PD_SOC   | 0x0004 | W    | 0x00000013  | Timing control for PD to SOC                            |
| SARADC_T_AS_SOC   | 0x0008 | W    | 0x00000005  | Timing control for assert SOC                           |
| SARADC_T_DAS_SOC  | 0x000C | W    | 0x00000007  | Timing control from dis-assert SOC to change channel    |
| SARADC_T_SEL_SOC  | 0x0010 | W    | 0x00000003  | Timing control from change channel select to assert SOC |
| SARADC_HIGH_COMP0 | 0x0014 | W    | 0x00000000  | High threshold for ADC output data                      |
| SARADC_HIGH_COMP1 | 0x0018 | W    | 0x00000000  | High threshold for ADC output data                      |
| SARADC_HIGH_COMP2 | 0x001C | W    | 0x00000000  | High threshold for ADC output data                      |
| SARADC_HIGH_COMP3 | 0x0020 | W    | 0x00000000  | High threshold for ADC output data                      |
| SARADC_LOW_COMP0  | 0x0054 | W    | 0x00000000  | Low threshold for ADC output data                       |
| SARADC_LOW_COMP1  | 0x0058 | W    | 0x00000000  | Low threshold for ADC output data                       |
| SARADC_LOW_COMP2  | 0x005C | W    | 0x00000000  | Low threshold for ADC output data                       |
| SARADC_LOW_COMP3  | 0x0060 | W    | 0x00000000  | Low threshold for ADC output data                       |
| SARADC_DEBOUNCE   | 0x0094 | W    | 0x00000003  | Threshold debounce                                      |
| SARADC_HT_INT_EN  | 0x0098 | W    | 0x00000000  | High threshold int enable                               |
| SARADC_LT_INT_EN  | 0x009C | W    | 0x00000000  | Low threshold int enable                                |
| SARADC_MT_INT_EN  | 0x0100 | W    | 0x00000000  | Middle threshold int enable                             |
| SARADC_END_INT_EN | 0x0104 | W    | 0x00000000  | End conversion int enable                               |
| SARADC_ST_CON     | 0x0108 | W    | 0x0000001C  | ADC static control                                      |
| SARADC_STATUS     | 0x010C | W    | 0x00000002  | ADC status                                              |
| SARADC_END_INT_ST | 0x0110 | W    | 0x00000000  | End conversion int state                                |
| SARADC_HT_INT_ST  | 0x0114 | W    | 0x00000000  | High threshold int state                                |
| SARADC_LT_INT_ST  | 0x0118 | W    | 0x00000000  | Low threshold int state                                 |
| SARADC_MT_INT_ST  | 0x011C | W    | 0x00000000  | Middle threshold int state                              |
| SARADC_DATA0      | 0x0120 | W    | 0x00000000  | ADC output data                                         |
| SARADC_DATA1      | 0x0124 | W    | 0x00000000  | ADC output data                                         |
| SARADC_DATA2      | 0x0128 | W    | 0x00000000  | ADC output data                                         |
| SARADC_DATA3      | 0x012C | W    | 0x00000000  | ADC output data                                         |
| SARADC_AUTO_CH_EN | 0x0160 | W    | 0x00000000  | Channel enable in auto channel mode                     |

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

#### 14.4.3 Detail Registers Description

##### SARADC\_CONV\_CON

Address: Operational Base(0xFF4E8000) + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:10 | RO   | 0x00        | reserved                                                                                                                          |
| 9     | RW   | 0x0         | int_lock<br>This is used to lock the sample data when interrupt happened.<br>1'b0: Disable lock<br>1'b1: Enable lock              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8          | RW          | 0x0                | as_pd_mode<br>If this bit is set to 1'b1, each time conversion ends, PD will be asserts. Then next time conversion starts, PD will be set to low automatically. This is not used in signal mode.                        |
| 7          | W1C         | 0x0                | end_conv<br>End conversion, this is not used when CONV_CON[5] is set to 1'b1. If this bit set to 1'b1, PD will set to 1'b1 after the last conversion and this bit will be cleared to 1'b0.                              |
| 6          | RW          | 0x0                | auto_channel_mode<br>Auto channel mode.<br>If this is enable, channel will be round auto according which is set in AUTO_CH_EN.                                                                                          |
| 5          | RW          | 0x0                | single_pd_mode<br>Single conversion mode. If this bit is set to 1, conversion only operate once, then PD single will be set to 1.                                                                                       |
| 4          | W1C         | 0x0                | start_adc<br>Enable ADC, if this bit set to one, conversion will start. Then this bit will be clear to 0.                                                                                                               |
| 3:0        | RW          | 0x0                | channel_sel<br>Channel for SARADC, 4 channel is supported. This field is not used when CONV_CON[6] is set to 1.<br>4'd0: Select channel 0<br>4'd1: Select channel 1<br>4'd2: Select channel 2<br>4'd3: Select channel 3 |

### **SARADC T PD SOC**

Address: Operational Base(0xFF4E8000) + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                            |
| 7:0        | RW          | 0x13               | t_pd_soc<br>Timing control between power up to start-of-conversion. |

### **SARADC T AS SOC**

Address: Operational Base(0xFF4E8000) + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                |
|------------|-------------|--------------------|---------------------------------------------------|
| 31:0       | RW          | 0x00000005         | t_as_soc<br>Timing control for assert SOC signal. |

### **SARADC T DAS SOC**

Address: Operational Base(0xFF4E8000) + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------|
| 31:0       | RW          | 0x00000007         | t_das_soc<br>Timing from dis-assert SOC to channel select change. |

### **SARADC T SEL SOC**

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                             |
| 15:0       | RW          | 0x0003             | t_sel_soc<br>Timing from channel load to SOC assert. |

### **SARADC HIGH COMPO**

Address: Operational Base(0xFF4E8000) + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                                        |
| 11:0       | RW          | 0x000              | high_comp0<br>High threshold for ADC output data for channel 0. |

**SARADC HIGH COMP1**

Address: Operational Base(0xFF4E8000) + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                                        |
| 11:0       | RW          | 0x000              | high_comp1<br>High threshold for ADC output data for channel 1. |

**SARADC HIGH COMP2**

Address: Operational Base(0xFF4E8000) + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                                        |
| 11:0       | RW          | 0x000              | high_comp2<br>High threshold for ADC output data for channel 2. |

**SARADC HIGH COMP3**

Address: Operational Base(0xFF4E8000) + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                                        |
| 11:0       | RW          | 0x000              | high_comp3<br>High threshold for ADC output data for channel 3. |

**SARADC LOW COMPO**

Address: Operational Base(0xFF4E8000) + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                                      |
| 11:0       | RW          | 0x000              | low_comp0<br>Low threshold for ADC output data for channel 0. |

**SARADC LOW COMP1**

Address: Operational Base(0xFF4E8000) + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                                      |
| 11:0       | RW          | 0x000              | low_comp1<br>Low threshold for ADC output data for channel 1. |

**SARADC LOW COMP2**

Address: Operational Base(0xFF4E8000) + offset (0x005C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                                      |
| 11:0       | RW          | 0x000              | low_comp2<br>Low threshold for ADC output data for channel 2. |

**SARADC LOW COMP3**

Address: Operational Base(0xFF4E8000) + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                                      |
| 11:0       | RW          | 0x000              | low_comp3<br>Low threshold for ADC output data for channel 3. |

**SARADC DEBOUNCE**

### RK3506 TRM (Part 1)

Address: Operational Base(0xFF4E8000) + offset (0x0094)

| Bit  | Attr | Reset Value | Description                                                                                                                  |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0000000   | reserved                                                                                                                     |
| 7:0  | RW   | 0x03        | debounce<br>ADC controller will only generate interrupt data is higher/lower/between setting threshold for "debounce" times. |

### SARADC HT INT EN

Address: Operational Base(0xFF4E8000) + offset (0x0098)

| 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:4  | RO   | 0x0         | reserved                                                                                                                          |
| 3     | RW   | 0x0         | ht_int_en3<br>High threshold interrupt for channel 3.<br>1'b0: Disable interrupt<br>1'b1: Enable interrupt                        |
| 2     | RW   | 0x0         | ht_int_en2<br>High threshold interrupt for channel 2.<br>1'b0: Disable interrupt<br>1'b1: Enable interrupt                        |
| 1     | RW   | 0x0         | ht_int_en1<br>High threshold interrupt for channel 1.<br>1'b0: Disable interrupt<br>1'b1: Enable interrupt                        |
| 0     | RW   | 0x0         | ht_int_en0<br>High threshold interrupt for channel 0.<br>1'b0: Disable interrupt<br>1'b1: Enable interrupt                        |

### SARADC LT INT EN

Address: Operational Base(0xFF4E8000) + offset (0x009C)

| 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:4  | RO   | 0x0         | reserved                                                                                                                          |
| 3     | RW   | 0x0         | lt_int_en3<br>Low threshold interrupt for channel 3.<br>1'b0: Disable interrupt<br>1'b1: Enable interrupt                         |
| 2     | RW   | 0x0         | lt_int_en2<br>Low threshold interrupt for channel 2.<br>1'b0: Disable interrupt<br>1'b1: Enable interrupt                         |
| 1     | RW   | 0x0         | lt_int_en1<br>Low threshold interrupt for channel 1.<br>1'b0: Disable interrupt<br>1'b1: Enable interrupt                         |
| 0     | RW   | 0x0         | lt_int_en0<br>Low threshold interrupt for channel 0.<br>1'b0: Disable interrupt<br>1'b1: Enable interrupt                         |

**SARADC\_MT\_INT\_EN**

Address: Operational Base(0xFF4E8000) + 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:4       | RO          | 0x0                | reserved                                                                                                                          |
| 3          | RW          | 0x0                | mt_int_en3<br>Middle threshold interrupt for channel3.<br>1'b0: Disable interrupt<br>1'b1: Enable interrupt                       |
| 2          | RW          | 0x0                | mt_int_en2<br>Middle threshold interrupt for channel2.<br>1'b0: Disable interrupt<br>1'b1: Enable interrupt                       |
| 1          | RW          | 0x0                | mt_int_en1<br>Middle threshold interrupt for channel1.<br>1'b0: Disable interrupt<br>1'b1: Enable interrupt                       |
| 0          | RW          | 0x0                | mt_int_en0<br>Middle threshold interrupt for channel0.<br>1'b0: Disable interrupt<br>1'b1: Enable interrupt                       |

**SARADC\_END\_INT\_EN**

Address: Operational Base(0xFF4E8000) + offset (0x0104)

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

**SARADC\_ST\_CON**

Address: Operational Base(0xFF4E8000) + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                                                                       |
| 5:3        | RW          | 0x3                | ictrl<br>Control the bias current of the preamplifier in the SAR-ADC.                                          |
| 2:0        | RW          | 0x4                | cctrl<br>Control the capacitance of the capacitor DAC array, which is related to the linearity of the SAR-ADC. |

**SARADC\_STATUS**

Address: Operational Base(0xFF4E8000) + offset (0x010C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>        |
|------------|-------------|--------------------|---------------------------|
| 31:6       | RO          | 0x00000000         | reserved                  |
| 5:2        | RO          | 0x0                | sel<br>ADC channel select |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------|
| 1          | RO          | 0x1                | pd<br>1'b1: ADC is power down.<br>1'b0: ADC is power up and in conversion.                             |
| 0          | RO          | 0x0                | conv_st<br>Conversion status<br>1'b1: ADC controller FSM is busy.<br>1'b0: ADC controller FSM is idle. |

### **SARADC END INT ST**

Address: Operational Base(0xFF4E8000) + offset (0x0110)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                       |
| 0          | W1 C        | 0x0                | end_int_st<br>ADC end conversion interrupt status.<br>1'b0: Interrupt not happened<br>1'b1: Interrupt happened |

### **SARADC HT INT ST**

Address: Operational Base(0xFF4E8000) + offset (0x0114)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0000             | reserved                                                                                                                |
| 3          | W1 C        | 0x0                | ht_int_st3<br>High threshold interrupt state for channel 3.<br>1'b0: Interrupt not happened<br>1'b1: Interrupt happened |
| 2          | W1 C        | 0x0                | ht_int_st2<br>High threshold interrupt state for channel 2.<br>1'b0: Interrupt not happened<br>1'b1: Interrupt happened |
| 1          | W1 C        | 0x0                | ht_int_st1<br>High threshold interrupt state for channel 1.<br>1'b0: Interrupt not happened<br>1'b1: Interrupt happened |
| 0          | W1 C        | 0x0                | ht_int_st0<br>High threshold interrupt state for channel 0.<br>1'b0: Interrupt not happened<br>1'b1: Interrupt happened |

### **SARADC LT INT ST**

Address: Operational Base(0xFF4E8000) + offset (0x0118)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0000             | reserved                                                                                                               |
| 3          | W1 C        | 0x0                | lt_int_st3<br>Low threshold interrupt state for channel 3.<br>1'b0: Interrupt not happened<br>1'b1: Interrupt happened |
| 2          | W1 C        | 0x0                | lt_int_st2<br>Low threshold interrupt state for channel 2.<br>1'b0: Interrupt not happened<br>1'b1: Interrupt happened |
| 1          | W1 C        | 0x0                | lt_int_st1<br>Low threshold interrupt state for channel 1.<br>1'b0: Interrupt not happened<br>1'b1: Interrupt happened |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------|
| 0          | W1<br>C     | 0x0                | lt_int_st0<br>Low threshold interrupt state for channel 0.<br>1'b0: Interrupt not happened<br>1'b1: Interrupt happened |

**SARADC\_MT\_INT\_ST**

Address: Operational Base(0xFF4E8000) + offset (0x011C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0000             | reserved                                                                                                                                |
| 3          | W1<br>C     | 0x0                | mt_int_st3<br>Between high and low threshold interrupt state for channel 3.<br>1'b0: Interrupt not happened<br>1'b1: Interrupt happened |
| 2          | W1<br>C     | 0x0                | mt_int_st2<br>Between high and low threshold interrupt state for channel 2.<br>1'b0: Interrupt not happened<br>1'b1: Interrupt happened |
| 1          | W1<br>C     | 0x0                | mt_int_st1<br>Between high and low threshold interrupt state for channel 1.<br>1'b0: Interrupt not happened<br>1'b1: Interrupt happened |
| 0          | W1<br>C     | 0x0                | mt_int_st0<br>Between high and low threshold interrupt state for channel 0.<br>1'b0: Interrupt not happened<br>1'b1: Interrupt happened |

**SARADC\_DATA0**

Address: Operational Base(0xFF4E8000) + offset (0x0120)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>          |
|------------|-------------|--------------------|-----------------------------|
| 31:12      | RO          | 0x00000            | reserved                    |
| 11:0       | RO          | 0x000              | data0<br>ADC channel 0 data |

**SARADC\_DATA1**

Address: Operational Base(0xFF4E8000) + offset (0x0124)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>          |
|------------|-------------|--------------------|-----------------------------|
| 31:12      | RO          | 0x00000            | reserved                    |
| 11:0       | RO          | 0x000              | data1<br>ADC channel 1 data |

**SARADC\_DATA2**

Address: Operational Base(0xFF4E8000) + offset (0x0128)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>          |
|------------|-------------|--------------------|-----------------------------|
| 31:12      | RO          | 0x00000            | reserved                    |
| 11:0       | RO          | 0x000              | data2<br>ADC channel 2 data |

**SARADC\_DATA3**

Address: Operational Base(0xFF4E8000) + offset (0x012C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>          |
|------------|-------------|--------------------|-----------------------------|
| 31:12      | RO          | 0x00000            | reserved                    |
| 11:0       | RO          | 0x000              | data3<br>ADC channel 3 data |

**SARADC\_AUTO\_CH\_EN**

Address: Operational Base(0xFF4E8000) + offset (0x0160)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:0  | RW   | 0x0000      | auto_ch_en<br>Enable channel in auto channel mode, each bit can enable for one channel.                                           |

## 14.5 Application Notes

### 14.5.1 Series Conversion Mode

Steps of ADC conversion in series conversion mode:

- Decide which channel should be used and whether auto\_channel mode should be set. In auto\_channel mode, the channel will be changed from 0-3 then to 0. Please refer to the SARADC\_CONV\_CON register.
- Set SARADC\_CONV\_CON[4] to 1'b1, then the conversion will start.
- If conversion wants to be ended, set SARADC\_CONV\_CON[7] to 1'b1.
- Conversion could be read from SARADC\_DATA $n$  ( $n$  is from 0-3).
- If threshold compare interrupt wants to be used, high/low threshold could be set, and interrupt should be set as an application.
- If auto\_channel mode is not set, you could set the channel as an application.

### 14.5.2 Single Mode

Steps of ADC conversion in single mode:

- Decide which channel should be used and set SARADC\_CONV\_CON[3:0].
- Set SARADC\_CONV\_CON[5] to 1'b1.
- Set SARADC\_CONV\_CON[4] to 1'b1, then the conversion will start.
- The conversion only operates once then ends. PD will be asserted and PD status could be got by reading SARADC\_STATUS.
- Conversion could be read from SARADC\_DATA $n$  ( $n$  is from 0-3).

## Chapter 15 Temperature-Sensor ADC (TSADC)

### 15.1 Overview

TSADC controller is used to control and get the temperature information. TSADC will convert for each enabled channel in loop after the initial setting and can be stopped by software. If you find that the temperature is high in a period of time, an interrupt is generated to the processor down-measures taken; if the temperature over a period of time High, the resulting TSHUT gave CRU module, let it reset the entire chip, or via GPIO give PMIC. Also, if you find that the temperature low in a period of time, an interrupt can be generated.

TSADC controller supports the following features:

- The temperature for high and low interrupt can be configured
- The temperature of system reset can be configured
- The time interval of temperature detection can be configured
- When detecting a high temperature, the time interval of temperature detection can be configured
- High temperature debounce can be configured
- An interrupt can be generated after TSADC converts all setting channel
- -40~125°C temperature range and 0.6°C temperature resolution

### 15.2 Block Diagram

TSADC controller comprises with:

- APB Interface
- TSADC control logic



Fig. 15-1 TSADC Controller Block Diagram

### 15.3 Function Description

#### 15.3.1 APB Interface

There is an APB Slave interface in TSADC controller, which is used to configure the TSADC controller registers and look up the temperature from the temperature sensor.

#### 15.3.2 TSADC Controller

This block is used to control the TSADC PHY to meet the conversion timing and receive the temperature information from TSADC PHY.

### 15.4 Register Description

#### 15.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

#### 15.4.2 Registers Summary

| Name                       | Offset | Size | Reset Value | Description                                       |
|----------------------------|--------|------|-------------|---------------------------------------------------|
| TSADC USER CON             | 0x0000 | W    | 0x00000000  | User control                                      |
| TSADC AUTO CON             | 0x0004 | W    | 0x00000000  | Auto control                                      |
| TSADC AUTO STATUS          | 0x0008 | W    | 0x00000000  | Status used in auto mode                          |
| TSADC AUTO SRC             | 0x000C | W    | 0x00000000  | Channel select for TSADC in auto mode             |
| TSADC LT EN                | 0x0010 | W    | 0x00000000  | Low temperature check logic enable                |
| TSADC HT INT EN            | 0x0014 | W    | 0x00000000  | High temperature interrupt enable                 |
| TSADC GPIO EN              | 0x0018 | W    | 0x00000000  | Temperature violation to GPIO enable              |
| TSADC CRU EN               | 0x001C | W    | 0x00000000  | Temperature violation to CRU enable               |
| TSADC LT INT EN            | 0x0020 | W    | 0x00000000  | Low temperature interrupt enable                  |
| TSADC HLT INT PD           | 0x0024 | W    | 0x00000000  | High and low temperature interrupt status         |
| TSADC EOC HSHUT PD         | 0x0028 | W    | 0x00000000  | High temperature shut and round int status        |
| TSADC DATA0                | 0x002C | W    | 0x00000000  | Channel0 data                                     |
| TSADC COMPO INT            | 0x006C | W    | 0x00000000  | High temperature interrupt threshold for channel0 |
| TSADC COMPO SHUT           | 0x010C | W    | 0x00000000  | High temperature shut threshold for channel0      |
| TSADC HIGH INT DEBO UNCE   | 0x014C | W    | 0x00000003  | High interrupt debounce                           |
| TSADC HIGH TSHUT DE BOUNCE | 0x0150 | W    | 0x00000003  | High shut debounce                                |
| TSADC AUTO PERIOD          | 0x0154 | W    | 0x00010000  | Auto conversion period                            |
| TSADC AUTO PERIOD H T      | 0x0158 | W    | 0x00010000  | Auto conversion period for high temperature       |
| TSADC COMPO LOW INT        | 0x015C | W    | 0x00000000  | Low temperature threshold for channel0            |
| TSADC T SETUP              | 0x019C | W    | 0x0000005F  | Timing for setup                                  |
| TSADC T PW EN              | 0x0200 | W    | 0x00000000  | Timing for pw_en                                  |
| TSADC T EN CLK             | 0x0204 | W    | 0x00000001  | Timing for en_clk                                 |
| TSADC T NON OV             | 0x0208 | W    | 0x00000002  | Timing for non_ov                                 |
| TSADC T HOLD               | 0x020C | W    | 0x00000013  | Timing for hold                                   |
| TSADC Q MAX                | 0x0210 | W    | 0x00000000  | Max data used for data inversion                  |
| TSADC STATIC CON           | 0x0214 | W    | 0x0280001B  | Static control signal                             |
| TSADC CLK CH PERIOD        | 0x021C | W    | 0x00000012B | CLK_CH_TS period control                          |
| TSADC T PW CLK             | 0x0220 | W    | 0x00000030  | Timing for pw_clk                                 |

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

### 15.4.3 Detail Registers Description

#### TSADC USER CON

Address: Operational Base(0xFF650000) + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b1: Write access enable<br>1'b0: Write access disable |
| 15:9  | RO   | 0x00        | reserved                                                                                                                          |
| 8     | RO   | 0x0         | adc_status<br>1'b0: ADC stop<br>1'b1: Conversion in progress                                                                      |

| Bit | Attr   | Reset Value | Description                                                                                                                                                                                             |
|-----|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | R/W SC | 0x0         | start<br>When software 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[5] = 1'b1, this bit takes effect. |
| 6   | RW     | 0x0         | eoc_inten<br>Enable end-of-conversion interrupt for each conversion.<br>1'b0 : Disable<br>1'b1 : Enable                                                                                                 |
| 5   | RW     | 0x0         | start_mode<br>Start mode.<br>1'b0: TSADC controller will assert start_of_conversion after power up.<br>1'b1: The start_of_conversion will be controlled by TSADC_USER_CON[7].                           |
| 4   | RW     | 0x0         | power_control<br>ADC power control<br>1'b0: Power down<br>1'b1: Power up<br>This bit is not enable when TSADC_AUTO_CON[0] is set to 1.                                                                  |
| 3:0 | RW     | 0x0         | input_src_sel<br>ADC input source select in user mode.<br>Should be set at 0.                                                                                                                           |

**TSADC AUTO CON**

Address: Operational Base(0xFF650000) + offset (0x0004)

| Bit   | Attr | Reset Value | Description                                                                                                                                                              |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b1: Write access enable<br>1'b0: Write access disable                                        |
| 15:9  | RO   | 0x00        | reserved                                                                                                                                                                 |
| 8     | RW   | 0x0         | tshut_polarity<br>This bit is used to control the output signal polarity to GPIO when the temperature is higher than threshold.<br>1'b0: Low active<br>1'b1: High active |
| 7:3   | RO   | 0x00        | reserved                                                                                                                                                                 |
| 2     | RW   | 0x0         | round_int_en<br>Int enable for round mode. Used for auto mode all channel set is sampled.<br>1'b1: Enable<br>1'b0: Disable                                               |
| 1     | RW   | 0x0         | q_sel<br>1'b0: Use tsadc_q as output (positive temperature coefficient)<br>1'b1: Use (q_max - tsadc_q) as output (negative temperature coefficient)                      |
| 0     | RW   | 0x0         | auto_en<br>Auto conversion enable<br>1'b0: TSADC controller works at user-define mode<br>1'b1: TSADC controller works at auto mode                                       |

**TSADC AUTO STATUS**

Address: Operational Base(0xFF650000) + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                                                                                             |
| 3          | RW          | 0x0                | ht_wram<br>High temperature status<br>1'b0: TSADC data is not higher than high temperature shut value<br>1'b1: TSADC data is higher than high temperature shut value |
| 2          | RW          | 0x0                | auto_status<br>TSADC auto mode status<br>1'b0: Auto mode stop<br>1'b1: Auto mode in progress                                                                         |
| 1          | W1C         | 0x0                | last_tshut_cru<br>Status for CRU reset latest temperature shut, write 1 to clear.                                                                                    |
| 0          | W1C         | 0x0                | last_tshut_gpio<br>Status for GPIO latest temperature shut, write 1 to clear.                                                                                        |

### **TSADC AUTO\_SRC**

Address: Operational Base(0xFF650000) + 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'b1: Write access enable<br>1'b0: Write access disable |
| 15:0       | RW          | 0x0000             | auto_src<br>Enable channel for TSADC in auto mode, each bit can enable for one channel.                                           |

### **TSADC LT EN**

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b1: Write access enable<br>1'b0: Write access disable |
| 15:0       | RW          | 0x0000             | low_temperature_vio_en<br>Low temperature violation logic enable, each bit enables one channel.<br>1'b1: Enable<br>1'b0: Disable  |

### **TSADC HT INT EN**

Address: Operational Base(0xFF650000) + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b1: Write access enable<br>1'b0: Write access disable |
| 15:0       | RW          | 0x0000             | high_temperature_int_en<br>High temperature interrupt enable, each bit enables one channel.<br>1'b1: Enable<br>1'b0: Disable      |

### **TSADC GPIO EN**

Address: Operational Base(0xFF650000) + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b1: Write access enable<br>1'b0: Write access disable |
| 15:0       | RW          | 0x0000             | gpio_en<br>Temperature violation to GPIO enable, each bit enables one channel.<br>1'b1: Enable<br>1'b0: Disable                   |

**TSADC CRU EN**

Address: Operational Base(0xFF650000) + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b1: Write access enable<br>1'b0: Write access disable |
| 15:0       | RW          | 0x0000             | cru_en<br>Temperature violation to CRU reset enable, each bit enables one channel.<br>1'b1: Enable<br>1'b0: Disable               |

**TSADC LT INT EN**

Address: Operational Base(0xFF650000) + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b1: Write access enable<br>1'b0: Write access disable |
| 15:0       | RW          | 0x0000             | low_temperature_int_en<br>Low temperature interrupt enable, each bit enables one channel.<br>1'b1: Enable<br>1'b0: Disable        |

**TSADC HLT INT PD**Address: **Operational Base(0xFF650000)** + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------|
| 31:16      | W1<br>C     | 0x0000             | lt_int_status<br>Low temperature interrupt status for each channel.  |
| 15:0       | W1<br>C     | 0x0000             | ht_int_status<br>High temperature interrupt status for each channel. |

**TSADC EOC HSHUT PD**

Address: Operational Base(0xFF650000) + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------|
| 31:18      | RO          | 0x0000             | reserved                                                               |
| 17         | W1<br>C     | 0x0                | round_int_pd<br>Auto mode interrupt for each round of all set channel. |
| 16         | W1<br>C     | 0x0                | usr_eoc_irq_pd<br>User mode end interrupt status.                      |
| 15:0       | W1<br>C     | 0x0000             | ht_shut_pd<br>High temperature shut down status for each channel.      |

**TSADC DATA0**

## RK3506 TRM (Part 1)

Address: Operational Base(0xFF650000) + offset (0x002C)

| Bit   | Attr | Reset Value | Description                                             |
|-------|------|-------------|---------------------------------------------------------|
| 31:10 | RO   | 0x0000000   | reserved                                                |
| 9:0   | RO   | 0x000       | adc_data<br>A/D value of the channel 0 last conversion. |

### TSADC COMPO INT

Address: Operational Base(0xFF650000) + offset (0x006C)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                     |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | RO   | 0x0000000   | reserved                                                                                                                                                                        |
| 9:0   | RW   | 0x000       | tsadc_h_int_comp_src0<br>TSADC high temperature level.<br>TSADC output is bigger than or equal to this 10-bit value, means the temperature is high.<br>TSADC_INT will be valid. |

### TSADC COMPO SHUT

Address: Operational Base(0xFF650000) + offset (0x010C)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                    |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | RO   | 0x0000000   | reserved                                                                                                                                                                       |
| 9:0   | RW   | 0x000       | tsadc_shut_comp_src0<br>TSADC high temperature level.<br>TSADC output is bigger than or equal to this 10-bit value, means the temperature is too high.<br>TSHUT will be valid. |

### TSADC HIGH INT DEBOUNCE

Address: Operational Base(0xFF650000) + offset (0x014C)

| Bit  | Attr | Reset Value | Description                                                                                                                          |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0000000   | reserved                                                                                                                             |
| 7:0  | RW   | 0x03        | debounce<br>TSADC controller will only generate interrupt when temperature is higher than or equal to COMP_INT for "debounce" times. |

### TSADC HIGH TSHUT DEBOUNCE

Address: Operational Base(0xFF650000) + offset (0x0150)

| Bit  | Attr | Reset Value | Description                                                                                                                       |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0000000   | reserved                                                                                                                          |
| 7:0  | RW   | 0x03        | debounce<br>TSADC controller will only generate TSHUT when temperature is higher than or equal to COMP_SHUT for "debounce" times. |

### TSADC AUTO PERIOD

Address: Operational Base(0xFF650000) + offset (0x0154)

| Bit  | Attr | Reset Value | Description                                                                                                                                |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00010000  | auto_period<br>When auto mode is enabled, this register controls the interleave between every conversion for all channel enabled of TSADC. |

### TSADC AUTO PERIOD HT

Address: Operational Base(0xFF650000) + offset (0x0158)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                            |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00010000  | auto_period<br>This register controls the interleave between every conversion for all channel enabled of TSADC after the temperature is higher than or equal to COMP_SHUT or COMP_INT. |

**TSADC COMPO LOW INT**

Address: Operational Base(0xFF650000) + offset (0x015C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x000000           | reserved                                                                                                                                                                         |
| 9:0        | RW          | 0x000              | tsadc_l_int_comp_src0<br>TSADC low temperature level.<br>TSADC output is lower than or equal to this 10-bit value, means the temperature is low.<br>TSADC_LOW_INT will be valid. |

**TSADC T SETUP**

Address: Operational Base(0xFF650000) + offset (0x019C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                           |
| 15:0       | RW          | 0x005f             | t_setup<br>The timing between TSADC power up and start conversion. |

**TSADC T PW EN**

Address: Operational Base(0xFF650000) + offset (0x0200)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                              |
| 15:0       | RW          | 0x0000             | t_pw_en<br>The timing assert start conversion signal. |

**TSADC T EN CLK**

Address: Operational Base(0xFF650000) + offset (0x0204)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                       |
| 7:0        | RW          | 0x01               | t_en_clk<br>The timing between dis-assert start conversion signal (EN_TEMP_SEN_TS) and assert CLK_SENSE_TS[8]. |

**TSADC T NON OV**

Address: Operational Base(0xFF650000) + offset (0x0208)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                           |
| 7:0        | RW          | 0x02               | t_non_ov<br>The timing between each bit assertion of CLK_SENSE_TS. |

**TSADC T HOLD**

Address: Operational Base(0xFF650000) + offset (0x020C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                   |
| 15:0       | RW          | 0x0013             | t_hold<br>The timing between dis-assert CLK_SENSE_TS and TSADC data valid. |

**TSADC Q MAX**

Address: Operational Base(0xFF650000) + offset (0x0210)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------|
| 31:11      | RO          | 0x000000           | reserved                                                                     |
| 10:0       | RW          | 0x000              | q_max<br>This register used for TSADC_AUTO_CON[1] for inversion output data. |

**TSADC STATIC CON**

Address: Operational Base(0xFF650000) + offset (0x0214)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:27      | RW          | 0x00               | buf_vref_sel<br>Offset control for temperature output code.             |
| 26:23      | RW          | 0x5                | buf_slope_sel<br>Slope control for temperature output code.             |
| 22:21      | RW          | 0x0                | comp_i_trim<br>Comparator current timing ports.                         |
| 20:17      | RW          | 0x0                | vbe_i_trm<br>Current timing ports for VBE in PTAT generator.            |
| 16:13      | RW          | 0x0                | verf_trim<br>Reference voltage trimming ports for reference generator.  |
| 12:9       | RW          | 0x0                | bgr_r_trim<br>BGR control ports in reference generator.                 |
| 8:5        | RW          | 0x0                | bgr_i_trim<br>BJT emitter current control ports in reference generator. |
| 4:2        | RW          | 0x6                | avg_mode<br>Average mode control ports for digital filter.              |
| 1          | RW          | 0x1                | en_dem<br>Dynamic element matching enable port.                         |
| 0          | RW          | 0x1                | en_ch<br>Digital offset cancellation enable port.                       |

**TSADC CLK CH PERIOD**

Address: Operational Base(0xFF650000) + offset (0x021C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                |
|------------|-------------|--------------------|---------------------------------------------------|
| 31:0       | RW          | 0x00000012b        | clk_ch_period<br>Control the period of CLK_CH_TS. |

**TSADC T PW CLK**

Address: Operational Base(0xFF650000) + offset (0x0220)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                          |
| 15:0       | RW          | 0x0030             | t_pw_clk<br>The timing for assertion of each bit of CLK_SENSE_TS. |

**15.5 Interface Description**

Table 15-1 TSADC Rockchip Matrix IO Interface Description

| <b>Module Pin</b> | <b>Dir</b> | <b>Pad Name</b> | <b>IOMUX Setting</b> |
|-------------------|------------|-----------------|----------------------|
| <b>IOMUX0</b>     |            |                 |                      |
| tsadc_tshut       | O          |                 |                      |

Notes: I=input, O=output, I/O=input/output. For the configuration of RM\_IO, please refer to chapter "Rockchip Matrix IO".

**15.6 Application Notes****15.6.1 Conversion Flow**

The system works as follows:

- 1) Temperature violation and other configurations may be set.
- 2) Assert tsadc\_tsen\_en and tsadc\_ana\_rego0/1/2.
- 3) Set the bit[0] in register TSADC\_AUTO\_CON, then TSADC will work.
- 4) Then temperature information can be read from the APB interface.
- 5) If TSADC needs to be closed, set bit[0] in register TSADC\_AUTO\_CON to 1'b0.

## 15.6.2 Timing Diagram

When TSADC start to work, the timing will follow the Fig. 15-2  
The timing requirement is also listed as follows.



Fig. 15-2 Timing Diagram for TSADC

Table 15-2 TSADC Start Timing

| parameter | min  |
|-----------|------|
| t1        | 10us |
| t2        | 0us  |
| t3        | 90us |

## 15.6.3 Temperature-to-Code Mapping

Table 15-3 TSADC Lookup Table

| temperature (°C) | typical output |
|------------------|----------------|
| -40              | 395            |
| -35              | 403            |
| -30              | 411            |
| 0                | 462            |
| 5                | 470            |
| 10               | 478            |
| 25               | 503            |
| 30               | 511            |
| 80               | 596            |
| 85               | 604            |
| 115              | 655            |
| 120              | 664            |
| 125              | 672            |

Note:

Code to Temperature mapping of the Temperature sensor is a linear curve. Any temperature, code falling between 2 given temperatures can be linearly interpolated.

Code to Temperature mapping should be updated based on silicon results.

## Chapter 16 SPINLOCK

### 16.1 Overview

The hardware spinlock used for spinlock status storage. All the CPU and MCU can access spinlock to get the lock status.

### 16.2 Block Diagram



Fig.16-1 Spinlock in System

### 16.3 Function Description

The CPU and MCU can obtain a lock by writing a non-zero value to the SPINLOCK\_STATUS\_x register in the spinlock; The CPU and MCU can also read SPINLOCK\_STATUS\_x to query the status of the lock.

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

**Operational Base**

| Name         | Base Address |
|--------------|--------------|
| SPINLOCK-CH0 | 0xFF240000   |
| SPINLOCK-CH1 | 0xFF241000   |
| SPINLOCK-CH2 | 0xFF242000   |
| SPINLOCK-CH3 | 0xFF243000   |

#### 16.4.2 Registers Summary

| Name              | Offset | Size | Reset Value | Description                           |
|-------------------|--------|------|-------------|---------------------------------------|
| SPINLOCK STATUS 0 | 0x0000 | W    | 0x00000000  | Spinlock Status Controller Register 0 |
| SPINLOCK STATUS 1 | 0x0004 | W    | 0x00000000  | Spinlock Status Controller Register 1 |
| SPINLOCK STATUS 2 | 0x0008 | W    | 0x00000000  | Spinlock Status Controller Register 2 |
| SPINLOCK STATUS 3 | 0x000C | W    | 0x00000000  | Spinlock Status Controller Register 3 |

| Name              | Offset | Size | Reset Value | Description                           |
|-------------------|--------|------|-------------|---------------------------------------|
| SPINLOCK STATUS 4 | 0x0010 | W    | 0x00000000  | Spinlock Status Controller Register 4 |
| SPINLOCK STATUS 5 | 0x0014 | W    | 0x00000000  | Spinlock Status Controller Register 5 |
| SPINLOCK STATUS 6 | 0x0018 | W    | 0x00000000  | Spinlock Status Controller Register 6 |
| SPINLOCK STATUS 7 | 0x001C | W    | 0x00000000  | Spinlock Status Controller Register 7 |

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

### 16.4.3 Detail Registers Description

#### SPINLOCK STATUS 0

Address: **Operational Base** + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | RO   | 0x00000000  | reserved                                                                                                                                                                   |
| 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.<br>When write data is 4'b0000, 4bits clean to 0. |

#### SPINLOCK STATUS 1

Address: **Operational Base** + offset (0x0004)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | RO   | 0x00000000  | reserved                                                                                                                                                                   |
| 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.<br>When write data is 4'b0000, 4bits clean to 0. |

#### SPINLOCK STATUS 2

Address: **Operational Base** + offset (0x0008)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | RO   | 0x00000000  | reserved                                                                                                                                                                   |
| 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.<br>When write data is 4'b0000, 4bits clean to 0. |

#### SPINLOCK STATUS 3

Address: **Operational Base** + offset (0x000C)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | RO   | 0x00000000  | reserved                                                                                                                                                                   |
| 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.<br>When write data is 4'b0000, 4bits clean to 0. |

#### SPINLOCK STATUS 4

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

| 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                | spinlock_status<br>When 4bits is 0, 4bits can be written with new value.<br>When 4bits is not 0, 4bits cannot be written.<br>When write data is 4'b0000, 4bits clean to 0. |

**SPINLOCK STATUS 5**Address: **Operational Base** + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                                                                                                   |
| 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.<br>When write data is 4'b0000, 4bits clean to 0. |

**SPINLOCK STATUS 6**Address: **Operational Base** + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                                                                                                   |
| 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.<br>When write data is 4'b0000, 4bits clean to 0. |

**SPINLOCK STATUS 7**Address: **Operational Base** + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                                                                                                   |
| 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.<br>When write data is 4'b0000, 4bits clean to 0. |

**16.5 Application Notes**

The spinlock can be used as follows:



Figure 16-1 spinlock usage flow

## Chapter 17 GPIO

### 17.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
- Four virtual OS with independent control registers can be supported
- In virtual OS mode, each OS has independent interrupt
- GPIO input is filtered to remove burrs. The filter function is configured using GRF

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



Fig. 17-1 GPIO Block Diagram

### 17.3 Function Description

#### 17.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\_DDR\_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.

### **17.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.

### **17.3.3 Debounce Operation**

The external signal can be debounced to remove any spurious glitches that are less than half 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 one cycle of the debounce clock to guarantee that it is registered. Any input pulse widths less than half debounce clock period are bounced. A pulse width between half and one debounce clock width may or may not propagate, depending on its phase relationship to the debounce clock. If the input pulse spans rising edges and falling edge of the debounce clock, it is registered. If it spans only one 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).

### **17.3.4 Four OS Operation and Four Interrupts**

To select this mode, virtual enable register should be set (GPIO\_VIRTUAL\_EN). Then all the configurations can be allotted to four OS (for example OS\_A, OS\_B, OS\_C, OS\_D). OS\_A will use the original address offset, OS\_B will use the offset + 0x1000, OS\_C will use the offset + 0x2000, OS\_D will use the offset + 0x3000. The 32 bit I/O port should also be allotted to

the OS by setting reg group registers (GPIO\_REG\_GROUP\_L and GPIO\_REG\_GROUP\_H). Once reg group is set, the I/O operation can only be used by the setting address offset. Each OS has its own interrupt for I/O port, this is depended on reg group. If virtual enable register is disable, reg group can also be used to allotted I/O interrupt. These four independent interrupts may be used for priority interrupt setting.

### 17.3.5 Burr filtration

The input signal from the PAD is filtered by filter to remove burrs and then sent to GPIO IP. The filter module can be selected to turn on or off, and the width of the filter burr can be configured. GPIO0-4 is connected to the filter in the table, the table lists the location of the register controlling filter in the GRF. See Chapter GRF for a more detailed description:

Table 17-1 GPIO filter Description

| Mod<br>ule                | Filter<br>Name      | Filter Info                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------------------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GPIO0                     | GPIO0_FILTER        | PMUGRF_SOC_CON5 [3:0]=gpio0_filter_en<br>PMUGRF_SOC_CON5 [8:4]=gpio0_filter_sel0<br>PMUGRF_SOC_CON5 [14:10]=gpio0_filter_sel1<br>PMUGRF_SOC_CON6 [8:4]=gpio0_filter_sel2<br>PMUGRF_SOC_CON6 [14:10]=gpio0_filter_sel3<br>PMUGRF_SOC_CON7 [19:0]=gpio0_filter_count0<br>PMUGRF_SOC_CON8 [19:0]=gpio0_filter_count1<br>PMUGRF_SOC_CON9 [19:0]=gpio0_filter_count2<br>PMUGRF_SOC_CON10 [19:0]=gpio0_filter_count3                                                                        |
| GPIO1_SHADOW              | GPIO1_SHADOW_FILTER | PMUGRF_SOC_CON11 [3:0]=gpio1_shadow_filter_en<br>PMUGRF_SOC_CON11 [8:4]=gpio1_shadow_filter_sel0<br>PMUGRF_SOC_CON11 [14:10]=gpio1_shadow_filter_sel1<br>PMUGRF_SOC_CON12 [8:4]=gpio1_shadow_filter_sel2<br>PMUGRF_SOC_CON12 [14:10]=gpio1_shadow_filter_sel3<br>PMUGRF_SOC_CON13 [19:0]=gpio1_shadow_filter_count0<br>PMUGRF_SOC_CON14 [19:0]=gpio1_shadow_filter_count1<br>PMUGRF_SOC_CON15 [19:0]=gpio1_shadow_filter_count2<br>PMUGRF_SOC_CON16 [19:0]=gpio1_shadow_filter_count3 |
| GPIO1                     | GPIO1_FILTER        | COREGRF_SOC_CON0 [3:0]=gpio1_filter_en<br>COREGRF_SOC_CON0 [8:4]=gpio1_filter_sel0<br>COREGRF_SOC_CON0 [14:10]=gpio1_filter_sel1<br>COREGRF_SOC_CON1 [8:4]=gpio1_filter_sel2<br>COREGRF_SOC_CON1 [14:10]=gpio1_filter_sel3<br>COREGRF_SOC_CON2 [19:0]=gpio1_filter_count0<br>COREGRF_SOC_CON3 [19:0]=gpio1_filter_count1<br>COREGRF_SOC_CON4 [19:0]=gpio1_filter_count2<br>COREGRF_SOC_CON5 [19:0]=gpio1_filter_count3                                                                |
| GPIO2/<br>GPIO3/<br>GPIO4 | GPIO2_FILTER        | GRF_SOC_CON31 [3:0]=gpio2_filter_en<br>GRF_SOC_CON31 [9:4]=gpio2_filter_sel0<br>GRF_SOC_CON31 [15:10]=gpio2_filter_sel1<br>GRF_SOC_CON32 [19:0]=gpio2_filter_count0<br>GRF_SOC_CON33 [19:0]=gpio2_filter_count1                                                                                                                                                                                                                                                                       |

GPIOX\_FILTER Filters a maximum of four input burrs. Select “gpiox\_filter\_en” to enable four inputs. “gpiox\_filter\_selY” controls which pin of gpio corresponds to the Y input; “gpiox\_filter\_count” controls the width of the filter burrs. GPIO2\_FILTER is shared by GPIO2/3/4.

### 17.3.6 Shadow GPIO

GPIO1 is in PD\_CORE, it has a shadow GPIO1 is in PD\_PMU. You can select whether IO is controlled by GPIO1 or GPIO1\_SHADOW with PMUGRF\_SOC\_CON17/18.

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

| Operational Base |              |
|------------------|--------------|
| Name             | Base Address |
| GPIO0            | 0xFF940000   |
| GPIO1            | 0xFF870000   |
| GPIO1_SHADOW     | 0xFF948000   |
| GPIO2            | 0xFF1C0000   |
| GPIO3            | 0xFF1D0000   |
| GPIO4            | 0xFF1E0000   |

### 17.4.2 Registers Summary

| Name                  | Offset | Size | Reset Value | Description                              |
|-----------------------|--------|------|-------------|------------------------------------------|
| GPIO_SWPORT_DR_L      | 0x0000 | W    | 0x00000000  | Port Data Register (Low)                 |
| GPIO_SWPORT_DR_H      | 0x0004 | W    | 0x00000000  | Port Data Register (High)                |
| GPIO_SWPORT_DDR_L     | 0x0008 | W    | 0x00000000  | Port Data Direction Register (Low)       |
| GPIO_SWPORT_DDR_H     | 0x000C | W    | 0x00000000  | Port Data Direction Register (High)      |
| GPIO_INT_EN_L         | 0x0010 | W    | 0x00000000  | Interrupt Enable Register (Low)          |
| GPIO_INT_EN_H         | 0x0014 | W    | 0x00000000  | Interrupt Enable Register (High)         |
| GPIO_INT_MASK_L       | 0x0018 | W    | 0x00000000  | Interrupt Mask Register (Low)            |
| GPIO_INT_MASK_H       | 0x001C | W    | 0x00000000  | Interrupt Mask Register (High)           |
| GPIO_INT_TYPE_L       | 0x0020 | W    | 0x00000000  | Interrupt Level Register (Low)           |
| GPIO_INT_TYPE_H       | 0x0024 | W    | 0x00000000  | Interrupt Level Register (High)          |
| GPIO_INT_POLARITY_L   | 0x0028 | W    | 0x00000000  | Interrupt Polarity Register (Low)        |
| GPIO_INT_POLARITY_H   | 0x002C | W    | 0x00000000  | Interrupt Polarity Register (High)       |
| GPIO_INT_BOTHEDGE_L   | 0x0030 | W    | 0x00000000  | Interrupt Both Edge Type Register (Low)  |
| GPIO_INT_BOTHEDGE_H   | 0x0034 | W    | 0x00000000  | Interrupt Both Edge Type Register (High) |
| GPIO_DEBOUNCE_L       | 0x0038 | W    | 0x00000000  | Debounce Enable Register (Low)           |
| GPIO_DEBOUNCE_H       | 0x003C | W    | 0x00000000  | Debounce Enable Register (High)          |
| GPIO_DBCLK_DIV_EN_L   | 0x0040 | W    | 0x00000000  | DBCLK Divide Enable Register (Low)       |
| GPIO_DBCLK_DIV_EN_H   | 0x0044 | W    | 0x00000000  | DBCLK Divide Enable Register (High)      |
| GPIO_DBCLK_DIV_CON    | 0x0048 | W    | 0x00000001  | DBCLK Divide Control Register            |
| GPIO_INT_STATUS       | 0x0050 | W    | 0x00000000  | Interrupt Status Register                |
| GPIO_INT_RAWSTATUS    | 0x0058 | W    | 0x00000000  | Interrupt Raw Status Register            |
| GPIO_PORT_EOI_L       | 0x0060 | W    | 0x00000000  | Interrupt Clear Register (Low)           |
| GPIO_PORT_EOI_H       | 0x0064 | W    | 0x00000000  | Interrupt Clear Register (High)          |
| GPIO_EXT_PORT         | 0x0070 | W    | 0x00000000  | External Port Data Register              |
| GPIO_VER_ID           | 0x0078 | W    | 0x010219C8  | Version ID Register                      |
| GPIO_STORE_ST_L       | 0x0080 | W    | 0x00000000  | Store Status Register(Low)               |
| GPIO_STORE_ST_H       | 0x0084 | W    | 0x00000000  | Store Status Register(High)              |
| GPIO_GPIO_REG_GROUP_L | 0x0100 | W    | 0x00000000  | GPIO Group Control                       |

| Name                    | Offset | Size | Reset Value | Description         |
|-------------------------|--------|------|-------------|---------------------|
| GPIO GPIO REG GROUP H   | 0x0104 | W    | 0x0000FFFF  | GPIO Group Control  |
| GPIO GPIO VIRTUAL EN    | 0x0108 | W    | 0x00000000  | GPIO Virtual Enable |
| GPIO GPIO REG GROUP 1_L | 0x0110 | W    | 0x00000000  | GPIO Group Control  |
| GPIO GPIO REG GROUP 1_H | 0x0114 | W    | 0x00000000  | GPIO Group Control  |
| GPIO GPIO REG GROUP 2_L | 0x0118 | W    | 0x00000000  | GPIO Group Control  |
| GPIO GPIO REG GROUP 2_H | 0x011C | W    | 0x00000000  | GPIO Group Control  |
| GPIO GPIO REG GROUP 3_L | 0x0120 | W    | 0x00000000  | GPIO Group Control  |
| GPIO GPIO REG GROUP 3_H | 0x0124 | W    | 0x00000000  | GPIO Group Control  |

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

### 17.4.3 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                                                                                                                                                                                                                                              |
| 15:0  | RW   | 0x0000      | 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<br>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. |

#### 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             | 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_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<br>Values written to this register independently control the direction of the corresponding data bit in the lower 16 bits of I/O Port. |

**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             | 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_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<br>Values written to this register independently control the direction of the corresponding data bit in the upper 16 bits of I/O Port. |

**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             | write_mask<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                                                                                                                                                                                                     |
| 15:0       | RW          | 0x0000             | int_en_low<br>Allows each bit of the lower 16 bits of I/O Port to be configured for interrupts.<br>1'b0: Interrupt is disabled<br>1'b1: Interrupt is enabled<br>Whenever a 1 is written to a bit of this register, it configures the corresponding bit on I/O Port to become an interrupt source; otherwise, I/O Port operates as a normal GPIO signal. Interrupts are disabled on the corresponding bits of I/O Port if the corresponding data direction register is set to Output. |

**GPIO\_INT\_EN\_H**

Address: **Operational Base** + offset (0x0014)

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

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0 | RW   | 0x0000      | <p>int_en_high<br/>Allows each bit of the upper 16 bits of I/O Port to be configured for interrupts.<br/>1'b0: Interrupt is disabled<br/>1'b1: Interrupt is enabled<br/>Whenever a 1 is written to a bit of this register, it configures the corresponding bit on I/O Port to become an interrupt source; otherwise, I/O Port operates as a normal GPIO signal. Interrupts are disabled on the corresponding bits of I/O Port if the corresponding data direction register is set to Output.</p> |

**GPIO INT MASK L**Address: **Operational Base** + offset (0x0018)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                                                                  |
| 15:0  | RW   | 0x0000      | <p>int_mask_low<br/>Controls whether an interrupt on the lower 16 bits of I/O Port can create an interrupt for the interrupt controller by not masking it.<br/>1'b0: Interrupt is unmasked<br/>1'b1: Interrupt is masked<br/>Whenever a 1 is written to a bit in this register, it masks the interrupt generation capability for this signal; otherwise interrupts are allowed through.</p> |

**GPIO INT MASK H**Address: **Operational Base** + offset (0x001C)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                                                                   |
| 15:0  | RW   | 0x0000      | <p>int_mask_high<br/>Controls whether an interrupt on the upper 16 bits of I/O Port can create an interrupt for the interrupt controller by not masking it.<br/>1'b0: Interrupt is unmasked<br/>1'b1: Interrupt is masked<br/>Whenever a 1 is written to a bit in this register, it masks the interrupt generation capability for this signal; otherwise interrupts are allowed through.</p> |

**GPIO INT TYPE L**Address: **Operational Base** + offset (0x0020)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0       | RW          | 0x0000             | <p>int_type_low<br/>Controls the type of interrupt that can occur on the lower 16 bits of I/O Port.<br/>1'b0: Level-sensitive<br/>1'b1: Edge-sensitive<br/>Whenever a 1 is written to a bit of this register, it configures the interrupt type to be edge-sensitive; otherwise, it is level-sensitive.</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<br/>Whenever a 1 is written to a bit of this register, it configures the interrupt type to be edge-sensitive; otherwise, it is level-sensitive.</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>                                                                                                                                                                                                                         |
| 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 BOTEDGE L**Address: **Operational Base** + offset (0x0030)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 15:0  | RW   | 0x0000      | <p>int_bothedge_low<br/>Controls the edge type of interrupt that can occur on the lower 16 bits of I/O Port.<br/>1'b0: Disable both-edge detection<br/>1'b1: Enable both-edge detection<br/>Whenever a particular bit is programmed to 1, it enables the generation of interrupts on both the rising edge and the falling edge of an external input signal corresponding to that bit on I/O Port. The values programmed in the registers int_type_low and int_polarity_low for this particular bit are not considered when the corresponding bit of this register is set to 1. Whenever a particular bit is programmed to 0, the interrupt type depends on the value of the corresponding bits in the int_type_low and int_polarity_low registers.</p> |

**GPIO INT BOTEDGE H**Address: **Operational Base** + offset (0x0034)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 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<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_high and int_polarity_high for this particular bit are not considered when the corresponding bit of this register is set to 1. Whenever a particular bit is programmed to 0, the interrupt type depends on the value of the corresponding bits in the int_type_high and int_polarity_high registers.</p> |

**GPIO DEBOUNCE L**Address: **Operational Base** + offset (0x0038)

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

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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.</p> <p>1'b0: Disable debounce<br/>1'b1: Enable debounce<br/>Writing a 1 to a bit in this register enables the debouncing circuitry. A signal must be valid for two periods of an external clock before it is internally processed.</p> |

**GPIO DEBOUNCE H**Address: Operational Base + offset (0x003C)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                                                                                              |
| 15:0  | RW   | 0x0000      | <p>debounce_high<br/>Controls whether an external signal of the lower 16 bits of I/O Port that is the source of an interrupt needs to be debounced to remove any spurious glitches.<br/>1'b0: Disable debounce<br/>1'b1: Enable debounce<br/>Writing a 1 to a bit in this register enables the debouncing circuitry. A signal must be valid for two periods of an external clock before it is internally processed.</p> |

**GPIO DBCLK DIV EN L**Address: Operational Base + offset (0x0040)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 15:0  | RW   | 0x0000      | <p>dbclk_div_en_low<br/>Controls whether to use the internal divided clock when debounce function is enabled for an external signal of the lower 16 bits of I/O Port.<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.</p> |

**GPIO DBCLK DIV EN H**Address: Operational Base + offset (0x0044)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0       | RW          | 0x0000             | <p>dbclk_div_en_high<br/>Controls whether to use the internal divided clock when debounce function is enabled for an external signal of the upper 16 bits of I/O Port.</p> <p>1'b0: Disable divider for debounce clock<br/>1'b1: Enable divider for debounce clock</p> <p>Whenever a 1 is written to a bit of this register, the clock divided from dbclk is used as debounce clock; otherwise, the original dbclk is used. The clock 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.</p> |

**GPIO DBCLK DIV CON**Address: **Operational Base** + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------|
| 31:24      | RO          | 0x00               | reserved                                                                         |
| 23:0       | RW          | 0x000001           | <p>dbclk_div_con<br/><math>dbclk\_div = dbclk / (dbclk\_div\_con + 1)</math></p> |

**GPIO INT STATUS**Address: **Operational Base** + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p>int_status<br/>Interrupt status of I/O Port.</p> |

**GPIO INT RAWSTATUS**Address: **Operational Base** + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p>int_rawstatus<br/>Interrupt raw status of I/O Port (premasking bits).</p> |

**GPIO PORT EOI L**Address: **Operational Base** + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.</p> <p>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                                                                                                                                |
| 15:0       | R/W SC      | 0x0000             | <p>port_eoi_low<br/>Controls the clearing of edge type interrupts from the lower 16 bits of I/O Port.</p> <p>1'b0: Nothing<br/>1'b1: Clear edge-sensitive interrupt</p> <p>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.</p> |

**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          | 0x010219c8         | ver_id<br>Version ID. |

**GPIO STORE ST L**Address: **Operational Base** + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 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             | store_st_l<br>This register can store the state for each GPIO by user writing to this register.                                  |

**GPIO STORE ST H**Address: **Operational Base** + offset (0x0084)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 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             | store_st_h<br>This register can store the state for each GPIO by user writing to this register.                                  |

**GPIO GPIO REG GROUP L**Address: **Operational Base** + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_mask<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                                                                       |
| 15:0       | RW          | 0x0000             | gpio_reg_group_low<br>This register control the low 16 bit of GPIO and each bit corresponds each GPIO.<br>When virtual_en=1'b1:<br>1'b1: GPIO control by GROUP0 with offset 0x0000<br>1'b0: GPIO control by other GROUP.<br>When virtual_en=1'b0:<br>1'b1: GPIO interrupt connect to gpio_int_flag0<br>1'b0: GPIO interrupt connect to other interrupt |

#### **GPIO GPIO REG GROUP H**

Address: **Operational Base** + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | 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          | 0xfffff            | gpio_reg_group_high<br>This register control the high 16 bit of GPIO and each bit corresponds each GPIO.<br>When virtual_en=1'b1:<br>1'b1: GPIO control by GROUP0 with offset 0x0000<br>1'b0: GPIO control by other GROUP.<br>When virtual_en=1'b0:<br>1'b1: GPIO interrupt connect to gpio_int_flag0<br>1'b0: GPIO interrupt connect to other interrupt |

#### **GPIO GPIO VIRTUAL EN**

Address: **Operational Base** + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | 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:1       | RO          | 0x0000             | reserved                                                                                                                         |
| 0          | RW          | 0x0                | gpio_virtual_en<br>1'b1: Enable virtual, two OS supported<br>1'b0: Disable virtual.<br>Only in GROUP0 with offset 0x0000.        |

#### **GPIO GPIO REG GROUP1 L**

Address: **Operational Base** + offset (0x0110)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0       | RW          | 0x0000             | <p>gpio_reg_group1_low<br/>           This register control the low 16 bit of GPIO and each bit corresponds each GPIO.<br/>           When virtual_en=1'b1:<br/>           1'b1: GPIO control by GROUP1 with offset 0x1000<br/>           1'b0: GPIO control by other GROUP.<br/>           When virtual_en=1'b0:<br/>           1'b1: GPIO interrupt connect to gpio_int_flag1<br/>           1'b0: GPIO interrupt connect to other interrupt</p> |

### **GPIO GPIO REG GROUP1 H**

 Address: **Operational Base** + offset (0x0114)

| <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>gpio_reg_group1_high<br/>           This register control the high 16 bit of GPIO and each bit corresponds each GPIO.<br/>           When virtual_en=1'b1:<br/>           1'b1: GPIO control by GROUP1 with offset 0x1000<br/>           1'b0: GPIO control by other GROUP.<br/>           When virtual_en=1'b0:<br/>           1'b1: GPIO interrupt connect to gpio_int_flag1<br/>           1'b0: GPIO interrupt connect to other interrupt</p> |

### **GPIO GPIO REG GROUP2 L**

 Address: **Operational Base** + offset (0x0118)

| <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>gpio_reg_group2_low<br/>           This register control the low 16 bit of GPIO and each bit corresponds each GPIO.<br/>           When virtual_en=1'b1:<br/>           1'b1: GPIO control by GROUP2 with offset 0x2000<br/>           1'b0: GPIO control by other GROUP.<br/>           When virtual_en=1'b0:<br/>           1'b1: GPIO interrupt connect to gpio_int_flag2<br/>           1'b0: GPIO interrupt connect to other interrupt</p> |

### **GPIO GPIO REG GROUP2 H**

 Address: **Operational Base** + offset (0x011C)

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

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                             |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0 | RW   | 0x0000      | <p>gpio_reg_group2_high<br/>This register control the high 16 bit of GPIO and each bit corresponds each GPIO.<br/>When virtual_en=1'b1:<br/>1'b1: GPIO control by GROUP2 with offset 0x2000<br/>1'b0: GPIO control by other GROUP.<br/>When virtual_en=1'b0:<br/>1'b1: GPIO interrupt connect to gpio_int_flag2<br/>1'b0: GPIO interrupt connect to other interrupt</p> |

**GPIO GPIO REG GROUP3 L**Address: **Operational Base** + offset (0x0120)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                                            |
| 15:0  | RW   | 0x0000      | <p>gpio_reg_group3_low<br/>This register control the low 16 bit of GPIO and each bit corresponds each GPIO.<br/>When virtual_en=1'b1:<br/>1'b1: GPIO control by GROUP3 with offset 0x3000<br/>1'b0: GPIO control by other GROUP.<br/>When virtual_en=1'b0:<br/>1'b1: GPIO interrupt connect to gpio_int_flag3<br/>1'b0: GPIO interrupt connect to other interrupt</p> |

**GPIO GPIO REG GROUP3 H**Address: **Operational Base** + offset (0x0124)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                             |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                                              |
| 15:0  | RW   | 0x0000      | <p>gpio_reg_group3_high<br/>This register control the high 16 bit of GPIO and each bit corresponds each GPIO.<br/>When virtual_en=1'b1:<br/>1'b1: GPIO control by GROUP3 with offset 0x3000<br/>1'b0: GPIO control by other GROUP.<br/>When virtual_en=1'b0:<br/>1'b1: GPIO interrupt connect to gpio_int_flag3<br/>1'b0: GPIO interrupt connect to other interrupt</p> |

**17.5 Interface Description**

Table 17-2 GPIO Interface Description

| Module Pin             | Pad Name | IOMUX Setting                          |
|------------------------|----------|----------------------------------------|
| <b>GPIO0 Interface</b> |          |                                        |
| gpio0_port [0]         | GPIO0_A0 | GPIO0_IOC_GPIO0A_IOMUX_SEL_0[3:0]=4'h0 |
| gpio0_port [1]         | GPIO0_A1 | GPIO0_IOC_GPIO0A_IOMUX_SEL_0[7:4]=4'h0 |

| <b>Module Pin</b>      | <b>Pad Name</b> | <b>IOMUX Setting</b>                     |
|------------------------|-----------------|------------------------------------------|
| gpio0_port [2]         | GPIO0_A2        | GPIO0_IOC_GPIO0A_IOMUX_SEL_0[11:8]=4'h0  |
| gpio0_port [3]         | GPIO0_A3        | GPIO0_IOC_GPIO0A_IOMUX_SEL_0[15:12]=4'h0 |
| gpio0_port [4]         | GPIO0_A4        | GPIO0_IOC_GPIO0A_IOMUX_SEL_1[3:0]=4'h0   |
| gpio0_port [5]         | GPIO0_A5        | GPIO0_IOC_GPIO0A_IOMUX_SEL_1[7:4]=4'h0   |
| gpio0_port [6]         | GPIO0_A6        | GPIO0_IOC_GPIO0A_IOMUX_SEL_1[11:8]=4'h0  |
| gpio0_port [7]         | GPIO0_A7        | GPIO0_IOC_GPIO0A_IOMUX_SEL_1[15:12]=4'h0 |
| gpio0_port [8]         | GPIO0_B0        | GPIO0_IOC_GPIO0B_IOMUX_SEL_0[3:0]=4'h0   |
| gpio0_port [9]         | GPIO0_B1        | GPIO0_IOC_GPIO0B_IOMUX_SEL_0[7:4]=4'h0   |
| gpio0_port [10]        | GPIO0_B2        | GPIO0_IOC_GPIO0B_IOMUX_SEL_0[11:8]=4'h0  |
| gpio0_port [11]        | GPIO0_B3        | GPIO0_IOC_GPIO0B_IOMUX_SEL_0[15:12]=4'h0 |
| gpio0_port [12]        | GPIO0_B4        | GPIO0_IOC_GPIO0B_IOMUX_SEL_1[3:0]=4'h0   |
| gpio0_port [13]        | GPIO0_B5        | GPIO0_IOC_GPIO0B_IOMUX_SEL_1[7:4]=4'h0   |
| gpio0_port [14]        | GPIO0_B6        | GPIO0_IOC_GPIO0B_IOMUX_SEL_1[11:8]=4'h0  |
| gpio0_port [15]        | GPIO0_B7        | GPIO0_IOC_GPIO0B_IOMUX_SEL_1[15:12]=4'h0 |
| gpio0_port [16]        | GPIO0_C0        | GPIO0_IOC_GPIO0C_IOMUX_SEL_0[3:0]=4'h0   |
| gpio0_port [17]        | GPIO0_C1        | GPIO0_IOC_GPIO0C_IOMUX_SEL_0[7:4]=4'h0   |
| gpio0_port [18]        | GPIO0_C2        | GPIO0_IOC_GPIO0C_IOMUX_SEL_0[11:8]=4'h0  |
| gpio0_port [19]        | GPIO0_C3        | GPIO0_IOC_GPIO0C_IOMUX_SEL_0[15:12]=4'h0 |
| gpio0_port [20]        | GPIO0_C4        | GPIO0_IOC_GPIO0C_IOMUX_SEL_1[3:0]=4'h0   |
| gpio0_port [21]        | GPIO0_C5        | GPIO0_IOC_GPIO0C_IOMUX_SEL_1[7:4]=4'h0   |
| gpio0_port [22]        | GPIO0_C6        | GPIO0_IOC_GPIO0C_IOMUX_SEL_1[11:8]=4'h0  |
| gpio0_port [23]        | GPIO0_C7        | GPIO0_IOC_GPIO0C_IOMUX_SEL_1[15:12]=4'h0 |
| gpio0_port [24]        | GPIO0_D0        | GPIO0_IOC_GPIO0D_CON[1:0]=2'h0           |
| <b>GPIO1 Interface</b> |                 |                                          |
| gpio1_port [0]         | GPIO1_A0        | GPIO1_IOC_GPIO1A_IOMUX_SEL_0[3:0]=4'h0   |
| gpio1_port [1]         | GPIO1_A1        | GPIO1_IOC_GPIO1A_IOMUX_SEL_0[7:4]=4'h0   |
| gpio1_port [2]         | GPIO1_A2        | GPIO1_IOC_GPIO1A_IOMUX_SEL_0[11:8]=4'h0  |
| gpio1_port             | GPIO1_          | GPIO1_IOC_GPIO1A_IOMUX_SEL_0[15:12]=4'h0 |

| <b>Module Pin</b>      | <b>Pad Name</b> | <b>IOMUX Setting</b>                     |
|------------------------|-----------------|------------------------------------------|
| [3]                    | A3              |                                          |
| gpio1_port [4]         | GPIO1_A4        | GPIO1_IOC_GPIO1A_IOMUX_SEL_1[3:0]=4'h0   |
| gpio1_port [5]         | GPIO1_A5        | GPIO1_IOC_GPIO1A_IOMUX_SEL_1[7:4]=4'h0   |
| gpio1_port [6]         | GPIO1_A6        | GPIO1_IOC_GPIO1A_IOMUX_SEL_1[11:8]=4'h0  |
| gpio1_port [7]         | GPIO1_A7        | GPIO1_IOC_GPIO1A_IOMUX_SEL_1[15:12]=4'h0 |
| gpio1_port [8]         | GPIO1_B0        | GPIO1_IOC_GPIO1B_IOMUX_SEL_0[3:0]=4'h0   |
| gpio1_port [9]         | GPIO1_B1        | GPIO1_IOC_GPIO1B_IOMUX_SEL_0[7:4]=4'h0   |
| gpio1_port [10]        | GPIO1_B2        | GPIO1_IOC_GPIO1B_IOMUX_SEL_0[11:8]=4'h0  |
| gpio1_port [11]        | GPIO1_B3        | GPIO1_IOC_GPIO1B_IOMUX_SEL_0[15:12]=4'h0 |
| gpio1_port [12]        | GPIO1_B4        | GPIO1_IOC_GPIO1B_IOMUX_SEL_1[3:0]=4'h0   |
| gpio1_port [13]        | GPIO1_B5        | GPIO1_IOC_GPIO1B_IOMUX_SEL_1[7:4]=4'h0   |
| gpio1_port [14]        | GPIO1_B6        | GPIO1_IOC_GPIO1B_IOMUX_SEL_1[11:8]=4'h0  |
| gpio1_port [15]        | GPIO1_B7        | GPIO1_IOC_GPIO1B_IOMUX_SEL_1[15:12]=4'h0 |
| gpio1_port [16]        | GPIO1_C0        | GPIO1_IOC_GPIO1C_IOMUX_SEL_0[3:0]=4'h0   |
| gpio1_port [17]        | GPIO1_C1        | GPIO1_IOC_GPIO1C_IOMUX_SEL_0[7:4]=4'h0   |
| gpio1_port [18]        | GPIO1_C2        | GPIO1_IOC_GPIO1C_IOMUX_SEL_0[11:8]=4'h0  |
| gpio1_port [19]        | GPIO1_C3        | GPIO1_IOC_GPIO1C_IOMUX_SEL_0[15:12]=4'h0 |
| gpio1_port [20]        | GPIO1_C4        | GPIO1_IOC_GPIO1C_IOMUX_SEL_1[3:0]=4'h0   |
| gpio1_port [21]        | GPIO1_C5        | GPIO1_IOC_GPIO1C_IOMUX_SEL_1[7:4]=4'h0   |
| gpio1_port [22]        | GPIO1_C6        | GPIO1_IOC_GPIO1C_IOMUX_SEL_1[11:8]=4'h0  |
| gpio1_port [23]        | GPIO1_C7        | GPIO1_IOC_GPIO1C_IOMUX_SEL_1[15:12]=4'h0 |
| gpio1_port [24]        | GPIO1_D0        | GPIO1_IOC_GPIO1D_IOMUX_SEL_0[3:0]=4'h0   |
| gpio1_port [25]        | GPIO1_D1        | GPIO1_IOC_GPIO1D_IOMUX_SEL_0[7:4]=4'h0   |
| gpio1_port [26]        | GPIO1_D2        | GPIO1_IOC_GPIO1D_IOMUX_SEL_0[11:8]=4'h0  |
| gpio1_port [27]        | GPIO1_D3        | GPIO1_IOC_GPIO1D_IOMUX_SEL_0[15:12]=4'h0 |
| <b>GPIO2 Interface</b> |                 |                                          |
| gpio2_port [0]         | GPIO2_A0        | GPIO2_IOC_GPIO2A_IOMUX_SEL_0[3:0]=4'h0   |
| gpio2_port [1]         | GPIO2_A1        | GPIO2_IOC_GPIO2A_IOMUX_SEL_0[7:4]=4'h0   |

| <b>Module Pin</b>      | <b>Pad Name</b> | <b>IOMUX Setting</b>                     |
|------------------------|-----------------|------------------------------------------|
| gpio2_port [2]         | GPIO2_A2        | GPIO2_IOC_GPIO2A_IOMUX_SEL_0[11:8]=4'h0  |
| gpio2_port [3]         | GPIO2_A3        | GPIO2_IOC_GPIO2A_IOMUX_SEL_0[15:12]=4'h0 |
| gpio2_port [4]         | GPIO2_A4        | GPIO2_IOC_GPIO2A_IOMUX_SEL_1[3:0]=4'h0   |
| gpio2_port [5]         | GPIO2_A5        | GPIO2_IOC_GPIO2A_IOMUX_SEL_1[7:4]=4'h0   |
| gpio2_port [6]         | GPIO2_B0        | GPIO2_IOC_GPIO2B_IOMUX_SEL_0[3:0]=4'h0   |
| gpio2_port [7]         | GPIO2_B1        | GPIO2_IOC_GPIO2B_IOMUX_SEL_0[7:4]=4'h0   |
| gpio2_port [8]         | GPIO2_B2        | GPIO2_IOC_GPIO2B_IOMUX_SEL_0[11:8]=4'h0  |
| gpio2_port [9]         | GPIO2_B3        | GPIO2_IOC_GPIO2B_IOMUX_SEL_0[15:12]=4'h0 |
| gpio2_port [10]        | GPIO2_B4        | GPIO2_IOC_GPIO2B_IOMUX_SEL_1[3:0]=4'h0   |
| gpio2_port [11]        | GPIO2_B5        | GPIO2_IOC_GPIO2B_IOMUX_SEL_1[7:4]=4'h0   |
| gpio2_port [12]        | GPIO2_B6        | GPIO2_IOC_GPIO2B_IOMUX_SEL_1[11:8]=4'h0  |
| gpio2_port [13]        | GPIO2_B7        | GPIO2_IOC_GPIO2B_IOMUX_SEL_1[15:12]=4'h0 |
| gpio2_port [14]        | GPIO2_C0        | GPIO2_IOC_GPIO2C_IOMUX_SEL_0[3:0]=4'h0   |
| <b>GPIO3 Interface</b> |                 |                                          |
| gpio3_port [0]         | GPIO3_A0        | GPIO3_IOC_GPIO3A_IOMUX_SEL_0[3:0]=4'h0   |
| gpio3_port [1]         | GPIO3_A1        | GPIO3_IOC_GPIO3A_IOMUX_SEL_0[7:4]=4'h0   |
| gpio3_port [2]         | GPIO3_A2        | GPIO3_IOC_GPIO3A_IOMUX_SEL_0[11:8]=4'h0  |
| gpio3_port [3]         | GPIO3_A3        | GPIO3_IOC_GPIO3A_IOMUX_SEL_0[15:12]=4'h0 |
| gpio3_port [4]         | GPIO3_A4        | GPIO3_IOC_GPIO3A_IOMUX_SEL_1[3:0]=4'h0   |
| gpio3_port [5]         | GPIO3_A5        | GPIO3_IOC_GPIO3A_IOMUX_SEL_1[7:4]=4'h0   |
| gpio3_port [6]         | GPIO3_A6        | GPIO3_IOC_GPIO3A_IOMUX_SEL_1[11:8]=4'h0  |
| gpio3_port [7]         | GPIO3_A7        | GPIO3_IOC_GPIO3A_IOMUX_SEL_1[15:12]=4'h0 |
| gpio3_port [8]         | GPIO3_B0        | GPIO3_IOC_GPIO3B_IOMUX_SEL_0[3:0]=4'h0   |
| gpio3_port [9]         | GPIO3_B1        | GPIO3_IOC_GPIO3B_IOMUX_SEL_0[7:4]=4'h0   |
| gpio3_port [10]        | GPIO3_B2        | GPIO3_IOC_GPIO3B_IOMUX_SEL_0[11:8]=4'h0  |
| gpio3_port [11]        | GPIO3_B3        | GPIO3_IOC_GPIO3B_IOMUX_SEL_0[15:12]=4'h0 |
| gpio3_port [12]        | GPIO3_B4        | GPIO3_IOC_GPIO3B_IOMUX_SEL_1[3:0]=4'h0   |
| gpio3_port             | GPIO3_          | GPIO3_IOC_GPIO3B_IOMUX_SEL_1[7:4]=4'h0   |

| Module Pin             | Pad Name | IOMUX Setting                           |
|------------------------|----------|-----------------------------------------|
| [13]                   | B5       |                                         |
| gpio3_port [14]        | GPIO3_B6 | GPIO3_IOC_GPIO3B_IOMUX_SEL_1[11:8]=4'h0 |
| <b>GPIO4 Interface</b> |          |                                         |
| gpio4_port [0]         | GPO4_A0  |                                         |
| gpio4_port [1]         | GPO4_A1  |                                         |
| gpio4_port [2]         | GPO4_A2  |                                         |
| gpio4_port [3]         | GPO4_A3  |                                         |
| gpio4_port [4]         | GPO4_A4  |                                         |
| gpio4_port [5]         | GPO4_A5  |                                         |
| gpio4_port [6]         | GPIO4_B0 | GPIO4_IOC_SARADC_CON [4]=1'h1           |
| gpio4_port [7]         | GPIO4_B1 | GPIO4_IOC_SARADC_CON [5]=1'h1           |
| gpio4_port [8]         | GPIO4_B2 | GPIO4_IOC_SARADC_CON [6]=1'h1           |
| gpio4_port [9]         | GPIO4_B3 | GPIO4_IOC_SARADC_CON [7]=1'h1           |

Notes: Unused Module Pin is tied to zero!

Notes: I=input, O=output, I/O=input/output, bidirectional

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

### 17.6.1 GPIO Mode of SARADC

The pad of GPIO4\_B0/GPIO4\_B1/GPIO4\_B2/GPIO4\_B3 are shared with SARADC and can be used as 1.8V input/output. Before using GPIO4\_B0~ GPIO4\_B3 as common GPIO, you must send 0x00F000F0 to register 0xFF4D8840 (GPIO4\_IOC\_SARADC\_CON) first to set GPIO intput enable. And you can configure other GPIO properties in GPIO4\_IOC\_SARADC\_CON (e.g. pull up/down, Schmitter).

### 17.6.2 GPIO Mode of SARADC

The pad of GPIO4\_A0/GPIO4\_A1/GPIO4\_A2/GPIO4\_A3/GPIO4\_A4/ GPIO4\_A5 are shared with MIPI D-PHY and can be used as 1.8V output. To switch mode to GPIO, refer to the MIPI D-PHY Chapter.

### 17.6.3 Configuration of GPIO0D0

GPIO0D0 is configured using a separate register GPIO0\_IOC\_GPIO0D\_CON (address 0xFF950830). Select the function by the following values:

- GPIO0\_IOC\_GPIO0D\_CON [1:0]==2'b00 for GPIO mode
- GPIO0\_IOC\_GPIO0D\_CON [1:0]==2'b01 for OSC\_CLK\_OUT
- GPIO0\_IOC\_GPIO0D\_CON [1:0]==2'b10 for REF\_CLK0\_OUT

## Chapter 18 IO Controller (IOC)

### 18.1 Overview

The IO Controller (IOC) will be used by the software to do some static Settings related to IOs.

### 18.2 Function Description

The functions of the IO Controller (IOC) are as follows:

- GPIO IOMUX control
- GPIO PAD pull-up/pull-down, drive strength, power supply voltage and other configurations

### 18.3 GPIO0\_IOC Register Description

#### 18.3.1 Registers Summary

| Name                         | Offset | Size | Reset Value | Description                       |
|------------------------------|--------|------|-------------|-----------------------------------|
| GPIO0_IOC_GPIO0A_IOMUX_SEL_0 | 0x0000 | W    | 0x00000000  | GPIO0A IOMUX Select Register 0    |
| GPIO0_IOC_GPIO0A_IOMUX_SEL_1 | 0x0004 | W    | 0x00000000  | GPIO0A IOMUX Select Register 1    |
| GPIO0_IOC_GPIO0B_IOMUX_SEL_0 | 0x0008 | W    | 0x00000000  | GPIO0B IOMUX Select Register 0    |
| GPIO0_IOC_GPIO0B_IOMUX_SEL_1 | 0x000C | W    | 0x00000000  | GPIO0B IOMUX Select Register 1    |
| GPIO0_IOC_GPIO0C_IOMUX_SEL_0 | 0x0010 | W    | 0x00000000  | GPIO0C IOMUX Select Register 0    |
| GPIO0_IOC_GPIO0C_IOMUX_SEL_1 | 0x0014 | W    | 0x00000070  | GPIO0C IOMUX Select Register 1    |
| GPIO0_IOC_GPIO0A_DS_0        | 0x0100 | W    | 0x00000707  | GPIO0A Driver Strength Register 0 |
| GPIO0_IOC_GPIO0A_DS_1        | 0x0104 | W    | 0x00000707  | GPIO0A Driver Strength Register 1 |
| GPIO0_IOC_GPIO0A_DS_2        | 0x0108 | W    | 0x00000707  | GPIO0A Driver Strength Register 2 |
| GPIO0_IOC_GPIO0A_DS_3        | 0x010C | W    | 0x00000707  | GPIO0A Driver Strength Register 3 |
| GPIO0_IOC_GPIO0B_DS_0        | 0x0110 | W    | 0x00000707  | GPIO0B Driver Strength Register 0 |
| GPIO0_IOC_GPIO0B_DS_1        | 0x0114 | W    | 0x00000707  | GPIO0B Driver Strength Register 1 |
| GPIO0_IOC_GPIO0B_DS_2        | 0x0118 | W    | 0x00000707  | GPIO0B Driver Strength Register 2 |
| GPIO0_IOC_GPIO0B_DS_3        | 0x011C | W    | 0x00000707  | GPIO0B Driver Strength Register 3 |
| GPIO0_IOC_GPIO0C_DS_0        | 0x0120 | W    | 0x00000707  | GPIO0C Driver Strength Register 0 |
| GPIO0_IOC_GPIO0C_DS_1        | 0x0124 | W    | 0x00000707  | GPIO0C Driver Strength Register 1 |
| GPIO0_IOC_GPIO0C_DS_2        | 0x0128 | W    | 0x00000707  | GPIO0C Driver Strength Register 2 |
| GPIO0_IOC_GPIO0C_DS_3        | 0x012C | W    | 0x00000707  | GPIO0C Driver Strength Register 3 |
| GPIO0_IOC_GPIO0A_PUL_L       | 0x0200 | W    | 0x0000AA99  | GPIO0A Pull up/down Register      |

| Name                          | Offset | Size | Reset Value | Description                     |
|-------------------------------|--------|------|-------------|---------------------------------|
| <u>GPIO0 IOC GPIO0B PUL_L</u> | 0x0204 | W    | 0x0000AAAA  | GPIO0B Pull up/down Register    |
| <u>GPIO0 IOC GPIO0C PUL_L</u> | 0x0208 | W    | 0x000052AA  | GPIO0C Pull up/down Register    |
| <u>GPIO0 IOC GPIO0A IE</u>    | 0x0300 | W    | 0x000000FF  | GPIO0A Input Enable Register    |
| <u>GPIO0 IOC GPIO0B IE</u>    | 0x0304 | W    | 0x000000FF  | GPIO0B Input Enable Register    |
| <u>GPIO0 IOC GPIO0C IE</u>    | 0x0308 | W    | 0x000000DF  | GPIO0C Input Enable Register    |
| <u>GPIO0 IOC GPIO0A SMT</u>   | 0x0400 | W    | 0x000000FF  | GPIO0A Schmitt Trigger Register |
| <u>GPIO0 IOC GPIO0B SMT</u>   | 0x0404 | W    | 0x000000FF  | GPIO0B Schmitt Trigger Register |
| <u>GPIO0 IOC GPIO0C SMT</u>   | 0x0408 | W    | 0x000000FF  | GPIO0C Schmitt Trigger Register |
| <u>GPIO0 IOC GPIO0A SUS</u>   | 0x0500 | W    | 0x00000000  | GPIO0A SUS Register             |
| <u>GPIO0 IOC GPIO0B SUS</u>   | 0x0504 | W    | 0x00000000  | GPIO0B SUS Register             |
| <u>GPIO0 IOC GPIO0C SUS</u>   | 0x0508 | W    | 0x00000000  | GPIO0C SUS Register             |
| <u>GPIO0 IOC GPIO0A SL</u>    | 0x0600 | W    | 0x0000FFFF  | GPIO0A Slew Rate Register       |
| <u>GPIO0 IOC GPIO0B SL</u>    | 0x0604 | W    | 0x0000FFFF  | GPIO0B Slew Rate Register       |
| <u>GPIO0 IOC GPIO0C SL</u>    | 0x0608 | W    | 0x0000FFFF  | GPIO0C Slew Rate Register       |
| <u>GPIO0 IOC GPIO0A OD</u>    | 0x0700 | W    | 0x00000000  | GPIO0A Open-Drain Register      |
| <u>GPIO0 IOC GPIO0B OD</u>    | 0x0704 | W    | 0x00000000  | GPIO0B Open-Drain Register      |
| <u>GPIO0 IOC GPIO0C OD</u>    | 0x0708 | W    | 0x00000000  | GPIO0C Open-Drain Register      |
| <u>GPIO0 IOC GPIO0 IDDQ</u>   | 0x0800 | W    | 0x00000000  | GPIO0 IDDQ Register             |
| <u>GPIO0 IOC GPIO0D CON</u>   | 0x0830 | W    | 0x0000072C  | GPIO0D0 Control Register        |

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

### 18.3.2 Detail Registers Description

#### GPIO0 IOC GPIO0A IOMUX SEL\_0

Address: Operational Base(0xFF950000) + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:12 | RW   | 0x0         | gpio0a3_sel<br>4'h0: GPIO0_A3<br>4'h1: SAI0_SDO<br>4'h7: RM_IO3                                                                   |
| 11:8  | RW   | 0x0         | gpio0a2_sel<br>4'h0: GPIO0_A2<br>4'h1: SAI0_MCLK<br>4'h7: RM_IO2                                                                  |
| 7:4   | RW   | 0x0         | gpio0a1_sel<br>4'h0: GPIO0_A1<br>4'h1: SAI0_SCLK<br>4'h7: RM_IO1                                                                  |
| 3:0   | RW   | 0x0         | gpio0a0_sel<br>4'h0: GPIO0_A0<br>4'h1: SAI0_LRCK<br>4'h7: RM_IO0                                                                  |

#### GPIO0 IOC GPIO0A IOMUX SEL\_1

Address: Operational Base(0xFF950000) + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:12      | RW          | 0x0                | gpio0a7_sel<br>4'h0: GPIO0_A7<br>4'h1: SAI0_SDI3<br>4'h2: SPI1_CSN1<br>4'h7: RM_IO7                                               |
| 11:8       | RW          | 0x0                | gpio0a6_sel<br>4'h0: GPIO0_A6<br>4'h1: SAI0_SDI2<br>4'h7: RM_IO6                                                                  |
| 7:4        | RW          | 0x0                | gpio0a5_sel<br>4'h0: GPIO0_A5<br>4'h1: SAI0_SDI1<br>4'h7: RM_IO5                                                                  |
| 3:0        | RW          | 0x0                | gpio0a4_sel<br>4'h0: GPIO0_A4<br>4'h1: SAI0_SDI0<br>4'h7: RM_IO4                                                                  |

**GPIO0 IOC GPIO0B IOMUX SEL 0**

Address: Operational Base(0xFF950000) + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:12      | RW          | 0x0                | gpio0b3_sel<br>4'h0: GPIO0_B3<br>4'h1: SAI1_SDI<br>4'h7: RM_IO11                                                                  |
| 11:8       | RW          | 0x0                | gpio0b2_sel<br>4'h0: GPIO0_B2<br>4'h1: SAI1_LRCK<br>4'h2: SPI1_MISO<br>4'h7: RM_IO10                                              |
| 7:4        | RW          | 0x0                | gpio0b1_sel<br>4'h0: GPIO0_B1<br>4'h1: SAI1_SCLK<br>4'h2: SPI1_MOSI<br>4'h7: RM_IO9                                               |
| 3:0        | RW          | 0x0                | gpio0b0_sel<br>4'h0: GPIO0_B0<br>4'h1: SAI1_MCLK<br>4'h2: SPI1_CLK<br>4'h7: RM_IO8                                                |

**GPIO0 IOC GPIO0B IOMUX SEL 1**

Address: Operational Base(0xFF950000) + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:12      | RW          | 0x0                | gpio0b7_sel<br>4'h0: GPIO0_B7<br>4'h1: SAI1_SDO3<br>4'h2: SPI0_CS1<br>4'h7: RM_IO15                                               |
| 11:8       | RW          | 0x0                | gpio0b6_sel<br>4'h0: GPIO0_B6<br>4'h1: SAI1_SDO2<br>4'h2: SPI1_CS0<br>4'h7: RM_IO14                                               |
| 7:4        | RW          | 0x0                | gpio0b5_sel<br>4'h0: GPIO0_B5<br>4'h1: SAI1_SDO1<br>4'h7: RM_IO13                                                                 |
| 3:0        | RW          | 0x0                | gpio0b4_sel<br>4'h0: GPIO0_B4<br>4'h1: SAI1_SDO0<br>4'h7: RM_IO12                                                                 |

**GPIO0 IOC GPIO0C IOMUX SEL\_0**

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:12      | RW          | 0x0                | gpio0c3_sel<br>4'h0: GPIO0_C3<br>4'h1: ETH_CLK1_25M_OUT<br>4'h2: SPI0_CS0<br>4'h7: RM_IO19                                        |
| 11:8       | RW          | 0x0                | gpio0c2_sel<br>4'h0: GPIO0_C2<br>4'h1: REF_CLK1_OUT<br>4'h2: SPI0_MISO<br>4'h7: RM_IO18                                           |
| 7:4        | RW          | 0x0                | gpio0c1_sel<br>4'h0: GPIO0_C1<br>4'h2: SPI0_MOSI<br>4'h7: RM_IO17                                                                 |
| 3:0        | RW          | 0x0                | gpio0c0_sel<br>4'h0: GPIO0_C0<br>4'h2: SPI0_CLK<br>4'h7: RM_IO16                                                                  |

**GPIO0 IOC GPIO0C IOMUX SEL\_1**

Address: Operational Base(0xFF950000) + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:12      | RW          | 0x0                | gpio0c7_sel<br>4'h0: GPIO0_C7<br>4'h1: UART0_RX<br>4'h2: JTAG_TMS_M1<br>4'h7: RM_IO23                                             |
| 11:8       | RW          | 0x0                | gpio0c6_sel<br>4'h0: GPIO0_C6<br>4'h1: UART0_TX<br>4'h2: JTAG_TCK_M1<br>4'h7: RM_IO22                                             |
| 7:4        | RW          | 0x7                | gpio0c5_sel<br>4'h0: GPIO0_C5<br>4'h1: CPU_AV_S<br>4'h7: RM_IO21                                                                  |
| 3:0        | RW          | 0x0                | gpio0c4_sel<br>4'h0: GPIO0_C4<br>4'h1: ETH_CLK0_25M_OUT<br>4'h2: AUPLL_CLK_IN<br>4'h7: RM_IO20                                    |

### **GPIO0 IOC GPIO0A DS 0**

Address: Operational Base(0xFF950000) + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 13:8       | RW          | 0x07               | gpio0a1_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 5:0        | RW          | 0x07               | gpio0a0_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

### **GPIO0 IOC GPIO0A DS 1**

Address: Operational Base(0xFF950000) + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 13:8       | RW          | 0x07               | gpio0a3_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 5:0        | RW          | 0x07               | gpio0a2_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO0 IOC GPIO0A DS 2**

Address: Operational Base(0xFF950000) + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 13:8       | RW          | 0x07               | gpio0a5_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 5:0        | RW          | 0x07               | gpio0a4_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO0 IOC GPIO0A DS 3**

Address: Operational Base(0xFF950000) + offset (0x010C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 13:8       | RW          | 0x07               | gpio0a7_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 5:0        | RW          | 0x07               | gpio0a6_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO0 IOC GPIO0B DS 0**

Address: Operational Base(0xFF950000) + 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 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 13:8       | RW          | 0x07               | gpio0b1_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:0        | RW          | 0x07               | <p>gpio0b0_ds</p> <p>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.</p> <p>6'b000000: Disable<br/>6'b000001: Level0<br/>6'b000011: Level1<br/>6'b000111: Level2<br/>6'b001111: Level3<br/>6'b011111: Level4<br/>6'b111111: Level5</p> |

### **GPIO0 IOC GPIO0B DS 1**

Address: Operational Base(0xFF950000) + offset (0x0114)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | <p>write_enable</p> <p>Write enable for lower 16bits, each bit is individual.</p> <p>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                         |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                  |
| 13:8       | RW          | 0x07               | <p>gpio0b3_ds</p> <p>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.</p> <p>6'b000000: Disable<br/>6'b000001: Level0<br/>6'b000011: Level1<br/>6'b000111: Level2<br/>6'b001111: Level3<br/>6'b011111: Level4<br/>6'b111111: Level5</p> |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                  |
| 5:0        | RW          | 0x07               | <p>gpio0b2_ds</p> <p>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.</p> <p>6'b000000: Disable<br/>6'b000001: Level0<br/>6'b000011: Level1<br/>6'b000111: Level2<br/>6'b001111: Level3<br/>6'b011111: Level4<br/>6'b111111: Level5</p> |

### **GPIO0 IOC GPIO0B DS 2**

Address: Operational Base(0xFF950000) + offset (0x0118)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:8       | RW          | 0x07               | gpio0b5_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 5:0        | RW          | 0x07               | gpio0b4_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO0 IOC GPIO0B DS 3**

Address: Operational Base(0xFF950000) + 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 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 13:8       | RW          | 0x07               | gpio0b7_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 5:0        | RW          | 0x07               | gpio0b6_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO0 IOC GPIO0C DS 0**

Address: Operational Base(0xFF950000) + 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 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 13:8       | RW          | 0x07               | gpio0c1_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 5:0        | RW          | 0x07               | gpio0c0_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO0 IOC GPIO0C DS 1**

Address: Operational Base(0xFF950000) + 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 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 13:8       | RW          | 0x07               | gpio0c3_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 5:0        | RW          | 0x07               | gpio0c2_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO0 IOC GPIO0C DS 2**

Address: Operational Base(0xFF950000) + offset (0x0128)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 13:8       | RW          | 0x07               | gpio0c5_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 5:0        | RW          | 0x07               | gpio0c4_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO0 IOC GPIO0C DS 3**

Address: Operational Base(0xFF950000) + offset (0x012C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 13:8       | RW          | 0x07               | gpio0c7_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:0        | RW          | 0x07               | <p>gpio0c6_ds<br/> The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br/> 6'b000000: Disable<br/> 6'b000001: Level0<br/> 6'b000011: Level1<br/> 6'b000111: Level2<br/> 6'b001111: Level3<br/> 6'b011111: Level4<br/> 6'b111111: Level5</p> |

**GPIO0 IOC GPIO0A PULL**

Address: Operational Base(0xFF950000) + offset (0x0200)

| <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:14      | RW          | 0x2                | <p>gpio0a7_pull<br/> Weak pull down/up for pad<br/> 2'b00: z<br/> 2'b01: up<br/> 2'b10: down<br/> 2'b11: illegal</p>                           |
| 13:12      | RW          | 0x2                | <p>gpio0a6_pull<br/> Weak pull down/up for pad<br/> 2'b00: z<br/> 2'b01: up<br/> 2'b10: down<br/> 2'b11: illegal</p>                           |
| 11:10      | RW          | 0x2                | <p>gpio0a5_pull<br/> Weak pull down/up for pad<br/> 2'b00: z<br/> 2'b01: up<br/> 2'b10: down<br/> 2'b11: illegal</p>                           |
| 9:8        | RW          | 0x2                | <p>gpio0a4_pull<br/> Weak pull down/up for pad<br/> 2'b00: z<br/> 2'b01: up<br/> 2'b10: down<br/> 2'b11: illegal</p>                           |
| 7:6        | RW          | 0x2                | <p>gpio0a3_pull<br/> Weak pull down/up for pad<br/> 2'b00: z<br/> 2'b01: up<br/> 2'b10: down<br/> 2'b11: illegal</p>                           |
| 5:4        | RW          | 0x1                | <p>gpio0a2_pull<br/> Weak pull down/up for pad<br/> 2'b00: z<br/> 2'b01: up<br/> 2'b10: down<br/> 2'b11: illegal</p>                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 3:2        | RW          | 0x2                | gpio0a1_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 1:0        | RW          | 0x1                | gpio0a0_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |

**GPIO0 IOC GPIO0B PULL**

Address: Operational Base(0xFF950000) + offset (0x0204)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:14      | RW          | 0x2                | gpio0b7_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |
| 13:12      | RW          | 0x2                | gpio0b6_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |
| 11:10      | RW          | 0x2                | gpio0b5_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |
| 9:8        | RW          | 0x2                | gpio0b4_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |
| 7:6        | RW          | 0x2                | gpio0b3_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |
| 5:4        | RW          | 0x2                | gpio0b2_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 3:2        | RW          | 0x2                | gpio0b1_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 1:0        | RW          | 0x2                | gpio0b0_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |

**GPIO0 IOC GPIO0C PULL**

Address: Operational Base(0xFF950000) + offset (0x0208)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:14      | RW          | 0x1                | gpio0c7_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |
| 13:12      | RW          | 0x1                | gpio0c6_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |
| 11:10      | RW          | 0x0                | gpio0c5_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |
| 9:8        | RW          | 0x2                | gpio0c4_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |
| 7:6        | RW          | 0x2                | gpio0c3_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |
| 5:4        | RW          | 0x2                | gpio0c2_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 3:2        | RW          | 0x2                | gpio0c1_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 1:0        | RW          | 0x2                | gpio0c0_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |

### **GPIO0 IOC GPIO0A IE**

Address: Operational Base(0xFF950000) + 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 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>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 6          | RW          | 0x1                | gpio0a6_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 5          | RW          | 0x1                | gpio0a5_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 4          | RW          | 0x1                | gpio0a4_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 3          | RW          | 0x1                | gpio0a3_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 2          | RW          | 0x1                | gpio0a2_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 1          | RW          | 0x1                | gpio0a1_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 0          | RW          | 0x1                | gpio0a0_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |

### **GPIO0 IOC GPIO0B IE**

Address: Operational Base(0xFF950000) + 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 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>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 6          | RW          | 0x1                | gpio0b6_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 5          | RW          | 0x1                | gpio0b5_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 4          | RW          | 0x1                | gpio0b4_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 3          | RW          | 0x1                | gpio0b3_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 2          | RW          | 0x1                | gpio0b2_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 1          | RW          | 0x1                | gpio0b1_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 0          | RW          | 0x1                | gpio0b0_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |

**GPIO0 IOC GPIO0C IE**

Address: Operational Base(0xFF950000) + 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 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>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 6          | RW          | 0x1                | gpio0c6_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                             |
|------------|-------------|--------------------|----------------------------------------------------------------|
| 5          | RW          | 0x0                | gpio0c5_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable |
| 4          | RW          | 0x1                | gpio0c4_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable |
| 3          | RW          | 0x1                | gpio0c3_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable |
| 2          | RW          | 0x1                | gpio0c2_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable |
| 1          | RW          | 0x1                | gpio0c1_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable |
| 0          | RW          | 0x1                | gpio0c0_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable |

**GPIO0 IOC GPIO0A SMT**

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

| <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                | gpio0a7_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 6          | RW          | 0x1                | gpio0a6_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 5          | RW          | 0x1                | gpio0a5_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 4          | RW          | 0x1                | gpio0a4_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 3          | RW          | 0x1                | gpio0a3_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------|
| 2          | RW          | 0x1                | gpio0a2_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable |
| 1          | RW          | 0x1                | gpio0a1_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable |
| 0          | RW          | 0x1                | gpio0a0_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable |

**GPIO0 IOC GPIO0B SMT**

Address: Operational Base(0xFF950000) + offset (0x0404)

| <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                | gpio0b7_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 6          | RW          | 0x1                | gpio0b6_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 5          | RW          | 0x1                | gpio0b5_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 4          | RW          | 0x1                | gpio0b4_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 3          | RW          | 0x1                | gpio0b3_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 2          | RW          | 0x1                | gpio0b2_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 1          | RW          | 0x1                | gpio0b1_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 0          | RW          | 0x1                | gpio0b0_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |

**GPIO0 IOC GPIO0C SMT**

## RK3506 TRM (Part 1)

Address: Operational Base(0xFF950000) + offset (0x0408)

| 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         | gpio0c7_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 6     | RW   | 0x1         | gpio0c6_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 5     | RW   | 0x1         | gpio0c5_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 4     | RW   | 0x1         | gpio0c4_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 3     | RW   | 0x1         | gpio0c3_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 2     | RW   | 0x1         | gpio0c2_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 1     | RW   | 0x1         | gpio0c1_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 0     | RW   | 0x1         | gpio0c0_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |

## GPIO0 IOC GPIO0A SUS

Address: Operational Base(0xFF950000) + offset (0x0500)

| 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         | gpio0a7_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 6     | RW   | 0x0         | gpio0a6_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 5          | RW          | 0x0                | gpio0a5_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable |
| 4          | RW          | 0x0                | gpio0a4_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable |
| 3          | RW          | 0x0                | gpio0a3_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable |
| 2          | RW          | 0x0                | gpio0a2_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable |
| 1          | RW          | 0x0                | gpio0a1_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable |
| 0          | RW          | 0x0                | gpio0a0_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable |

**GPIO0 IOC GPIO0B SUS**

Address: Operational Base(0xFF950000) + offset (0x0504)

| <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                | gpio0b7_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 6          | RW          | 0x0                | gpio0b6_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 5          | RW          | 0x0                | gpio0b5_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 4          | RW          | 0x0                | gpio0b4_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 3          | RW          | 0x0                | gpio0b3_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | gpio0b2_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable |
| 1          | RW          | 0x0                | gpio0b1_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable |
| 0          | RW          | 0x0                | gpio0b0_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable |

**GPIO0 IOC GPIO0C SUS**

Address: Operational Base(0xFF950000) + offset (0x0508)

| <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                | gpio0c7_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 6          | RW          | 0x0                | gpio0c6_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 5          | RW          | 0x0                | gpio0c5_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 4          | RW          | 0x0                | gpio0c4_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 3          | RW          | 0x0                | gpio0c3_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 2          | RW          | 0x0                | gpio0c2_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 1          | RW          | 0x0                | gpio0c1_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 0          | RW          | 0x0                | gpio0c0_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |

**GPIO0 IOC GPIO0A SL**

## RK3506 TRM (Part 1)

Address: Operational Base(0xFF950000) + offset (0x0600)

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

## GPIO0 IOC GPIO0B SL

Address: Operational Base(0xFF950000) + offset (0x0604)

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

**GPIO0 IOC GPIO0C SL**

Address: Operational Base(0xFF950000) + offset (0x0608)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                    |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                              |
| 15:14 | RW   | 0x3         | gpio0c7_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest. Always set to 2'b11 in normal operation.<br>2'b00: slowest<br>2'b11: fastest |
| 13:12 | RW   | 0x3         | gpio0c6_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest. Always set to 2'b11 in normal operation.<br>2'b00: slowest<br>2'b11: fastest |
| 11:10 | RW   | 0x3         | gpio0c5_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest. Always set to 2'b11 in normal operation.<br>2'b00: slowest<br>2'b11: fastest |
| 9:8   | RW   | 0x3         | gpio0c4_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest. Always set to 2'b11 in normal operation.<br>2'b00: slowest<br>2'b11: fastest |
| 7:6   | RW   | 0x3         | gpio0c3_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest. Always set to 2'b11 in normal operation.<br>2'b00: slowest<br>2'b11: fastest |
| 5:4   | RW   | 0x3         | gpio0c2_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest. Always set to 2'b11 in normal operation.<br>2'b00: slowest<br>2'b11: fastest |
| 3:2   | RW   | 0x3         | gpio0c1_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest. Always set to 2'b11 in normal operation.<br>2'b00: slowest<br>2'b11: fastest |
| 1:0   | RW   | 0x3         | gpio0c0_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest. Always set to 2'b11 in normal operation.<br>2'b00: slowest<br>2'b11: fastest |

**GPIO0 IOC GPIO0A OD**

Address: Operational Base(0xFF950000) + offset (0x0700)

| <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                | gpio0a7_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |
| 6          | RW          | 0x0                | gpio0a6_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |
| 5          | RW          | 0x0                | gpio0a5_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |
| 4          | RW          | 0x0                | gpio0a4_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |
| 3          | RW          | 0x0                | gpio0a3_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |
| 2          | RW          | 0x0                | gpio0a2_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |
| 1          | RW          | 0x0                | gpio0a1_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |
| 0          | RW          | 0x0                | gpio0a0_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |

### **GPIO0 IOC GPIO0B OD**

Address: Operational Base(0xFF950000) + offset (0x0704)

| <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                | gpio0b7_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |
| 6          | RW          | 0x0                | gpio0b6_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 5          | RW          | 0x0                | gpio0b5_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 4          | RW          | 0x0                | gpio0b4_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 3          | RW          | 0x0                | gpio0b3_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 2          | RW          | 0x0                | gpio0b2_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 1          | RW          | 0x0                | gpio0b1_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 0          | RW          | 0x0                | gpio0b0_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |

**GPIO0\_IOC\_GPIO0C\_OD**

Address: Operational Base(0xFF950000) + offset (0x0708)

| <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                | gpio0c7_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |
| 6          | RW          | 0x0                | gpio0c6_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |
| 5          | RW          | 0x0                | gpio0c5_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |
| 4          | RW          | 0x0                | gpio0c4_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |
| 3          | RW          | 0x0                | gpio0c3_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | gpio0c2_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 1          | RW          | 0x0                | gpio0c1_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 0          | RW          | 0x0                | gpio0c0_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |

**GPIO0 IOC GPIO0 IDDQ**

Address: Operational Base(0xFF950000) + offset (0x0800)

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

**GPIO0 IOC GPIO0D CON**

Address: Operational Base(0xFF950000) + offset (0x0830)

| <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:9       | RW          | 0x3                | gpio0d0_smt<br>Schmitter trigger enable<br>2'b00: disable<br>2'b11: enable<br>Others: Reserved                                    |
| 8          | RW          | 0x1                | gpio0d0_sl<br>Slew rate control enable<br>1'b0: disable<br>1'b1: enable                                                           |
| 7          | RW          | 0x0                | gpio0d0_he<br>Hold enable<br>1'b0: diable<br>1'b1: enable                                                                         |
| 6          | RW          | 0x0                | gpio0d0_ps<br>Weak pull down/up select for pad<br>1'b0: down<br>1'b1: up                                                          |
| 5          | RW          | 0x1                | gpio0d0_pe<br>Weak pull down/up enable for pad<br>1'b0: diable<br>1'b1: enable                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:3        | RW          | 0x1                | gpio0d0_ds<br>The drive strength of IO. The weakest setting is 2'b00 and the strongest setting is 2'b11.<br>2'b00: Level0<br>2'b01: Level1<br>2'b10: Level2<br>2'b11: Level3 |
| 2          | RW          | 0x1                | gpio0d0_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                                                               |
| 1:0        | RW          | 0x0                | gpio0d0_sel<br>2'b00: GPIO0D0<br>2'b01: OSC_CLK_OUT<br>2'b10: REF_CLK0_OUT<br>2'b11: Reserved                                                                                |

## 18.4 GPIO1\_IOC Register Description

### 18.4.1 Registers Summary

| <b>Name</b>                          | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                |
|--------------------------------------|---------------|-------------|--------------------|-----------------------------------|
| <u>GPIO1 IOC GPIO1A IOM UX_SEL_0</u> | 0x0020        | W           | 0x00000000         | GPIO1A IOMUX Select Register 0    |
| <u>GPIO1 IOC GPIO1A IOM UX_SEL_1</u> | 0x0024        | W           | 0x00000000         | GPIO1A IOMUX Select Register 1    |
| <u>GPIO1 IOC GPIO1B IOM UX_SEL_0</u> | 0x0028        | W           | 0x00000000         | GPIO1B IOMUX Select Register 0    |
| <u>GPIO1 IOC GPIO1B IOM UX_SEL_1</u> | 0x002C        | W           | 0x00000000         | GPIO1B IOMUX Select Register 1    |
| <u>GPIO1 IOC GPIO1C IOM UX_SEL_0</u> | 0x0030        | W           | 0x00000000         | GPIO1C IOMUX Select Register 0    |
| <u>GPIO1 IOC GPIO1C IOM UX_SEL_1</u> | 0x0034        | W           | 0x00000000         | GPIO1C IOMUX Select Register 1    |
| <u>GPIO1 IOC GPIO1D IOM UX_SEL_0</u> | 0x0038        | W           | 0x00000000         | GPIO1D IOMUX Select Register 0    |
| <u>GPIO1 IOC GPIO1A DS_0</u>         | 0x0140        | W           | 0x00000707         | GPIO1A Driver Strength Register 0 |
| <u>GPIO1 IOC GPIO1A DS_1</u>         | 0x0144        | W           | 0x00000707         | GPIO1A Driver Strength Register 1 |
| <u>GPIO1 IOC GPIO1A DS_2</u>         | 0x0148        | W           | 0x00000707         | GPIO1A Driver Strength Register 2 |
| <u>GPIO1 IOC GPIO1A DS_3</u>         | 0x014C        | W           | 0x00000707         | GPIO1A Driver Strength Register 3 |
| <u>GPIO1 IOC GPIO1B DS_0</u>         | 0x0150        | W           | 0x00000707         | GPIO1B Driver Strength Register 0 |
| <u>GPIO1 IOC GPIO1B DS_1</u>         | 0x0154        | W           | 0x00000707         | GPIO1B Driver Strength Register 1 |
| <u>GPIO1 IOC GPIO1B DS_2</u>         | 0x0158        | W           | 0x00000707         | GPIO1B Driver Strength Register 2 |
| <u>GPIO1 IOC GPIO1B DS_3</u>         | 0x015C        | W           | 0x00000707         | GPIO1B Driver Strength Register 3 |
| <u>GPIO1 IOC GPIO1C DS_0</u>         | 0x0160        | W           | 0x00000707         | GPIO1C Driver Strength Register 0 |

| Name                   | Offset | Size | Reset Value | Description                       |
|------------------------|--------|------|-------------|-----------------------------------|
| GPIO1_IOC_GPIO1C_DS_1  | 0x0164 | W    | 0x00000707  | GPIO1C Driver Strength Register 1 |
| GPIO1_IOC_GPIO1C_DS_2  | 0x0168 | W    | 0x00000707  | GPIO1C Driver Strength Register 2 |
| GPIO1_IOC_GPIO1C_DS_3  | 0x016C | W    | 0x00000707  | GPIO1C Driver Strength Register 3 |
| GPIO1_IOC_GPIO1D_DS_0  | 0x0170 | W    | 0x00000707  | GPIO1D Driver Strength Register 0 |
| GPIO1_IOC_GPIO1D_DS_1  | 0x0174 | W    | 0x00000707  | GPIO1D Driver Strength Register 1 |
| GPIO1_IOC_GPIO1A_PUL_L | 0x0210 | W    | 0x0000AAAA  | GPIO1A Pull up/down Register      |
| GPIO1_IOC_GPIO1B_PUL_L | 0x0214 | W    | 0x0000AAAA  | GPIO1B Pull up/down Register      |
| GPIO1_IOC_GPIO1C_PUL_L | 0x0218 | W    | 0x0000AAAA  | GPIO1C Pull up/down Register      |
| GPIO1_IOC_GPIO1D_PUL_L | 0x021C | W    | 0x000000AA  | GPIO1D Pull up/down Register      |
| GPIO1_IOC_GPIO1A_IE    | 0x0310 | W    | 0x000000FF  | GPIO1A Input Enable Register      |
| GPIO1_IOC_GPIO1B_IE    | 0x0314 | W    | 0x000000FF  | GPIO1B Input Enable Register      |
| GPIO1_IOC_GPIO1C_IE    | 0x0318 | W    | 0x000000FF  | GPIO1C Input Enable Register      |
| GPIO1_IOC_GPIO1D_IE    | 0x031C | W    | 0x0000000F  | GPIO1D Input Enable Register      |
| GPIO1_IOC_GPIO1A_SMT   | 0x0410 | W    | 0x000000FF  | GPIO1A Schmitt Trigger Register   |
| GPIO1_IOC_GPIO1B_SMT   | 0x0414 | W    | 0x000000FF  | GPIO1B Schmitt Trigger Register   |
| GPIO1_IOC_GPIO1C_SMT   | 0x0418 | W    | 0x000000FF  | GPIO1C Schmitt Trigger Register   |
| GPIO1_IOC_GPIO1D_SMT   | 0x041C | W    | 0x0000000F  | GPIO1D Schmitt Trigger Register   |
| GPIO1_IOC_GPIO1A_SUS   | 0x0510 | W    | 0x00000000  | GPIO1A SUS Register               |
| GPIO1_IOC_GPIO1B_SUS   | 0x0514 | W    | 0x00000000  | GPIO1B SUS Register               |
| GPIO1_IOC_GPIO1C_SUS   | 0x0518 | W    | 0x00000000  | GPIO1C SUS Register               |
| GPIO1_IOC_GPIO1D_SUS   | 0x051C | W    | 0x00000000  | GPIO1D SUS Register               |
| GPIO1_IOC_GPIO1A_SL    | 0x0610 | W    | 0x0000FFFF  | GPIO1A Slew Rate Register         |
| GPIO1_IOC_GPIO1B_SL    | 0x0614 | W    | 0x0000FFFF  | GPIO1B Slew Rate Register         |
| GPIO1_IOC_GPIO1C_SL    | 0x0618 | W    | 0x0000FFFF  | GPIO1C Slew Rate Register         |
| GPIO1_IOC_GPIO1D_SL    | 0x061C | W    | 0x000000FF  | GPIO1D Slew Rate Register         |
| GPIO1_IOC_GPIO1A_OD    | 0x0710 | W    | 0x00000000  | GPIO1A Open-Drain Register        |
| GPIO1_IOC_GPIO1B_OD    | 0x0714 | W    | 0x00000000  | GPIO1B Open-Drain Register        |
| GPIO1_IOC_GPIO1C_OD    | 0x0718 | W    | 0x00000000  | GPIO1C Open-Drain Register        |
| GPIO1_IOC_GPIO1D_OD    | 0x071C | W    | 0x00000000  | GPIO1D Open-Drain Register        |
| GPIO1_IOC_GPIO1_IDDQ   | 0x0810 | W    | 0x00000000  | GPIO1 IDDQ Register               |

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

### 18.4.2 Detail Registers Description

#### GPIO1\_IOC\_GPIO1A\_IOMUX\_SEL\_0

Address: Operational Base(0xFF660000) + offset (0x0020)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 15:12      | RW          | 0x0                | gpio1a3_sel<br>4'h0: GPIO1_A3<br>4'h1: VO_LCDC_CLK<br>4'h2: DSMC_D0<br>4'h3: FLEXBUS1_D3                                              |
| 11:8       | RW          | 0x0                | gpio1a2_sel<br>4'h0: GPIO1_A2<br>4'h1: VO_LCDC_HSYNC<br>4'h2: DSMC_DQS0<br>4'h3: FLEXBUS1_D2                                          |
| 7:4        | RW          | 0x0                | gpio1a1_sel<br>4'h0: GPIO1_A1<br>4'h1: VO_LCDC_VSYNC<br>4'h2: DSMC_CLKN<br>4'h3: FLEXBUS1_D1<br>4'h4: DSMC_INT0<br>4'h8: DSMC_SLV_INT |
| 3:0        | RW          | 0x0                | gpio1a0_sel<br>4'h0: GPIO1_A0<br>4'h1: VO_LCDC_DEN<br>4'h2: DSMC_CLKP<br>4'h3: FLEXBUS1_D0                                            |

**GPIO1 IOC GPIO1A IOMUX SEL\_1**

Address: Operational Base(0xFF660000) + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:12      | RW          | 0x0                | gpio1a7_sel<br>4'h0: GPIO1_A7<br>4'h1: VO_LCDC_D20<br>4'h2: DSMC_D4<br>4'h3: FLEXBUS1_D7                                          |
| 11:8       | RW          | 0x0                | gpio1a6_sel<br>4'h0: GPIO1_A6<br>4'h1: VO_LCDC_D21<br>4'h2: DSMC_D3<br>4'h3: FLEXBUS1_D6                                          |
| 7:4        | RW          | 0x0                | gpio1a5_sel<br>4'h0: GPIO1_A5<br>4'h1: VO_LCDC_D22<br>4'h2: DSMC_D2<br>4'h3: FLEXBUS1_D5                                          |
| 3:0        | RW          | 0x0                | gpio1a4_sel<br>4'h0: GPIO1_A4<br>4'h1: VO_LCDC_D23<br>4'h2: DSMC_D1<br>4'h3: FLEXBUS1_D4                                          |

**GPIO1 IOC GPIO1B IOMUX SEL\_0**

Address: Operational Base(0xFF660000) + offset (0x0028)

| 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:12 | RW   | 0x0         | gpio1b3_sel<br>4'h0: GPIO1_B3<br>4'h1: VO_LCDC_D16<br>4'h2: DSMC_INT3<br>4'h3: FLEXBUS1_D11<br>4'h4: FLEXBUS0_D14<br>4'h5: FLEXBUS1_CS_N_M1<br>4'h6: SAI2_LRCK_M1<br>4'h7: RM_IO26 |
| 11:8  | RW   | 0x0         | gpio1b2_sel<br>4'h0: GPIO1_B2<br>4'h1: VO_LCDC_D17<br>4'h2: DSMC_INT2<br>4'h3: FLEXBUS1_D10<br>4'h4: FLEXBUS0_D15<br>4'h5: FLEXBUS0_CS_N_M1<br>4'h6: SAI2_SCLK_M1<br>4'h7: RM_IO25 |
| 7:4   | RW   | 0x0         | gpio1b1_sel<br>4'h0: GPIO1_B1<br>4'h1: VO_LCDC_D18<br>4'h2: DSMC_CS_N1<br>4'h3: FLEXBUS1_D9<br>4'h5: FLEXBUS1_CS_N_M0<br>4'h6: UART5_CTSN_M1<br>4'h7: RM_IO24                      |
| 3:0   | RW   | 0x0         | gpio1b0_sel<br>4'h0: GPIO1_B0<br>4'h1: VO_LCDC_D19<br>4'h2: DSMC_D5<br>4'h3: FLEXBUS1_D8<br>4'h5: FLEXBUS0_CS_N_M0                                                                 |

**GPIO1\_IOC GPIO1B\_IOMUX\_SEL\_1**

Address: Operational Base(0xFF660000) + offset (0x002C)

| 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:12 | RW   | 0x0         | gpio1b7_sel<br>4'h0: GPIO1_B7<br>4'h1: VO_LCDC_D12<br>4'h2: DSMC_RDYN<br>4'h3: FLEXBUS1_D15<br>4'h4: FLEXBUS0_D10<br>4'h5: FLEXBUS1_CS_N_M3 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 11:8       | RW          | 0x0                | gpio1b6_sel<br>4'h0: GPIO1_B6<br>4'h1: VO_LCDC_D13<br>4'h2: DSMC_CSNO<br>4'h3: FLEXBUS1_D14<br>4'h4: FLEXBUS0_D11<br>4'h5: FLEXBUS0_CSN_M3 |
| 7:4        | RW          | 0x0                | gpio1b5_sel<br>4'h0: GPIO1_B5<br>4'h1: VO_LCDC_D14<br>4'h2: DSMC_D7<br>4'h3: FLEXBUS1_D13<br>4'h4: FLEXBUS0_D12<br>4'h5: FLEXBUS1_CSN_M2   |
| 3:0        | RW          | 0x0                | gpio1b4_sel<br>4'h0: GPIO1_B4<br>4'h1: VO_LCDC_D15<br>4'h2: DSMC_D6<br>4'h3: FLEXBUS1_D12<br>4'h4: FLEXBUS0_D13<br>4'h5: FLEXBUS0_CSN_M2   |

**GPIO1\_IOC\_GPIO1C\_IOMUX\_SEL\_0**

Address: Operational Base(0xFF660000) + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                  |
| 15:12      | RW          | 0x0                | gpio1c3_sel<br>4'h0: GPIO1_C3<br>4'h1: VO_LCDC_D8<br>4'h2: DSMC_D10<br>4'h3: FLEXBUS0_D8<br>4'h5: FLEXBUS1_CSN_M5<br>4'h6: SAI2_SDO_M1<br>4'h7: RM_IO28<br>4'h8: DSMC_SLV_D1                       |
| 11:8       | RW          | 0x0                | gpio1c2_sel<br>4'h0: GPIO1_C2<br>4'h1: VO_LCDC_D9<br>4'h2: DSMC_D9<br>4'h3: FLEXBUS0_D9<br>4'h4: DSM_AUD_RP_M0<br>4'h5: FLEXBUS0_CSN_M5<br>4'h6: SAI2_SDI_M1<br>4'h7: RM_IO27<br>4'h8: DSMC_SLV_D0 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4        | RW          | 0x0                | gpio1c1_sel<br>4'h0: GPIO1_C1<br>4'h1: VO_LCDC_D10<br>4'h2: DSMC_D8<br>4'h3: FLEXBUS0_CLK<br>4'h4: DSM_AUD_RN_M0<br>4'h5: FLEXBUS1_CSN_M4<br>4'h6: SAI2_MCLK_M1<br>4'h8: DSMC_SLV_DQS0 |
| 3:0        | RW          | 0x0                | gpio1c0_sel<br>4'h0: GPIO1_C0<br>4'h1: VO_LCDC_D11<br>4'h2: DSMC_RESETN<br>4'h3: FLEXBUS1_CLK<br>4'h4: DSMC_INT1<br>4'h5: FLEXBUS0_CSN_M4<br>4'h8: DSMC_SLV_CLK                        |

**GPIO1 IOC GPIO1C IOMUX SEL 1**

Address: Operational Base(0xFF660000) + 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 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:12      | RW          | 0x0                | gpio1c7_sel<br>4'h0: GPIO1_C7<br>4'h1: VO_LCDC_D4<br>4'h2: DSMC_D14<br>4'h3: FLEXBUS0_D4<br>4'h8: DSMC_SLV_D5                     |
| 11:8       | RW          | 0x0                | gpio1c6_sel<br>4'h0: GPIO1_C6<br>4'h1: VO_LCDC_D5<br>4'h2: DSMC_D13<br>4'h3: FLEXBUS0_D5<br>4'h8: DSMC_SLV_D4                     |
| 7:4        | RW          | 0x0                | gpio1c5_sel<br>4'h0: GPIO1_C5<br>4'h1: VO_LCDC_D6<br>4'h2: DSMC_D12<br>4'h3: FLEXBUS0_D6<br>4'h8: DSMC_SLV_D3                     |
| 3:0        | RW          | 0x0                | gpio1c4_sel<br>4'h0: GPIO1_C4<br>4'h1: VO_LCDC_D7<br>4'h2: DSMC_D11<br>4'h3: FLEXBUS0_D7<br>4'h8: DSMC_SLV_D2                     |

**GPIO1 IOC GPIO1D IOMUX SEL 0**

Address: Operational Base(0xFF660000) + offset (0x0038)

| 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:12 | RW   | 0x0         | gpio1d3_sel<br>4'h0: GPIO1_D3<br>4'h1: VO_LCDC_D0<br>4'h2: DSMC_CSN3<br>4'h3: FLEXBUS0_D0<br>4'h6: UART5_RX_M1<br>4'h7: RM_IO31<br>4'h8: DSMC_SLV_RDYN                        |
| 11:8  | RW   | 0x0         | gpio1d2_sel<br>4'h0: GPIO1_D2<br>4'h1: VO_LCDC_D1<br>4'h2: DSMC_CSN2<br>4'h3: FLEXBUS0_D1<br>4'h6: UART5_TX_M1<br>4'h7: RM_IO30<br>4'h8: DSMC_SLV_CSN0                        |
| 7:4   | RW   | 0x0         | gpio1d1_sel<br>4'h0: GPIO1_D1<br>4'h1: VO_LCDC_D2<br>4'h2: DSMC_DQS1<br>4'h3: FLEXBUS0_D2<br>4'h4: DSM_AUD_LP_M0<br>4'h6: UART5_RTSN_M1<br>4'h7: RM_IO29<br>4'h8: DSMC_SLV_D7 |
| 3:0   | RW   | 0x0         | gpio1d0_sel<br>4'h0: GPIO1_D0<br>4'h1: VO_LCDC_D3<br>4'h2: DSMC_D15<br>4'h3: FLEXBUS0_D3<br>4'h4: DSM_AUD_LN_M0<br>4'h8: DSMC_SLV_D6                                          |

**GPIO1\_IOC GPIO1A DS\_0**

Address: Operational Base(0xFF660000) + offset (0x0140)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                          |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                             |
| 13:8  | RW   | 0x07        | gpio1a1_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:0        | RW          | 0x07               | <p>gpio1a0_ds<br/> The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br/> 6'b000000: Disable<br/> 6'b000001: Level0<br/> 6'b000011: Level1<br/> 6'b000111: Level2<br/> 6'b001111: Level3<br/> 6'b011111: Level4<br/> 6'b111111: Level5</p> |

### **GPIO1 IOC GPIO1A DS 1**

Address: Operational Base(0xFF660000) + offset (0x0144)

| <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:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                    |
| 13:8       | RW          | 0x07               | <p>gpio1a3_ds<br/> The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br/> 6'b000000: Disable<br/> 6'b000001: Level0<br/> 6'b000011: Level1<br/> 6'b000111: Level2<br/> 6'b001111: Level3<br/> 6'b011111: Level4<br/> 6'b111111: Level5</p> |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                    |
| 5:0        | RW          | 0x07               | <p>gpio1a2_ds<br/> The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br/> 6'b000000: Disable<br/> 6'b000001: Level0<br/> 6'b000011: Level1<br/> 6'b000111: Level2<br/> 6'b001111: Level3<br/> 6'b011111: Level4<br/> 6'b111111: Level5</p> |

### **GPIO1 IOC GPIO1A DS 2**

Address: Operational Base(0xFF660000) + offset (0x0148)

| <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:14      | RO          | 0x0                | reserved                                                                                                                                       |

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                          |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:8 | RW   | 0x07        | gpio1a5_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                             |
| 5:0  | RW   | 0x07        | gpio1a4_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO1 IOC GPIO1A DS 3**

Address: Operational Base(0xFF660000) + offset (0x014C)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                          |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                             |
| 13:8  | RW   | 0x07        | gpio1a7_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                             |
| 5:0   | RW   | 0x07        | gpio1a6_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO1 IOC GPIO1B DS 0**

Address: Operational Base(0xFF660000) + offset (0x0150)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                          |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                             |
| 13:8  | RW   | 0x07        | gpio1b1_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                             |
| 5:0   | RW   | 0x07        | gpio1b0_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO1 IOC GPIO1B DS 1**

Address: Operational Base(0xFF660000) + offset (0x0154)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                          |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                             |
| 13:8  | RW   | 0x07        | gpio1b3_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                             |
| 5:0   | RW   | 0x07        | gpio1b2_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO1 IOC GPIO1B DS 2**

Address: Operational Base(0xFF660000) + 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 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 13:8       | RW          | 0x07               | gpio1b5_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 5:0        | RW          | 0x07               | gpio1b4_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO1 IOC GPIO1B DS 3**

Address: Operational Base(0xFF660000) + 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 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 13:8       | RW          | 0x07               | gpio1b7_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:0        | RW          | 0x07               | <p>gpio1b6_ds</p> <p>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.</p> <p>6'b000000: Disable<br/>6'b000001: Level0<br/>6'b000011: Level1<br/>6'b000111: Level2<br/>6'b001111: Level3<br/>6'b011111: Level4<br/>6'b111111: Level5</p> |

### **GPIO1 IOC GPIO1C DS 0**

Address: Operational Base(0xFF660000) + offset (0x0160)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | <p>write_enable</p> <p>Write enable for lower 16bits, each bit is individual.</p> <p>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                         |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                  |
| 13:8       | RW          | 0x07               | <p>gpio1c1_ds</p> <p>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.</p> <p>6'b000000: Disable<br/>6'b000001: Level0<br/>6'b000011: Level1<br/>6'b000111: Level2<br/>6'b001111: Level3<br/>6'b011111: Level4<br/>6'b111111: Level5</p> |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                  |
| 5:0        | RW          | 0x07               | <p>gpio1c0_ds</p> <p>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.</p> <p>6'b000000: Disable<br/>6'b000001: Level0<br/>6'b000011: Level1<br/>6'b000111: Level2<br/>6'b001111: Level3<br/>6'b011111: Level4<br/>6'b111111: Level5</p> |

### **GPIO1 IOC GPIO1C DS 1**

Address: Operational Base(0xFF660000) + offset (0x0164)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:8       | RW          | 0x07               | gpio1c3_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 5:0        | RW          | 0x07               | gpio1c2_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO1 IOC GPIO1C DS\_2**

Address: Operational Base(0xFF660000) + offset (0x0168)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 13:8       | RW          | 0x07               | gpio1c5_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 5:0        | RW          | 0x07               | gpio1c4_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO1 IOC GPIO1C DS\_3**

Address: Operational Base(0xFF660000) + offset (0x016C)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                          |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                             |
| 13:8  | RW   | 0x07        | gpio1c7_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                             |
| 5:0   | RW   | 0x07        | gpio1c6_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO1 IOC GPIO1D DS 0**

Address: Operational Base(0xFF660000) + offset (0x0170)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                          |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                             |
| 13:8  | RW   | 0x07        | gpio1d1_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                             |
| 5:0   | RW   | 0x07        | gpio1d0_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO1 IOC GPIO1D DS 1**

Address: Operational Base(0xFF660000) + offset (0x0174)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 13:8       | RW          | 0x07               | gpio1d3_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 5:0        | RW          | 0x07               | gpio1d2_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO1 IOC GPIO1A PULL**

Address: Operational Base(0xFF660000) + offset (0x0210)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:14      | RW          | 0x2                | gpio1a7_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |
| 13:12      | RW          | 0x2                | gpio1a6_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |
| 11:10      | RW          | 0x2                | gpio1a5_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 9:8        | RW          | 0x2                | gpio1a4_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 7:6        | RW          | 0x2                | gpio1a3_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 5:4        | RW          | 0x2                | gpio1a2_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 3:2        | RW          | 0x2                | gpio1a1_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 1:0        | RW          | 0x2                | gpio1a0_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |

**GPIO1 IOC GPIO1B PULL**

Address: Operational Base(0xFF660000) + offset (0x0214)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:14      | RW          | 0x2                | gpio1b7_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |
| 13:12      | RW          | 0x2                | gpio1b6_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |
| 11:10      | RW          | 0x2                | gpio1b5_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 9:8        | RW          | 0x2                | gpio1b4_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 7:6        | RW          | 0x2                | gpio1b3_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 5:4        | RW          | 0x2                | gpio1b2_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 3:2        | RW          | 0x2                | gpio1b1_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 1:0        | RW          | 0x2                | gpio1b0_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |

**GPIO1 IOC GPIO1C PULL**

Address: Operational Base(0xFF660000) + 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 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:14      | RW          | 0x2                | gpio1c7_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |
| 13:12      | RW          | 0x2                | gpio1c6_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |
| 11:10      | RW          | 0x2                | gpio1c5_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 9:8        | RW          | 0x2                | gpio1c4_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 7:6        | RW          | 0x2                | gpio1c3_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 5:4        | RW          | 0x2                | gpio1c2_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 3:2        | RW          | 0x2                | gpio1c1_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 1:0        | RW          | 0x2                | gpio1c0_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |

**GPIO1 IOC GPIO1D PULL**

Address: Operational Base(0xFF660000) + 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 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                | gpio1d3_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |
| 5:4        | RW          | 0x2                | gpio1d2_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 3:2        | RW          | 0x2                | gpio1d1_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 1:0        | RW          | 0x2                | gpio1d0_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |

### **GPIO1 IOC GPIO1A IE**

Address: Operational Base(0xFF660000) + 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 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>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 6          | RW          | 0x1                | gpio1a6_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 5          | RW          | 0x1                | gpio1a5_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 4          | RW          | 0x1                | gpio1a4_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 3          | RW          | 0x1                | gpio1a3_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 2          | RW          | 0x1                | gpio1a2_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 1          | RW          | 0x1                | gpio1a1_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 0          | RW          | 0x1                | gpio1a0_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |

### **GPIO1 IOC GPIO1B IE**

Address: Operational Base(0xFF660000) + 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 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>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 6          | RW          | 0x1                | gpio1b6_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 5          | RW          | 0x1                | gpio1b5_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 4          | RW          | 0x1                | gpio1b4_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 3          | RW          | 0x1                | gpio1b3_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 2          | RW          | 0x1                | gpio1b2_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 1          | RW          | 0x1                | gpio1b1_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 0          | RW          | 0x1                | gpio1b0_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |

**GPIO1 IOC GPIO1C IE**

Address: Operational Base(0xFF660000) + 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 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>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 6          | RW          | 0x1                | gpio1c6_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                             |
|------------|-------------|--------------------|----------------------------------------------------------------|
| 5          | RW          | 0x1                | gpio1c5_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable |
| 4          | RW          | 0x1                | gpio1c4_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable |
| 3          | RW          | 0x1                | gpio1c3_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable |
| 2          | RW          | 0x1                | gpio1c2_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable |
| 1          | RW          | 0x1                | gpio1c1_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable |
| 0          | RW          | 0x1                | gpio1c0_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable |

**GPIO1\_IOC\_GPIO1D\_IE**

Address: Operational Base(0xFF660000) + 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 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4       | RO          | 0x000              | reserved                                                                                                                          |
| 3          | RW          | 0x1                | gpio1d3_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 2          | RW          | 0x1                | gpio1d2_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 1          | RW          | 0x1                | gpio1d1_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 0          | RW          | 0x1                | gpio1d0_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |

**GPIO1\_IOC\_GPIO1A\_SMT**

Address: Operational Base(0xFF660000) + offset (0x0410)

| <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_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 6          | RW          | 0x1                | gpio1a6_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 5          | RW          | 0x1                | gpio1a5_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 4          | RW          | 0x1                | gpio1a4_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 3          | RW          | 0x1                | gpio1a3_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 2          | RW          | 0x1                | gpio1a2_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 1          | RW          | 0x1                | gpio1a1_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 0          | RW          | 0x1                | gpio1a0_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |

**GPIO1 IOC GPIO1B SMT**

Address: Operational Base(0xFF660000) + offset (0x0414)

| <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_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 6          | RW          | 0x1                | gpio1b6_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------|
| 5          | RW          | 0x1                | gpio1b5_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable |
| 4          | RW          | 0x1                | gpio1b4_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable |
| 3          | RW          | 0x1                | gpio1b3_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable |
| 2          | RW          | 0x1                | gpio1b2_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable |
| 1          | RW          | 0x1                | gpio1b1_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable |
| 0          | RW          | 0x1                | gpio1b0_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable |

**GPIO1\_IOC GPIO1C\_SMT**

Address: Operational Base(0xFF660000) + offset (0x0418)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------|
| 2          | RW          | 0x1                | gpio1c2_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable |
| 1          | RW          | 0x1                | gpio1c1_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable |
| 0          | RW          | 0x1                | gpio1c0_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable |

### **GPIO1 IOC GPIO1D SMT**

Address: Operational Base(0xFF660000) + offset (0x041C)

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

### **GPIO1 IOC GPIO1A SUS**

Address: Operational Base(0xFF660000) + offset (0x0510)

| <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_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 6          | RW          | 0x0                | gpio1a6_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 5          | RW          | 0x0                | gpio1a5_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable |
| 4          | RW          | 0x0                | gpio1a4_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable |
| 3          | RW          | 0x0                | gpio1a3_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable |
| 2          | RW          | 0x0                | gpio1a2_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable |
| 1          | RW          | 0x0                | gpio1a1_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable |
| 0          | RW          | 0x0                | gpio1a0_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable |

**GPIO1\_IOC\_GPIO1B\_SUS**

Address: Operational Base(0xFF660000) + offset (0x0514)

| <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_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 6          | RW          | 0x0                | gpio1b6_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 5          | RW          | 0x0                | gpio1b5_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 4          | RW          | 0x0                | gpio1b4_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 3          | RW          | 0x0                | gpio1b3_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | gpio1b2_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable |
| 1          | RW          | 0x0                | gpio1b1_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable |
| 0          | RW          | 0x0                | gpio1b0_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable |

**GPIO1 IOC GPIO1C SUS**

Address: Operational Base(0xFF660000) + offset (0x0518)

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

**GPIO1 IOC GPIO1D SUS**

## RK3506 TRM (Part 1)

Address: Operational Base(0xFF660000) + offset (0x051C)

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

## GPIO1 IOC GPIO1A SL

Address: Operational Base(0xFF660000) + offset (0x0610)

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

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

**GPIO1 IOC GPIO1B SL**

Address: Operational Base(0xFF660000) + offset (0x0614)

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

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

**GPIO1 IOC GPIO1C SL**

Address: Operational Base(0xFF660000) + offset (0x0618)

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

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

**GPIO1 IOC GPIO1D SL**

Address: Operational Base(0xFF660000) + offset (0x061C)

| 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:6   | RW   | 0x3         | gpio1d3_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest. Always set to 2'b11 in normal operation.<br>2'b00: slowest<br>2'b11: fastest |
| 5:4   | RW   | 0x3         | gpio1d2_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest. Always set to 2'b11 in normal operation.<br>2'b00: slowest<br>2'b11: fastest |
| 3:2   | RW   | 0x3         | gpio1d1_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest. Always set to 2'b11 in normal operation.<br>2'b00: slowest<br>2'b11: fastest |

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

**GPIO1 IOC GPIO1A OD**

Address: Operational Base(0xFF660000) + offset (0x0710)

| 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         | gpio1a7_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |
| 6     | RW   | 0x0         | gpio1a6_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |
| 5     | RW   | 0x0         | gpio1a5_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |
| 4     | RW   | 0x0         | gpio1a4_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |
| 3     | RW   | 0x0         | gpio1a3_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |
| 2     | RW   | 0x0         | gpio1a2_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |
| 1     | RW   | 0x0         | gpio1a1_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |
| 0     | RW   | 0x0         | gpio1a0_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |

**GPIO1 IOC GPIO1B OD**

Address: Operational Base(0xFF660000) + offset (0x0714)

| 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:8       | RO          | 0x00               | reserved                                                                           |
| 7          | RW          | 0x0                | gpio1b7_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 6          | RW          | 0x0                | gpio1b6_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 5          | RW          | 0x0                | gpio1b5_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 4          | RW          | 0x0                | gpio1b4_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 3          | RW          | 0x0                | gpio1b3_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 2          | RW          | 0x0                | gpio1b2_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 1          | RW          | 0x0                | gpio1b1_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 0          | RW          | 0x0                | gpio1b0_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |

### **GPIO1\_IOC GPIO1C OD**

Address: Operational Base(0xFF660000) + offset (0x0718)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 4          | RW          | 0x0                | gpio1c4_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 3          | RW          | 0x0                | gpio1c3_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 2          | RW          | 0x0                | gpio1c2_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 1          | RW          | 0x0                | gpio1c1_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 0          | RW          | 0x0                | gpio1c0_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |

### **GPIO1\_IOC\_GPIO1D\_OD**

Address: Operational Base(0xFF660000) + offset (0x071C)

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

### **GPIO1\_IOC\_GPIO1\_IDDO**

Address: Operational Base(0xFF660000) + offset (0x0810)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>             |
|------------|-------------|--------------------|--------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                       |
| 0          | RW          | 0x0                | gpio1_iddq<br>For IDDO testing |

## **18.5 GPIO2\_IOC Register Description**

### **18.5.1 Registers Summary**

| Name                         | Offset | Size | Reset Value | Description                       |
|------------------------------|--------|------|-------------|-----------------------------------|
| GPIO2_IOC_GPIO2A_IOMUX_SEL_0 | 0x0040 | W    | 0x00000000  | GPIO2A IOMUX Select Register 0    |
| GPIO2_IOC_GPIO2A_IOMUX_SEL_1 | 0x0044 | W    | 0x00000000  | GPIO2A IOMUX Select Register 1    |
| GPIO2_IOC_GPIO2B_IOMUX_SEL_0 | 0x0048 | W    | 0x00000000  | GPIO2B IOMUX Select Register 0    |
| GPIO2_IOC_GPIO2B_IOMUX_SEL_1 | 0x004C | W    | 0x00000000  | GPIO2B IOMUX Select Register 1    |
| GPIO2_IOC_GPIO2C_IOMUX_SEL_0 | 0x0050 | W    | 0x00000000  | GPIO2C IOMUX Select Register 0    |
| GPIO2_IOC_GPIO2A_DS_0        | 0x0180 | W    | 0x00000F07  | GPIO2A Driver Strength Register 0 |
| GPIO2_IOC_GPIO2A_DS_1        | 0x0184 | W    | 0x00000707  | GPIO2A Driver Strength Register 1 |
| GPIO2_IOC_GPIO2A_DS_2        | 0x0188 | W    | 0x00000707  | GPIO2A Driver Strength Register 2 |
| GPIO2_IOC_GPIO2B_DS_0        | 0x0190 | W    | 0x00000707  | GPIO2B Driver Strength Register 0 |
| GPIO2_IOC_GPIO2B_DS_1        | 0x0194 | W    | 0x00000707  | GPIO2B Driver Strength Register 1 |
| GPIO2_IOC_GPIO2B_DS_2        | 0x0198 | W    | 0x00000707  | GPIO2B Driver Strength Register 2 |
| GPIO2_IOC_GPIO2B_DS_3        | 0x019C | W    | 0x00000707  | GPIO2B Driver Strength Register 3 |
| GPIO2_IOC_GPIO2C_DS_0        | 0x01A0 | W    | 0x00000007  | GPIO2C Driver Strength Register 0 |
| GPIO2_IOC_GPIO2A_PUL_L       | 0x0220 | W    | 0x00000559  | GPIO2A Pull up/down Register      |
| GPIO2_IOC_GPIO2B_PUL_L       | 0x0224 | W    | 0x0000AAAA  | GPIO2B Pull up/down Register      |
| GPIO2_IOC_GPIO2C_PUL_L       | 0x0228 | W    | 0x00000002  | GPIO2C Pull up/down Register      |
| GPIO2_IOC_GPIO2A_IE          | 0x0320 | W    | 0x0000003F  | GPIO2A Input Enable Register      |
| GPIO2_IOC_GPIO2B_IE          | 0x0324 | W    | 0x000000FF  | GPIO2B Input Enable Register      |
| GPIO2_IOC_GPIO2C_IE          | 0x0328 | W    | 0x00000001  | GPIO2C Input Enable Register      |
| GPIO2_IOC_GPIO2A_SMT         | 0x0420 | W    | 0x0000003F  | GPIO2A Schmitt Trigger Register   |
| GPIO2_IOC_GPIO2B_SMT         | 0x0424 | W    | 0x000000FF  | GPIO2B Schmitt Trigger Register   |
| GPIO2_IOC_GPIO2C_SMT         | 0x0428 | W    | 0x00000001  | GPIO2C Schmitt Trigger Register   |
| GPIO2_IOC_GPIO2A_SUS         | 0x0520 | W    | 0x00000000  | GPIO2A SUS Register               |
| GPIO2_IOC_GPIO2B_SUS         | 0x0524 | W    | 0x00000000  | GPIO2B SUS Register               |
| GPIO2_IOC_GPIO2C_SUS         | 0x0528 | W    | 0x00000000  | GPIO2C SUS Register               |
| GPIO2_IOC_GPIO2A_SL          | 0x0620 | W    | 0x00000FFF  | GPIO2A Slew Rate Register         |
| GPIO2_IOC_GPIO2B_SL          | 0x0624 | W    | 0x0000FFFF  | GPIO2B Slew Rate Register         |
| GPIO2_IOC_GPIO2C_SL          | 0x0628 | W    | 0x00000003  | GPIO2C Slew Rate Register         |
| GPIO2_IOC_GPIO2A_OD          | 0x0720 | W    | 0x00000000  | GPIO2A Open-Drain Register        |
| GPIO2_IOC_GPIO2B_OD          | 0x0724 | W    | 0x00000000  | GPIO2B Open-Drain Register        |
| GPIO2_IOC_GPIO2C_OD          | 0x0728 | W    | 0x00000000  | GPIO2C Open-Drain Register        |
| GPIO2_IOC_GPIO2_IDDQ         | 0x0820 | W    | 0x00000000  | GPIO2 IDDQ Register               |

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

### 18.5.2 Detail Registers Description

#### **GPIO2\_IOC\_GPIO2A\_IOMUX\_SEL\_0**

Address: Operational Base(0xFF4D8000) + 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 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:12      | RW          | 0x0                | gpio2a3_sel<br>4'h0: GPIO2_A3<br>4'h1: FSPI_D1                                                                                    |
| 11:8       | RW          | 0x0                | gpio2a2_sel<br>4'h0: GPIO2_A2<br>4'h1: FSPI_D0                                                                                    |
| 7:4        | RW          | 0x0                | gpio2a1_sel<br>4'h0: GPIO2_A1<br>4'h1: FSPI_CLK                                                                                   |
| 3:0        | RW          | 0x0                | gpio2a0_sel<br>4'h0: GPIO2_A0<br>4'h1: FSPI_CSN                                                                                   |

**GPIO2 IOC GPIO2A IOMUX SEL\_1**

Address: Operational Base(0xFF4D8000) + 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 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                | gpio2a5_sel<br>4'h0: GPIO2_A5<br>4'h1: FSPI_D3                                                                                    |
| 3:0        | RW          | 0x0                | gpio2a4_sel<br>4'h0: GPIO2_A4<br>4'h1: FSPI_D2                                                                                    |

**GPIO2 IOC GPIO2B IOMUX SEL\_0**

Address: Operational Base(0xFF4D8000) + offset (0x0048)

| <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          | 0x0                | gpio2b3_sel<br>4'h0: GPIO2_B3<br>4'h1: ETH_RMII0_RXD0<br>4'h2: SPI2_MISO                                                          |
| 11:8       | RW          | 0x0                | gpio2b2_sel<br>4'h0: GPIO2_B2<br>4'h1: ETH_RMII0_CLK<br>4'h2: SPI2_MOSI                                                           |
| 7:4        | RW          | 0x0                | gpio2b1_sel<br>4'h0: GPIO2_B1<br>4'h1: ETH_RMII0_RXD1<br>4'h2: SPI2_CSN                                                           |
| 3:0        | RW          | 0x0                | gpio2b0_sel<br>4'h0: GPIO2_B0<br>4'h1: ETH_RMII0_RXD0<br>4'h2: SPI2_CLK                                                           |

**GPIO2 IOC GPIO2B IOMUX SEL\_1**

Address: Operational Base(0xFF4D8000) + 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 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:12      | RW          | 0x0                | gpio2b7_sel<br>4'h0: GPIO2_B7<br>4'h1: ETH_RMII0_MDIO<br>4'h2: DSM_AUD_LP_M1<br>4'h3: SAI3_SDO                                    |
| 11:8       | RW          | 0x0                | gpio2b6_sel<br>4'h0: GPIO2_B6<br>4'h1: ETH_RMII0_MDC<br>4'h2: DSM_AUD_LN_M1<br>4'h3: SAI3_SDI                                     |
| 7:4        | RW          | 0x0                | gpio2b5_sel<br>4'h0: GPIO2_B5<br>4'h1: ETH_RMII0_TXEN<br>4'h2: DSM_AUD_RP_M1<br>4'h3: SAI3_LRCK                                   |
| 3:0        | RW          | 0x0                | gpio2b4_sel<br>4'h0: GPIO2_B4<br>4'h1: ETH_RMII0_TXD1<br>4'h2: DSM_AUD_RN_M1<br>4'h3: SAI3_SCLK                                   |

**GPIO2 IOC GPIO2C IOMUX SEL\_0**

Address: Operational Base(0xFF4D8000) + offset (0x0050)

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

**GPIO2 IOC GPIO2A DS\_0**

Address: Operational Base(0xFF4D8000) + offset (0x0180)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:8       | RW          | 0x0f               | gpio2a1_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 5:0        | RW          | 0x07               | gpio2a0_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO2\_IOC\_GPIO2A\_DS\_1**

Address: Operational Base(0xFF4D8000) + offset (0x0184)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 13:8       | RW          | 0x07               | gpio2a3_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 5:0        | RW          | 0x07               | gpio2a2_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO2\_IOC\_GPIO2A\_DS\_2**

Address: Operational Base(0xFF4D8000) + 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 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 13:8       | RW          | 0x07               | gpio2a5_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 5:0        | RW          | 0x07               | gpio2a4_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO2 IOC GPIO2B DS 0**

Address: Operational Base(0xFF4D8000) + offset (0x0190)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 13:8       | RW          | 0x07               | gpio2b1_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 5:0        | RW          | 0x07               | gpio2b0_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO2 IOC GPIO2B DS 1**

Address: Operational Base(0xFF4D8000) + offset (0x0194)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 13:8       | RW          | 0x07               | gpio2b3_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 5:0        | RW          | 0x07               | gpio2b2_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO2 IOC GPIO2B DS 2**

Address: Operational Base(0xFF4D8000) + offset (0x0198)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 13:8       | RW          | 0x07               | gpio2b5_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:0        | RW          | 0x07               | <p>gpio2b4_ds</p> <p>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.</p> <p>6'b000000: Disable<br/>6'b000001: Level0<br/>6'b000011: Level1<br/>6'b000111: Level2<br/>6'b001111: Level3<br/>6'b011111: Level4<br/>6'b111111: Level5</p> |

### **GPIO2 IOC GPIO2B DS 3**

Address: Operational Base(0xFF4D8000) + offset (0x019C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | <p>write_enable</p> <p>Write enable for lower 16bits, each bit is individual.</p> <p>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                         |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                  |
| 13:8       | RW          | 0x07               | <p>gpio2b7_ds</p> <p>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.</p> <p>6'b000000: Disable<br/>6'b000001: Level0<br/>6'b000011: Level1<br/>6'b000111: Level2<br/>6'b001111: Level3<br/>6'b011111: Level4<br/>6'b111111: Level5</p> |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                  |
| 5:0        | RW          | 0x07               | <p>gpio2b6_ds</p> <p>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.</p> <p>6'b000000: Disable<br/>6'b000001: Level0<br/>6'b000011: Level1<br/>6'b000111: Level2<br/>6'b001111: Level3<br/>6'b011111: Level4<br/>6'b111111: Level5</p> |

### **GPIO2 IOC GPIO2C DS 0**

Address: Operational Base(0xFF4D8000) + offset (0x01A0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | <p>write_enable</p> <p>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                                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:0        | RW          | 0x07               | <p>gpio2c0_ds<br/> The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br/> 6'b000000: Disable<br/> 6'b000001: Level0<br/> 6'b000011: Level1<br/> 6'b000111: Level2<br/> 6'b001111: Level3<br/> 6'b011111: Level4<br/> 6'b111111: Level5</p> |

**GPIO2 IOC GPIO2A PULL**

Address: Operational Base(0xFF4D8000) + offset (0x0220)

| <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:12      | RO          | 0x0                | reserved                                                                                                                                       |
| 11:10      | RW          | 0x1                | <p>gpio2a5_pull<br/> Weak pull down/up for pad<br/> 2'b00: z<br/> 2'b01: up<br/> 2'b10: down<br/> 2'b11: illegal</p>                           |
| 9:8        | RW          | 0x1                | <p>gpio2a4_pull<br/> Weak pull down/up for pad<br/> 2'b00: z<br/> 2'b01: up<br/> 2'b10: down<br/> 2'b11: illegal</p>                           |
| 7:6        | RW          | 0x1                | <p>gpio2a3_pull<br/> Weak pull down/up for pad<br/> 2'b00: z<br/> 2'b01: up<br/> 2'b10: down<br/> 2'b11: illegal</p>                           |
| 5:4        | RW          | 0x1                | <p>gpio2a2_pull<br/> Weak pull down/up for pad<br/> 2'b00: z<br/> 2'b01: up<br/> 2'b10: down<br/> 2'b11: illegal</p>                           |
| 3:2        | RW          | 0x2                | <p>gpio2a1_pull<br/> Weak pull down/up for pad<br/> 2'b00: z<br/> 2'b01: up<br/> 2'b10: down<br/> 2'b11: illegal</p>                           |
| 1:0        | RW          | 0x1                | <p>gpio2a0_pull<br/> Weak pull down/up for pad<br/> 2'b00: z<br/> 2'b01: up<br/> 2'b10: down<br/> 2'b11: illegal</p>                           |

**GPIO2 IOC GPIO2B PULL**

Address: Operational Base(0xFF4D8000) + 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 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:14      | RW          | 0x2                | gpio2b7_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |
| 13:12      | RW          | 0x2                | gpio2b6_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |
| 11:10      | RW          | 0x2                | gpio2b5_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |
| 9:8        | RW          | 0x2                | gpio2b4_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |
| 7:6        | RW          | 0x2                | gpio2b3_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |
| 5:4        | RW          | 0x2                | gpio2b2_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |
| 3:2        | RW          | 0x2                | gpio2b1_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |
| 1:0        | RW          | 0x2                | gpio2b0_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |

**GPIO2 IOC GPIO2C PULL**

## RK3506 TRM (Part 1)

Address: Operational Base(0xFF4D8000) + offset (0x0228)

| 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   | 0x0000      | reserved                                                                                                                          |
| 1:0   | RW   | 0x2         | gpio2c0_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal                               |

## GPIO2 IOC GPIO2A IE

Address: Operational Base(0xFF4D8000) + offset (0x0320)

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

## GPIO2 IOC GPIO2B IE

Address: Operational Base(0xFF4D8000) + offset (0x0324)

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

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

### **GPIO2 IOC GPIO2C IE**

Address: Operational Base(0xFF4D8000) + offset (0x0328)

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

### **GPIO2 IOC GPIO2A SMT**

Address: Operational Base(0xFF4D8000) + offset (0x0420)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------|
| 5          | RW          | 0x1                | gpio2a5_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable |
| 4          | RW          | 0x1                | gpio2a4_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable |
| 3          | RW          | 0x1                | gpio2a3_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable |
| 2          | RW          | 0x1                | gpio2a2_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable |
| 1          | RW          | 0x1                | gpio2a1_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable |
| 0          | RW          | 0x1                | gpio2a0_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable |

**GPIO2\_IOC\_GPIO2B\_SMT**

Address: Operational Base(0xFF4D8000) + offset (0x0424)

| <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_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 6          | RW          | 0x1                | gpio2b6_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 5          | RW          | 0x1                | gpio2b5_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 4          | RW          | 0x1                | gpio2b4_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 3          | RW          | 0x1                | gpio2b3_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------|
| 2          | RW          | 0x1                | gpio2b2_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable |
| 1          | RW          | 0x1                | gpio2b1_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable |
| 0          | RW          | 0x1                | gpio2b0_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable |

### **GPIO2 IOC GPIO2C SMT**

Address: Operational Base(0xFF4D8000) + offset (0x0428)

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

### **GPIO2 IOC GPIO2A SUS**

Address: Operational Base(0xFF4D8000) + offset (0x0520)

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

**GPIO2 IOC GPIO2B SUS**

Address: Operational Base(0xFF4D8000) + offset (0x0524)

| <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_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 6          | RW          | 0x0                | gpio2b6_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 5          | RW          | 0x0                | gpio2b5_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 4          | RW          | 0x0                | gpio2b4_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 3          | RW          | 0x0                | gpio2b3_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 2          | RW          | 0x0                | gpio2b2_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 1          | RW          | 0x0                | gpio2b1_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 0          | RW          | 0x0                | gpio2b0_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |

**GPIO2 IOC GPIO2C SUS**

Address: Operational Base(0xFF4D8000) + offset (0x0528)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | gpio2c0_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable |

### **GPIO2 IOC GPIO2A SL**

Address: Operational Base(0xFF4D8000) + offset (0x0620)

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

### **GPIO2 IOC GPIO2B SL**

Address: Operational Base(0xFF4D8000) + offset (0x0624)

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

**GPIO2 IOC GPIO2C SL**

Address: Operational Base(0xFF4D8000) + offset (0x0628)

| <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:0        | RW          | 0x3                | gpio2c0_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest. Always set to 2'b11 in normal operation.<br>2'b00: slowest<br>2'b11: fastest |

**GPIO2 IOC GPIO2A OD**

Address: Operational Base(0xFF4D8000) + offset (0x0720)

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

**GPIO2 IOC GPIO2B OD**

Address: Operational Base(0xFF4D8000) + offset (0x0724)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 7          | RW          | 0x0                | gpio2b7_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 6          | RW          | 0x0                | gpio2b6_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 5          | RW          | 0x0                | gpio2b5_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 4          | RW          | 0x0                | gpio2b4_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 3          | RW          | 0x0                | gpio2b3_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 2          | RW          | 0x0                | gpio2b2_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 1          | RW          | 0x0                | gpio2b1_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 0          | RW          | 0x0                | gpio2b0_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |

### **GPIO2\_IOC\_GPIO2C\_OD**

Address: Operational Base(0xFF4D8000) + offset (0x0728)

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

### **GPIO2\_IOC\_GPIO2\_IDDQ**

Address: Operational Base(0xFF4D8000) + offset (0x0820)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>               |
|------------|-------------|--------------------|----------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                         |
| 1          | RW          | 0x0                | gpio2bc_iddq<br>For IDDQ testing |
| 0          | RW          | 0x0                | gpio2a_iddq<br>For IDDQ testing  |

## 18.6 GPIO3\_IOC Register Description

### 18.6.1 Registers Summary

| Name                          | Offset | Size | Reset Value | Description                       |
|-------------------------------|--------|------|-------------|-----------------------------------|
| GPIO3_IOC_GPIO3A_IOM_UX_SEL_0 | 0x0060 | W    | 0x00000000  | GPIO3A IOMUX Select Register 0    |
| GPIO3_IOC_GPIO3A_IOM_UX_SEL_1 | 0x0064 | W    | 0x00000022  | GPIO3A IOMUX Select Register 1    |
| GPIO3_IOC_GPIO3B_IOM_UX_SEL_0 | 0x0068 | W    | 0x00000000  | GPIO3B IOMUX Select Register 0    |
| GPIO3_IOC_GPIO3B_IOM_UX_SEL_1 | 0x006C | W    | 0x00000000  | GPIO3B IOMUX Select Register 1    |
| GPIO3_IOC_GPIO3A_DS_0         | 0x01C0 | W    | 0x0000070F  | GPIO3A Driver Strength Register 0 |
| GPIO3_IOC_GPIO3A_DS_1         | 0x01C4 | W    | 0x00000707  | GPIO3A Driver Strength Register 1 |
| GPIO3_IOC_GPIO3A_DS_2         | 0x01C8 | W    | 0x00000707  | GPIO3A Driver Strength Register 2 |
| GPIO3_IOC_GPIO3A_DS_3         | 0x01CC | W    | 0x00000707  | GPIO3A Driver Strength Register 3 |
| GPIO3_IOC_GPIO3B_DS_0         | 0x01D0 | W    | 0x00000707  | GPIO3B Driver Strength Register 0 |
| GPIO3_IOC_GPIO3B_DS_1         | 0x01D4 | W    | 0x00000707  | GPIO3B Driver Strength Register 1 |
| GPIO3_IOC_GPIO3B_DS_2         | 0x01D8 | W    | 0x00000707  | GPIO3B Driver Strength Register 2 |
| GPIO3_IOC_GPIO3B_DS_3         | 0x01DC | W    | 0x00000007  | GPIO3B Driver Strength Register 3 |
| GPIO3_IOC_GPIO3A_PUL_L        | 0x0230 | W    | 0x0000AAAA  | GPIO3A Pull up/down Register      |
| GPIO3_IOC_GPIO3B_PUL_L        | 0x0234 | W    | 0x00002AAA  | GPIO3B Pull up/down Register      |
| GPIO3_IOC_GPIO3A_IE           | 0x0330 | W    | 0x000000FF  | GPIO3A Input Enable Register      |
| GPIO3_IOC_GPIO3B_IE           | 0x0334 | W    | 0x0000007F  | GPIO3B Input Enable Register      |
| GPIO3_IOC_GPIO3A_SMT          | 0x0430 | W    | 0x000000FF  | GPIO3A Schmitt Trigger Register   |
| GPIO3_IOC_GPIO3B_SMT          | 0x0434 | W    | 0x0000007F  | GPIO3B Schmitt Trigger Register   |
| GPIO3_IOC_GPIO3A_SUS          | 0x0530 | W    | 0x00000000  | GPIO3A SUS Register               |
| GPIO3_IOC_GPIO3B_SUS          | 0x0534 | W    | 0x00000000  | GPIO3B SUS Register               |
| GPIO3_IOC_GPIO3A_SL           | 0x0630 | W    | 0x0000FFFF  | GPIO3A Slew Rate Register         |
| GPIO3_IOC_GPIO3B_SL           | 0x0634 | W    | 0x00003FFF  | GPIO3B Slew Rate Register         |
| GPIO3_IOC_GPIO3A_OD           | 0x0730 | W    | 0x00000000  | GPIO3A Open-Drain Register        |
| GPIO3_IOC_GPIO3B_OD           | 0x0734 | W    | 0x00000000  | GPIO3B Open-Drain Register        |
| GPIO3_IOC_GPIO3_IDDQ          | 0x0820 | W    | 0x00000000  | GPIO3 IDDQ 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

### 18.6.2 Detail Registers Description

#### GPIO3\_IOC\_GPIO3A\_IOMUX\_SEL\_0

Address: Operational Base(0xFF4D8000) + offset (0x0060)

| 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:12      | RW          | 0x0                | gpio3a3_sel<br>4'h0: GPIO3_A3<br>4'h1: SDMMC_D1<br>4'h2: TEST_CLK_OUT |
| 11:8       | RW          | 0x0                | gpio3a2_sel<br>4'h0: GPIO3_A2<br>4'h1: SDMMC_D0                       |
| 7:4        | RW          | 0x0                | gpio3a1_sel<br>4'h0: GPIO3_A1<br>4'h1: SDMMC_CMD                      |
| 3:0        | RW          | 0x0                | gpio3a0_sel<br>4'h0: GPIO3_A0<br>4'h1: SDMMC_CLK                      |

**GPIO3 IOC GPIO3A IOMUX SEL\_1**

Address: Operational Base(0xFF4D8000) + offset (0x0064)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:12      | RW          | 0x0                | gpio3a7_sel<br>4'h0: GPIO3_A7<br>4'h1: SAI2_SCLK_M0<br>4'h2: ETH_RMII1_RXD1                                                       |
| 11:8       | RW          | 0x0                | gpio3a6_sel<br>4'h0: GPIO3_A6<br>4'h1: SAI2_SDI_M0<br>4'h2: ETH_RMII1_RXD0                                                        |
| 7:4        | RW          | 0x2                | gpio3a5_sel<br>4'h0: GPIO3_A5<br>4'h1: SDMMC_D3<br>4'h2: JTAG_TMS_M0                                                              |
| 3:0        | RW          | 0x2                | gpio3a4_sel<br>4'h0: GPIO3_A4<br>4'h1: SDMMC_D2<br>4'h2: JTAG_TCK_M0                                                              |

**GPIO3 IOC GPIO3B IOMUX SEL\_0**

Address: Operational Base(0xFF4D8000) + offset (0x0068)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:12      | RW          | 0x0                | gpio3b3_sel<br>4'h0: GPIO3_B3<br>4'h1: UART5_RX_M0<br>4'h2: ETH_RMII1_TXEN                                                        |
| 11:8       | RW          | 0x0                | gpio3b2_sel<br>4'h0: GPIO3_B2<br>4'h1: UART5_CTSN_M0<br>4'h2: ETH_RMII1_RXD1                                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------|
| 7:4        | RW          | 0x0                | gpio3b1_sel<br>4'h0: GPIO3_B1<br>4'h1: SAI2_LRCK_M0<br>4'h2: ETH_RMII1_TXD0 |
| 3:0        | RW          | 0x0                | gpio3b0_sel<br>4'h0: GPIO3_B0<br>4'h1: SAI2_SDO_M0<br>4'h2: ETH_RMII1_CLK   |

### **GPIO3 IOC GPIO3B IOMUX SEL\_1**

Address: Operational Base(0xFF4D8000) + 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 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          | 0x0                | gpio3b6_sel<br>4'h0: GPIO3_B6<br>4'h1: SAI2_MCLK_M0<br>4'h2: ETH_RMII1_RXDVCRS                                                    |
| 7:4        | RW          | 0x0                | gpio3b5_sel<br>4'h0: GPIO3_B5<br>4'h1: UART5_RTSN_M0<br>4'h2: ETH_RMII1_MDIO                                                      |
| 3:0        | RW          | 0x0                | gpio3b4_sel<br>4'h0: GPIO3_B4<br>4'h1: UART5_TX_M0<br>4'h2: ETH_RMII1_MDC                                                         |

### **GPIO3 IOC GPIO3A DS\_0**

Address: Operational Base(0xFF4D8000) + offset (0x01C0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |
| 13:8       | RW          | 0x07               | gpio3a1_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:0        | RW          | 0x0f               | <p>gpio3a0_ds</p> <p>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.</p> <p>6'b000000: Disable<br/>6'b000001: Level0<br/>6'b000011: Level1<br/>6'b000111: Level2<br/>6'b001111: Level3<br/>6'b011111: Level4<br/>6'b111111: Level5</p> |

### **GPIO3 IOC GPIO3A DS 1**

Address: Operational Base(0xFF4D8000) + offset (0x01C4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | <p>write_enable</p> <p>Write enable for lower 16bits, each bit is individual.</p> <p>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                         |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                  |
| 13:8       | RW          | 0x07               | <p>gpio3a3_ds</p> <p>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.</p> <p>6'b000000: Disable<br/>6'b000001: Level0<br/>6'b000011: Level1<br/>6'b000111: Level2<br/>6'b001111: Level3<br/>6'b011111: Level4<br/>6'b111111: Level5</p> |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                  |
| 5:0        | RW          | 0x07               | <p>gpio3a2_ds</p> <p>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.</p> <p>6'b000000: Disable<br/>6'b000001: Level0<br/>6'b000011: Level1<br/>6'b000111: Level2<br/>6'b001111: Level3<br/>6'b011111: Level4<br/>6'b111111: Level5</p> |

### **GPIO3 IOC GPIO3A DS 2**

Address: Operational Base(0xFF4D8000) + offset (0x01C8)

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

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                          |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:8 | RW   | 0x07        | gpio3a5_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                             |
| 5:0  | RW   | 0x07        | gpio3a4_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO3 IOC GPIO3A DS 3**

Address: Operational Base(0xFF4D8000) + offset (0x01CC)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                          |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                             |
| 13:8  | RW   | 0x07        | gpio3a7_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                             |
| 5:0   | RW   | 0x07        | gpio3a6_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO3 IOC GPIO3B DS 0**

Address: Operational Base(0xFF4D8000) + offset (0x01D0)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                          |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                             |
| 13:8  | RW   | 0x07        | gpio3b1_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                             |
| 5:0   | RW   | 0x07        | gpio3b0_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO3 IOC GPIO3B DS 1**

Address: Operational Base(0xFF4D8000) + offset (0x01D4)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                          |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                             |
| 13:8  | RW   | 0x07        | gpio3b3_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                             |
| 5:0   | RW   | 0x07        | gpio3b2_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO3 IOC GPIO3B DS 2**

Address: Operational Base(0xFF4D8000) + offset (0x01D8)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                          |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                    |
| 15:14 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                             |
| 13:8  | RW   | 0x07        | gpio3b5_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |
| 7:6   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                             |
| 5:0   | RW   | 0x07        | gpio3b4_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO3 IOC GPIO3B DS 3**

Address: Operational Base(0xFF4D8000) + offset (0x01DC)

| 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:6  | RO   | 0x000       | reserved                                                                                                                                                                                                                                                             |
| 5:0   | RW   | 0x07        | gpio3b6_ds<br>The drive strength of IO. The weakest setting is 6'b000001 and the strongest setting is 6'b111111.<br>6'b000000: Disable<br>6'b000001: Level0<br>6'b000011: Level1<br>6'b000111: Level2<br>6'b001111: Level3<br>6'b011111: Level4<br>6'b111111: Level5 |

**GPIO3 IOC GPIO3A PULL**

Address: Operational Base(0xFF4D8000) + offset (0x0230)

| 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          | 0x2                | gpio3a7_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 13:12      | RW          | 0x2                | gpio3a6_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 11:10      | RW          | 0x2                | gpio3a5_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 9:8        | RW          | 0x2                | gpio3a4_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 7:6        | RW          | 0x2                | gpio3a3_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 5:4        | RW          | 0x2                | gpio3a2_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 3:2        | RW          | 0x2                | gpio3a1_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 1:0        | RW          | 0x2                | gpio3a0_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |

**GPIO3 IOC GPIO3B PULL**

Address: Operational Base(0xFF4D8000) + 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 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:12      | RW          | 0x2                | gpio3b6_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 11:10      | RW          | 0x2                | gpio3b5_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 9:8        | RW          | 0x2                | gpio3b4_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 7:6        | RW          | 0x2                | gpio3b3_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 5:4        | RW          | 0x2                | gpio3b2_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 3:2        | RW          | 0x2                | gpio3b1_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |
| 1:0        | RW          | 0x2                | gpio3b0_pull<br>Weak pull down/up for pad<br>2'b00: z<br>2'b01: up<br>2'b10: down<br>2'b11: illegal |

**GPIO3 IOC GPIO3A IE**

Address: Operational Base(0xFF4D8000) + 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 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>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |

| Bit | Attr | Reset Value | Description                                                    |
|-----|------|-------------|----------------------------------------------------------------|
| 6   | RW   | 0x1         | gpio3a6_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable |
| 5   | RW   | 0x1         | gpio3a5_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable |
| 4   | RW   | 0x1         | gpio3a4_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable |
| 3   | RW   | 0x1         | gpio3a3_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable |
| 2   | RW   | 0x1         | gpio3a2_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable |
| 1   | RW   | 0x1         | gpio3a1_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable |
| 0   | RW   | 0x1         | gpio3a0_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable |

**GPIO3 IOC GPIO3B IE**

Address: Operational Base(0xFF4D8000) + offset (0x0334)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:7  | RO   | 0x000       | reserved                                                                                                                          |
| 6     | RW   | 0x1         | gpio3b6_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 5     | RW   | 0x1         | gpio3b5_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 4     | RW   | 0x1         | gpio3b4_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |
| 3     | RW   | 0x1         | gpio3b3_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                             |
|------------|-------------|--------------------|----------------------------------------------------------------|
| 2          | RW          | 0x1                | gpio3b2_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable |
| 1          | RW          | 0x1                | gpio3b1_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable |
| 0          | RW          | 0x1                | gpio3b0_ie<br>Receiver enable<br>1'b0: disable<br>1'b1: enable |

**GPIO3 IOC GPIO3A SMT**

Address: Operational Base(0xFF4D8000) + offset (0x0430)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                          |
| 7          | RW          | 0x1                | gpio3a7_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 6          | RW          | 0x1                | gpio3a6_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 5          | RW          | 0x1                | gpio3a5_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 4          | RW          | 0x1                | gpio3a4_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 3          | RW          | 0x1                | gpio3a3_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 2          | RW          | 0x1                | gpio3a2_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 1          | RW          | 0x1                | gpio3a1_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 0          | RW          | 0x1                | gpio3a0_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |

**GPIO3 IOC GPIO3B SMT**

Address: Operational Base(0xFF4D8000) + offset (0x0434)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:7       | RO          | 0x000              | reserved                                                                                                                          |
| 6          | RW          | 0x1                | gpio3b6_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 5          | RW          | 0x1                | gpio3b5_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 4          | RW          | 0x1                | gpio3b4_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 3          | RW          | 0x1                | gpio3b3_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 2          | RW          | 0x1                | gpio3b2_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 1          | RW          | 0x1                | gpio3b1_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |
| 0          | RW          | 0x1                | gpio3b0_smt<br>Schmitt trigger enable<br>1'b0: disable<br>1'b1: enable                                                            |

**GPIO3 IOC GPIO3A SUS**

Address: Operational Base(0xFF4D8000) + offset (0x0530)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 4          | RW          | 0x0                | gpio3a4_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable |
| 3          | RW          | 0x0                | gpio3a3_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable |
| 2          | RW          | 0x0                | gpio3a2_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable |
| 1          | RW          | 0x0                | gpio3a1_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable |
| 0          | RW          | 0x0                | gpio3a0_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable |

**GPIO3\_IOC\_GPIO3B\_SUS**

Address: Operational Base(0xFF4D8000) + offset (0x0534)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:7       | RO          | 0x000              | reserved                                                                                                                          |
| 6          | RW          | 0x0                | gpio3b6_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 5          | RW          | 0x0                | gpio3b5_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 4          | RW          | 0x0                | gpio3b4_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 3          | RW          | 0x0                | gpio3b3_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 2          | RW          | 0x0                | gpio3b2_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable                                                   |
| 1          | RW          | 0x0                | gpio3b1_sus<br>Weak pull keeper for pad 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                | gpio3b0_sus<br>Weak pull keeper for pad enable<br>1'b0: disable<br>1'b1: enable |

**GPIO3 IOC GPIO3A SL**

Address: Operational Base(0xFF4D8000) + offset (0x0630)

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

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

**GPIO3 IOC GPIO3B SL**

Address: Operational Base(0xFF4D8000) + offset (0x0634)

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

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

**GPIO3 IOC GPIO3A OD**

Address: Operational Base(0xFF4D8000) + offset (0x0730)

| 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         | gpio3a7_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |
| 6     | RW   | 0x0         | gpio3a6_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |
| 5     | RW   | 0x0         | gpio3a5_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |
| 4     | RW   | 0x0         | gpio3a4_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |
| 3     | RW   | 0x0         | gpio3a3_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |
| 2     | RW   | 0x0         | gpio3a2_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |
| 1     | RW   | 0x0         | gpio3a1_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |
| 0     | RW   | 0x0         | gpio3a0_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable                                                |

**GPIO3 IOC GPIO3B OD**

Address: Operational Base(0xFF4D8000) + offset (0x0734)

| 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:7       | RO          | 0x000              | reserved                                                                           |
| 6          | RW          | 0x0                | gpio3b6_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 5          | RW          | 0x0                | gpio3b5_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 4          | RW          | 0x0                | gpio3b4_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 3          | RW          | 0x0                | gpio3b3_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 2          | RW          | 0x0                | gpio3b2_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 1          | RW          | 0x0                | gpio3b1_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |
| 0          | RW          | 0x0                | gpio3b0_od<br>For open drain functionality enable<br>1'b0: disable<br>1'b1: enable |

**GPIO3 IOC GPIO3 IDDQ**

Address: Operational Base(0xFF4D8000) + offset (0x0820)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>             |
|------------|-------------|--------------------|--------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                       |
| 2          | RW          | 0x0                | gpio3_iddq<br>For IDDQ testing |
| 1:0        | RO          | 0x0                | reserved                       |

**18.7 GPIO4\_IOC Register Description****18.7.1 Registers Summary**

| <b>Name</b>          | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>           |
|----------------------|---------------|-------------|--------------------|------------------------------|
| GPIO4 IOC SARADC CON | 0x0840        | W           | 0x00001700         | GPIO SARADC Control Register |

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

**18.7.2 Detail Registers Description****GPIO4 IOC SARADC CON**

Address: Operational Base(0xFF4D8000) + offset (0x0840)

| <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         | RW          | 0x0                | gpio_saradc_ps<br>Weak pull down/up select of IO<br>SARADC_IN0_BOOT/GPIO4_B0_z~SARADC_IN3/GPIO4_B3_z.<br>1'b0: down<br>1'b1: up                                                                                                         |
| 13         | RW          | 0x0                | gpio_saradc_pe<br>Weak pull down/up enable of IO<br>SARADC_IN0_BOOT/GPIO4_B0_z~SARADC_IN3/GPIO4_B3_z.<br>1'b0: disable<br>1'b1: enable                                                                                                  |
| 12         | RW          | 0x1                | gpio_saradc_sl<br>Slew rate control enable of IO<br>SARADC_IN0_BOOT/GPIO4_B0_z~SARADC_IN3/GPIO4_B3_z.<br>1'b0: disable<br>1'b1: enable                                                                                                  |
| 11:10      | RW          | 0x1                | gpio_saradc_ds<br>The drive strength of IO<br>SARADC_IN0_BOOT/GPIO4_B0_z~SARADC_IN3/GPIO4_B3_z.<br>The weakest setting is 2'b00 and the strongest setting is 2'b11.<br>2'b00: Level0<br>2'b01: Level1<br>2'b10: Level2<br>2'b11: Level3 |
| 9:8        | RW          | 0x3                | gpio_saradc_smt<br>Schmitter trigger enable of IO<br>SARADC_IN0_BOOT/GPIO4_B0_z~SARADC_IN3/GPIO4_B3_z.<br>2'b00: disable<br>2'b11: enable<br>Others: Reserved                                                                           |
| 7:4        | RW          | 0x0                | gpio_saradc_ie<br>Receiver enable of IO<br>SARADC_IN0_BOOT/GPIO4_B0_z~SARADC_IN3/GPIO4_B3_z,<br>each bits for one IO.<br>1'b0: disable<br>1'b1: enable                                                                                  |
| 3:0        | RW          | 0x0                | gpio_saradc_he<br>Hold enable of IO<br>SARADC_IN0_BOOT/GPIO4_B0_z~SARADC_IN3/GPIO4_B3_z,<br>each bits for one IO.<br>1'b0: disable<br>1'b1: enable                                                                                      |

## 18.8 Application Notes

IOC is usually connected to a functional IP in the following ways (take input as an example):

- 1) As shown in following figure, the IO PAD connects directly to the function IP through IOC, and IOC\_IOMUX\_SEL (for example, GPIO0\_IOC\_GPIO0A\_IOMUX\_SEL\_0) controls which IP the signal is input to.



Fig. 18-1 Connect directly from IOC to function IP

2) As shown in following figure, some IP will be connected to the IO PAD via RMIO and IOC. In this case, you need to configure IOC\_IOMUX\_SEL to select RMIO (for example, GPIO0\_IOC\_GPIO0A\_IOMUX\_SEL\_0=4 'h7) and then configure RMIO FUNC\_SEL so that one of the IP in the orange box is selected to complete stroking with the IO PAD.



Fig. 18-2 Some IPs are connected to the IO PAD through RMIO and IOC

3) As shown in following figure, the IP can be connected to the IO PAD only through IOC, or through RMIO+IOC. In this case, you need to configure RMIO\_FUNC\_SEL, and IOC\_IOMUX\_SEL to select one of the paths. The IOC will have a higher priority.



Fig. 18-3 IP which has multiple paths connecting to the I/O PAD

## Chapter 19 Rockchip Matrix IO

### 19.1 Overview

The Rockchip Matrix IO (RM\_IO) can be configured with registers to route arbitrary signals from low-speed IP, such as UART/I2C, to the selected IO PAD.

RM\_IO has the following features:

- Supports routing any IP signal in the optional range to the IO PAD
- The IP signal that is not routed to the IO PAD is tied to the default value

### 19.2 Block Diagram

RM\_IO is comprised of:

- Config Interface

This interface controls which IP pins Rockchip Matrix IO routes to RM\_IOx.

- IP Interface

IP interfaces connect signals from peripheral IP, including input/output/output enablement.

- RM\_IO0~RM\_IOx

These signals are connected to IOMUX. When IOMUX's SEL signal is configured to a specific value, RM\_IOx connects to the IO PAD. That is, RM\_IO0 is connected to PAD0 through IOMUX, and RM\_IO1 is connected to PAD1 through IOMUX.

- Test Interface

This interface controls the behavior in test mode.



Fig. 19-1 RM\_IO Block Diagram

### 19.3 Function Description

#### 19.3.1 IP signal routing

The number of peripheral IP signals connected to RM\_IO is greater than the number of pads. RM\_IO can be configured by software to connect an IP signal to any PAD. The following is an example:

- 1) Write a value to RM\_IO\_rm\_gpio0a0\_sel by referring to the RM\_IO register description in section 19.4 to configure the IP function pin of the RM\_IO0 connection. The selected function pins can be viewed in 19.4.2 Detail Registers Description.
- 2) View the PAD name that RM\_IO0 connects to by referring to Table 19-1. Set the value in IOMUX Setting to enable RM\_IO0 to connect to the PAD through IOMUX.
- 3) You can perform steps 1 and 2 to configure any RM\_IOx. Note that the function selection of multiple RM\_IO cannot be the same; otherwise, conflicts will occur, causing the IP function pins to fail to connect to the PAD.

#### 19.3.2 Test Mode

RM\_IO can switch to the test mode through the register, which is used to find connection problems faster; after entering the Test mode, the value of the IP pins in Fig. 19-1 does not affect the input and output of RM\_IO. Instead, the Test pins connect to the PAD through

RM\_IO. To use it, follow the following steps:

1. Switch to test mode by setting GRF\_PMU\_SOC\_CON1[11].
2. Repeat steps 1 and 2 in Section 1.3.1 to connect the Test pins to the PAD.
3. The value of Test pins (output/output enable driven to RM\_IO) is controlled by registers PMUGRF\_OS\_REG0/1/2/3 (To control output0 ~97) and PMUGRF\_OS\_REG4/5/6/7(To control output enable0 ~ 97). The RM\_IO\_test\_status register can be used to obtain the Test pins (the value driven to the Test pins by RM\_IO) and the values of the RM\_IO0~RM\_IOx pins.

## 19.4 Register Description

### 19.4.1 Registers Summary

| Name                 | Offset | Size | Reset Value | Description                                     |
|----------------------|--------|------|-------------|-------------------------------------------------|
| RM_IO_rm_gpio0a0_sel | 0x0080 | W    | 0x00000000  | Configure the rm_io0 function                   |
| RM_IO_rm_gpio0a1_sel | 0x0084 | W    | 0x00000000  | Configure the rm_io1 function                   |
| RM_IO_rm_gpio0a2_sel | 0x0088 | W    | 0x00000000  | Configure the rm_io2 function                   |
| RM_IO_rm_gpio0a3_sel | 0x008C | W    | 0x00000000  | Configure the rm_io3 function                   |
| RM_IO_rm_gpio0a4_sel | 0x0090 | W    | 0x00000000  | Configure the rm_io4 function                   |
| RM_IO_rm_gpio0a5_sel | 0x0094 | W    | 0x00000000  | Configure the rm_io5 function                   |
| RM_IO_rm_gpio0a6_sel | 0x0098 | W    | 0x00000000  | Configure the rm_io6 function                   |
| RM_IO_rm_gpio0a7_sel | 0x009C | W    | 0x00000000  | Configure the rm_io7 function                   |
| RM_IO_rm_gpio0b0_sel | 0x00A0 | W    | 0x00000000  | Configure the rm_io8 function                   |
| RM_IO_rm_gpio0b1_sel | 0x00A4 | W    | 0x00000000  | Configure the rm_io9 function                   |
| RM_IO_rm_gpio0b2_sel | 0x00A8 | W    | 0x00000000  | Configure the rm_io10 function                  |
| RM_IO_rm_gpio0b3_sel | 0x00AC | W    | 0x00000000  | Configure the rm_io11 function                  |
| RM_IO_rm_gpio0b4_sel | 0x00B0 | W    | 0x00000000  | Configure the rm_io12 function                  |
| RM_IO_rm_gpio0b5_sel | 0x00B4 | W    | 0x00000000  | Configure the rm_io13 function                  |
| RM_IO_rm_gpio0b6_sel | 0x00B8 | W    | 0x00000000  | Configure the rm_io14 function                  |
| RM_IO_rm_gpio0b7_sel | 0x00BC | W    | 0x00000000  | Configure the rm_io15 function                  |
| RM_IO_rm_gpio0c0_sel | 0x00C0 | W    | 0x00000000  | Configure the rm_io16 function                  |
| RM_IO_rm_gpio0c1_sel | 0x00C4 | W    | 0x00000000  | Configure the rm_io17 function                  |
| RM_IO_rm_gpio0c2_sel | 0x00C8 | W    | 0x00000000  | Configure the rm_io18 function                  |
| RM_IO_rm_gpio0c3_sel | 0x00CC | W    | 0x00000000  | Configure the rm_io19 function                  |
| RM_IO_rm_gpio0c4_sel | 0x00D0 | W    | 0x00000000  | Configure the rm_io20 function                  |
| RM_IO_rm_gpio0c5_sel | 0x00D4 | W    | 0x00000000  | Configure the rm_io21 function                  |
| RM_IO_rm_gpio0c6_sel | 0x00D8 | W    | 0x00000000  | Configure the rm_io22 function                  |
| RM_IO_rm_gpio0c7_sel | 0x00DC | W    | 0x00000000  | Configure the rm_io23 function                  |
| RM_IO_rm_gpio1b1_sel | 0x00E0 | W    | 0x00000000  | Configure the rm_io24 function                  |
| RM_IO_rm_gpio1b2_sel | 0x00E4 | W    | 0x00000000  | Configure the rm_io25 function                  |
| RM_IO_rm_gpio1b3_sel | 0x00E8 | W    | 0x00000000  | Configure the rm_io26 function                  |
| RM_IO_rm_gpio1c2_sel | 0x00EC | W    | 0x00000000  | Configure the rm_io27 function                  |
| RM_IO_rm_gpio1c3_sel | 0x00F0 | W    | 0x00000000  | Configure the rm_io28 function                  |
| RM_IO_rm_gpio1d1_sel | 0x00F4 | W    | 0x00000000  | Configure the rm_io29 function                  |
| RM_IO_rm_gpio1d2_sel | 0x00F8 | W    | 0x00000000  | Configure the rm_io30 function                  |
| RM_IO_rm_gpio1d3_sel | 0x00FC | W    | 0x00000000  | Configure the rm_io31 function                  |
| RM_IO_test_status0   | 0x0300 | W    | 0x00000000  | Status of RM_IO output in test mode             |
| RM_IO_test_status1   | 0x0304 | W    | 0x00000000  | Status of RM_IO output in test mode             |
| RM_IO_test_status2   | 0x0308 | W    | 0x00000000  | Status of RM_IO output in test mode             |
| RM_IO_test_status3   | 0x030C | W    | 0x00000000  | Status of RM_IO output in test mode             |
| RM_IO_test_status4   | 0x0310 | W    | 0x00000000  | Status of output from PAD to RM_IO in test mode |

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

### 19.4.2 Detail Registers Description

#### RM IO rm gpio0a0 sel

Address: Operational Base(0xFF910000) + offset (0x0080)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio0a1\_sel**

Address: Operational Base(0xFF910000) + offset (0x0084)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio0a2\_sel**

Address: Operational Base(0xFF910000) + offset (0x0088)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio0a3\_sel**

Address: Operational Base(0xFF910000) + offset (0x008C)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio0a4\_sel**

Address: Operational Base(0xFF910000) + offset (0x0090)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio0a5\_sel**

Address: Operational Base(0xFF910000) + offset (0x0094)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio0a6\_sel**

Address: Operational Base(0xFF910000) + offset (0x0098)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio0a7\_sel**

Address: Operational Base(0xFF910000) + offset (0x009C)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio0b0\_sel**

Address: Operational Base(0xFF910000) + offset (0x00A0)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio0b1\_sel**

Address: Operational Base(0xFF910000) + offset (0x00A4)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio0b2\_sel**

Address: Operational Base(0xFF910000) + offset (0x00A8)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio0b3\_sel**

Address: Operational Base(0xFF910000) + offset (0x00AC)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio0b4\_sel**

Address: Operational Base(0xFF910000) + offset (0x00B0)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio0b5\_sel**

Address: Operational Base(0xFF910000) + offset (0x00B4)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio0b6\_sel**

Address: Operational Base(0xFF910000) + offset (0x00B8)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio0b7\_sel**

Address: Operational Base(0xFF910000) + offset (0x00BC)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio0c0\_sel**

Address: Operational Base(0xFF910000) + offset (0x00C0)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio0c1\_sel**

Address: Operational Base(0xFF910000) + offset (0x00C4)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio0c2\_sel**

Address: Operational Base(0xFF910000) + offset (0x00C8)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio0c3\_sel**

Address: Operational Base(0xFF910000) + offset (0x00CC)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio0c4\_sel**

Address: Operational Base(0xFF910000) + offset (0x00D0)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio0c5\_sel**

Address: Operational Base(0xFF910000) + offset (0x00D4)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio0c6\_sel**

Address: Operational Base(0xFF910000) + offset (0x00D8)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio0c7\_sel**

Address: Operational Base(0xFF910000) + offset (0x00DC)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio1b1\_sel**

Address: Operational Base(0xFF910000) + offset (0x00E0)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio1b2\_sel**

Address: Operational Base(0xFF910000) + offset (0x00E4)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio1b3\_sel**

Address: Operational Base(0xFF910000) + offset (0x00E8)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio1c2\_sel**

Address: Operational Base(0xFF910000) + offset (0x00EC)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio1c3\_sel**

Address: Operational Base(0xFF910000) + offset (0x00F0)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio1d1\_sel**

Address: Operational Base(0xFF910000) + offset (0x00F4)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio1d2\_sel**

Address: Operational Base(0xFF910000) + offset (0x00F8)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO rm\_gpio1d3\_sel**

Address: Operational Base(0xFF910000) + offset (0x00FC)

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

|     |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |      | func_sel<br>Select different function pins<br>7'h0: No pins are selected<br>7'h1: UART1_TX<br>7'h2: UART1_RX<br>7'h3: UART2_TX<br>7'h4: UART2_RX<br>7'h5: UART3_TX<br>7'h6: UART3_RX<br>7'h7: UART3_CTSN<br>7'h8: UART3_RTSN<br>7'h9: UART4_TX<br>7'hA: UART4_RX<br>7'hB: UART4_CTSN<br>7'hC: UART4_RTSN<br>7'hD: MIPI_DPHY_DSI_TX_TE<br>7'hE: CLK_32K<br>7'hF: I2C0_SCL<br>7'h10: I2C0_SDA<br>7'h11: I2C1_SCL<br>7'h12: I2C1_SDA<br>7'h13: I2C2_SCL<br>7'h14: I2C2_SDA<br>7'h15: PDM_CLK0<br>7'h16: PDM_SDIO0<br>7'h17: PDM_SDIO1<br>7'h18: PDM_SDIO2<br>7'h19: PDM_SDIO3<br>7'h1A: CAN1_TX<br>7'h1B: CAN1_RX<br>7'h1C: CAN0_TX<br>7'h1D: CAN0_RX<br>7'h1E: PWM0_CH0<br>7'h1F: PWM0_CH1<br>7'h20: PWM0_CH2<br>7'h21: PWM0_CH3<br>7'h22: PWM1_CH0<br>7'h23: PWM1_CH1<br>7'h24: PWM1_CH2<br>7'h25: PWM1_CH3<br>7'h26: PWM1_CH4<br>7'h27: PWM1_CH5<br>7'h28: PWM1_CH6<br>7'h29: PWM1_CH7<br>7'h2A: TOUCH_KEY_DRIVE<br>7'h2B: TOUCH_KEY_IN0<br>7'h2C: TOUCH_KEY_IN1<br>7'h2D: TOUCH_KEY_IN2<br>7'h2E: TOUCH_KEY_IN3<br>7'h2F: TOUCH_KEY_IN4<br>7'h30: TOUCH_KEY_IN5<br>7'h31: TOUCH_KEY_IN6<br>7'h32: TOUCH_KEY_IN7<br>7'h33: SAI0_MCLK<br>7'h34: SAI0_SCLK<br>7'h35: SAI0_LRCK<br>7'h36: SAI0_SDIO |
| 6:0 | RW | 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 7'h37: SAI0_SD1<br>7'h38: SAI0_SD2<br>7'h39: SAI0_SD3<br>7'h3A: SAI0_SDO<br>7'h3B: SAI1_MCLK<br>7'h3C: SAI1_SCLK<br>7'h3D: SAI1_LRCK<br>7'h3E: SAI1_SD1<br>7'h3F: SAI1_SDO0<br>7'h40: SAI1_SDO1<br>7'h41: SAI1_SDO2<br>7'h42: SAI1_SDO3<br>7'h43: SPI0_CLK<br>7'h44: SPI0_MOSI<br>7'h45: SPI0_MISO<br>7'h46: SPI0_CSNO<br>7'h47: SPI0_CSNI<br>7'h48: SPI1_CLK<br>7'h49: SPI1_MOSI<br>7'h4A: SPI1_MISO<br>7'h4B: SPI1_CSNO<br>7'h4C: SPI1_CSNI<br>7'h4D: TSADC_CTRL<br>7'h4E: PMU_SLEEP<br>7'h4F: CORE_POWER_OFF<br>7'h50: SPDIF_TX<br>7'h51: SPDIF_RX<br>7'h52: PWM1_BIP_CNTR_A0<br>7'h53: PWM1_BIP_CNTR_A1<br>7'h54: PWM1_BIP_CNTR_A2<br>7'h55: PWM1_BIP_CNTR_A3<br>7'h56: PWM1_BIP_CNTR_A4<br>7'h57: PWM1_BIP_CNTR_A5<br>7'h58: PWM1_BIP_CNTR_B0<br>7'h59: PWM1_BIP_CNTR_B1<br>7'h5A: PWM1_BIP_CNTR_B2<br>7'h5B: PWM1_BIP_CNTR_B3<br>7'h5C: PWM1_BIP_CNTR_B4<br>7'h5D: PWM1_BIP_CNTR_B5<br>7'h5E: PDM_CLK1<br>7'h5F: ETH_RMII0_PPSCLK<br>7'h60: ETH_RMII0_PPSTRI<br>7'h61: ETH_RMII1_PPSCLK<br>7'h62: ETH_RMII1_PPSTRI |

**RM IO test status0**

Address: Operational Base(0xFF910000) + offset (0x0300)

| Bit  | Attr | Reset Value | Description                            |
|------|------|-------------|----------------------------------------|
| 31:0 | RW   | 0x00000000  | sig_to_ip<br>Signal status 0~31 to IP. |

**RM IO test status1**

Address: Operational Base(0xFF910000) + offset (0x0304)

| Bit  | Attr | Reset Value | Description                             |
|------|------|-------------|-----------------------------------------|
| 31:0 | RW   | 0x00000000  | sig_to_ip<br>Signal status 32~63 to IP. |

**RM IO test status2**

Address: Operational Base(0xFF910000) + offset (0x0308)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                      |
|------------|-------------|--------------------|-----------------------------------------|
| 31:0       | RW          | 0x00000000         | sig_to_ip<br>Signal status 64~95 to IP. |

**RM IO test status3**

Address: Operational Base(0xFF910000) + offset (0x030C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                      |
|------------|-------------|--------------------|-----------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                |
| 1:0        | RW          | 0x0                | sig_to_ip<br>Signal status 96~97 to IP. |

**RM IO test status4**

Address: Operational Base(0xFF910000) + offset (0x0310)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                      |
|------------|-------------|--------------------|-----------------------------------------|
| 31:0       | RW          | 0x00000000         | sig_from_pad<br>Signal status from PAD. |

## 19.5 Interface Description

RM\_IO0~31 connects to different I/O pads. For details, see Table 19-1.

Table 19-1 RM\_IO Interface Description

| <b>Module Pin</b>       | <b>Dir</b> | <b>Pad Name</b> | <b>IOMUX Setting</b>                         |
|-------------------------|------------|-----------------|----------------------------------------------|
| <b>RM0_IO Interface</b> |            |                 |                                              |
| RM_IO0                  | I/O        | GPIO0_A0        | GPIO0_IOC_GPIO0A_IOMUX_SE<br>L_0[3:0]=4'h7   |
| RM_IO1                  | I/O        | GPIO0_A1        | GPIO0_IOC_GPIO0A_IOMUX_SE<br>L_0[7:4]=4'h7   |
| RM_IO2                  | I/O        | GPIO0_A2        | GPIO0_IOC_GPIO0A_IOMUX_SE<br>L_0[11:8]=4'h7  |
| RM_IO3                  | I/O        | GPIO0_A3        | GPIO0_IOC_GPIO0A_IOMUX_SE<br>L_0[15:12]=4'h7 |
| RM_IO4                  | I/O        | GPIO0_A4        | GPIO0_IOC_GPIO0A_IOMUX_SE<br>L_1[3:0]=4'h7   |
| RM_IO5                  | I/O        | GPIO0_A5        | GPIO0_IOC_GPIO0A_IOMUX_SE<br>L_1[7:4]=4'h7   |
| RM_IO6                  | I/O        | GPIO0_A6        | GPIO0_IOC_GPIO0A_IOMUX_SE<br>L_1[11:8]=4'h7  |
| RM_IO7                  | I/O        | GPIO0_A7        | GPIO0_IOC_GPIO0A_IOMUX_SE<br>L_1[15:12]=4'h7 |
| RM_IO8                  | I/O        | GPIO0_B0        | GPIO0_IOC_GPIO0B_IOMUX_SE<br>L_0[3:0]=4'h7   |
| RM_IO9                  | I/O        | GPIO0_B1        | GPIO0_IOC_GPIO0B_IOMUX_SE<br>L_0[7:4]=4'h7   |
| RM_IO10                 | I/O        | GPIO0_B2        | GPIO0_IOC_GPIO0B_IOMUX_SE<br>L_0[11:8]=4'h7  |
| RM_IO11                 | I/O        | GPIO0_B3        | GPIO0_IOC_GPIO0B_IOMUX_SE<br>L_0[15:12]=4'h7 |
| RM_IO12                 | I/O        | GPIO0_B4        | GPIO0_IOC_GPIO0B_IOMUX_SE<br>L_1[3:0]=4'h7   |
| RM_IO13                 | I/O        | GPIO0_B5        | GPIO0_IOC_GPIO0B_IOMUX_SE<br>L_1[7:4]=4'h7   |
| RM_IO14                 | I/O        | GPIO0_B6        | GPIO0_IOC_GPIO0B_IOMUX_SE                    |

| <b>Module Pin</b> | <b>Dir</b> | <b>Pad Name</b> | <b>IOMUX Setting</b>                         |
|-------------------|------------|-----------------|----------------------------------------------|
| 4                 |            |                 | L_1[11:8]=4'h7                               |
| RM_IO1_5          | I/O        | GPIO0_B7        | GPIO0_IOC_GPIO0B_IOMUX_SE<br>L_1[15:12]=4'h7 |
| RM_IO1_6          | I/O        | GPIO0_C0        | GPIO0_IOC_GPIO0C_IOMUX_SE<br>L_0[3:0]=4'h7   |
| RM_IO1_7          | I/O        | GPIO0_C1        | GPIO0_IOC_GPIO0C_IOMUX_SE<br>L_0[7:4]=4'h7   |
| RM_IO1_8          | I/O        | GPIO0_C2        | GPIO0_IOC_GPIO0C_IOMUX_SE<br>L_0[11:8]=4'h7  |
| RM_IO1_9          | I/O        | GPIO0_C3        | GPIO0_IOC_GPIO0C_IOMUX_SE<br>L_0[15:12]=4'h7 |
| RM_IO2_0          | I/O        | GPIO0_C4        | GPIO0_IOC_GPIO0C_IOMUX_SE<br>L_1[3:0]=4'h7   |
| RM_IO2_1          | I/O        | GPIO0_C5        | GPIO0_IOC_GPIO0C_IOMUX_SE<br>L_1[7:4]=4'h7   |
| RM_IO2_2          | I/O        | GPIO0_C6        | GPIO0_IOC_GPIO0C_IOMUX_SE<br>L_1[11:8]=4'h7  |
| RM_IO2_3          | I/O        | GPIO0_C7        | GPIO0_IOC_GPIO0C_IOMUX_SE<br>L_1[15:12]=4'h7 |
| RM_IO2_4          | I/O        | GPIO1_B1        | GPIO1_IOC_GPIO1B_IOMUX_SE<br>L_0[7:4]=4'h7   |
| RM_IO2_5          | I/O        | GPIO1_B2        | GPIO1_IOC_GPIO1B_IOMUX_SE<br>L_0[11:8]=4'h7  |
| RM_IO2_6          | I/O        | GPIO1_B3        | GPIO1_IOC_GPIO1B_IOMUX_SE<br>L_0[15:12]=4'h7 |
| RM_IO2_7          | I/O        | GPIO1_C2        | GPIO1_IOC_GPIO1C_IOMUX_SE<br>L_0[11:8]=4'h7  |
| RM_IO2_8          | I/O        | GPIO1_C3        | GPIO1_IOC_GPIO1C_IOMUX_SE<br>L_0[15:12]=4'h7 |
| RM_IO2_9          | I/O        | GPIO1_D1        | GPIO1_IOC_GPIO1D_IOMUX_S<br>EL_0[7:4]=4'h7   |
| RM_IO3_0          | I/O        | GPIO1_D2        | GPIO1_IOC_GPIO1D_IOMUX_S<br>EL_0[11:8]=4'h7  |
| RM_IO3_1          | I/O        | GPIO1_D3        | GPIO1_IOC_GPIO1D_IOMUX_S<br>EL_0[15:12]=4'h7 |

Notes: I=input, O=output, I/O=input/output

## 19.6 Application Notes

- If multiple RM\_IO configurations are configured for the same function (for example, RM\_GPIO0A0\_SEL == RM\_GPIO0A1\_SEL), a conflict will occur. The input and output of both RM\_IO are fixed to their default values.

## Chapter 20 Audio Subsystem

### 20.1 Overview

The audio subsystem is dedicated for managing the audio resources of the whole chip. In RK3506, the audio subsystem consists of three pieces: BUS\_WRAPPER, LS\_PERI wrapper and HS\_PERI wrapper. With the audio subsystem, we can combine audio components and the embedded SOC platform together and provide an audio system solution.

### 20.2 Block Diagram



Fig. 20-1 Audio Subsystem Block Diagram

#### LS\_PERI Wrapper

LS\_PERI Wrapper consists of audio components shown as follow:

- One PDM
- One SPDIF\_TX
- One SPDIF\_RX
- SAI0 (1 tx, 4 rx lanes) and SAI1 (4 tx, 1 rx lanes), which can be combined together
- Two 4 channel ASRC0/1, which can be combined together. Audio components in the HS\_PERI wrapper can also converted using ASRC0/1, not just the audio components in LS\_PERI wrapper.

#### HS\_PERI Wrapper

HS\_PERI Wrapper consists of audio components shown as follow:

- One Audio ADC
- One Audio DSM, which can be used to play audio data from SAI3
- SAI2/3 (1 lane), which can be combined together
- SAI4 (1 rx lane), which can be used to receive data from Audio ADC

#### BUS Wrapper

BUS Wrapper consists of two multichannel DMA called DMAC0 and DMAC1, which can be used to transmit audio data.

### 20.3 Function Description

In this chapter, we will only cover the interconnection of these audio components. For the detail of audio components, please refer to the following chapters: Audio DSM, Audio ADC, SPDIF Transmitter, SPDIF Receiver, PDM, Serial Audio Interface (SAI) and Asynchronous Sample Rate Converter (ASRC).

#### 20.3.1 SAI Series Mode

In series mode, SAIs in LS\_PERI wrapper or HS\_PERI wrapper can be combined together to

enhance throughput. We can appoint the SAI at the front as master and other SAIs as slave. In RK3506, SAI0 as master and SAI1 as slave when combined, SAI2 as master and SAI3 as slave when combined.

In series mode, the following internal signals interact to ensure that the combined SAIs stay synchronized. Meanwhile, the FS interface and SCLK interface of slave SAI are derived from master SAI instead. Besides, all combined SAIs can be viewed as a whole and interact with the outside world using their respective interface. We can take LS\_PERI wrapper series mode as an example in the following figure.



Fig. 20-2 SAI Series Mode Structure

### 20.3.2 ASRC Series Mode

In series mode, adjacent ASRCs in LS\_PERI wrapper can be combined together to enhance throughput. We can appoint the ASRC at the front as master and other ASRCs as slave. In RK3506, ASRC0 as master and ASRC1 as slave when combined.

In series mode, all combined ASRCs can be viewed as a whole and interact with the outside world using the interface of master ASRC only. We can take MEM2MEM series mode in audio0 wrapper as an example in the following figure.



Fig. 20-3 ASRC MEM2MEM Series Mode Structure

In series mode of SAI and ASRC, only the clock source of master is used. Combined SAIs using their own DMA handshake interface and interrupt interface, but only the interface of master ASRC is used when combined.

### 20.3.3 SPDIF Mux

Usually, the output of SPDIF\_TX is sent to IO. But for debug purpose, we can send the input of SPDIF\_RX to IO instead using the following selector.



Fig. 20-4 SPDIF SDO Selector

### 20.3.4 Audio DSM and SAI3

Audio DSM can be used to play audio data from SAI3. Three possible application can be shown as follow.

- Audio DSM acts as slave and SAI3 as master

- Clock source of audio DSM is from SAI3, and clock source of SAI3 is from CRU.
- Audio DSM acts as master and SAI3 as slave  
Clock source of audio DSM is from CRU, and clock source of SAI3 is from audio DSM.
- Both audio DSM and SAI3 acts as slave  
Clock source of audio DSM and SAI3 is from IO.



Fig. 20-5 Audio DSM Input Clock Selector



Fig. 20-6 SAI Input Clock Selector

## Chapter 21 Audio DSM

### 21.1 Overview

Audio DSM is a 16-bit digital audio encoder which supports multiple sample rates. It is mainly composed of digital DAC. The aim of digital DAC is to process the data received from I2S/PCM interface through filters, volume control and modulation.

The RK DSM supports the following features.

- Support 8-bit APB and AHB bus slave interface
- Support 2-channel digital DAC
- Support I2S/PCM interface
- Support I2S/PCM master and slave mode
- Support 2-channel audio receiving in I2S mode
- Support 2-channel audio receiving in PCM mode
- Support I2S normal, left and right justified mode serial audio data transfer
- Support PCM early, late1, late2, late3 mode serial audio data transfer
- Support MSB or LSB first serial audio data transfer
- Support configurable SCLK and LRCK polarity
- Support 16 bit sample resolution
- Support programmable left and right channel exchangeable in I2S mode and PCM mode
- Support three modes of mixing for every digital DAC channel
- Support volume control
- Support programmable negative and positive volume gain

### 21.2 Block Diagram



Fig.21-1 RK DSM Block Diagram

#### RK DSM\_RF

The RK DSM\_RF implements the 8-bit APB/AHB slave operation through APB/AHB bus. It is responsible for configuring the operation registers of other modules.

#### RK DSM\_CRU

The RK DSM\_CRU implements clock and reset generation function. It is responsible for generating sample clock, digital DAC operation clock and I2S operation clock.

#### RK DSM

There are 2 digital DAC channels. The digital DAC receives audio data from ACDC\_I2S module. It includes one CIC filter, one high-pass filter, several low-pass decimation filters and other audio signal processing related modules. The output of digital DAC is sent to DSM modular before transmitting outside.

#### RK DSM\_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 RK DSM\_I2S module can only operate in RX mode. When in RX mode, it receives audio data from I2S RX interface and sends it to digital DAC.

### **DSM Modulator**

It is a modulator that converts 16 bits audio sample data to 1 bit audio data.

## **21.3 Function description**

The I2S/PCM interface of Digital Audio Codec is connected to the I2S1 controller. Please refer to the I2S chapter for detailed information about I2S and PCM format that Digital Audio Codec supports.

### **21.3.1 Filters of Digital DAC**

I2S module receives two-channel audio data from I2S RX interface and drives it to the digital DAC which supports mixing function or directly to the DSM modulator. How to pour 2-channel audio data into 2-channel digital DAC can be achieved by programming mixing mode.

The 2-channel digital DAC includes a high-pass filter and a maximum of 5 half-band filters. The high-pass filter is used to filter DC components in audio data stream. Result of high-pass filter is sent to the digital DAC volume control module. The input of 5 half-band filters comes from output of volume control module with each perform 2-times interpolation. But not all of them are working all the time. How many of them are needed to work depends on the sample rate of digital DAC. The result of half-band filters is sent to a modulator.

### **21.3.2 Volume Control**

For digital DAC, output of high-pass filters is fed into volume control module. The volume control module inside digital DAC contains several sub-modules such as peak detect, frequency cross zero detect, LIMITER and digital gain control. It can be digitally attenuated over a range of -96dB~0dB in 0.375dB/step for negative gain and amplified over a range of 0dB~96dB in 0.375dB/step for positive gain. Whether is attenuated or amplified can be software programmed.

## **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                            |
|-----------------------|--------|------|-------------|----------------------------------------|
| RKDSTM_DSMVUCTL       | 0x0000 | W    | 0x00000001  | DAC Volume Control Register            |
| RKDSTM_DSMVUCTIME     | 0x0004 | W    | 0x00000000  | DAC Volume Control Time Limit Register |
| RKDSTM_DSMDIGEN       | 0x0008 | W    | 0x00000000  | DAC Digital Enable Register            |
| RKDSTM_DSMCLKCTRL     | 0x000C | W    | 0x00000000  | DAC Clock Control Register             |
| RKDSTM_DSMINTMOD_DIV  | 0x0014 | W    | 0x00000007  | DAC Integer Clock Divider Register     |
| RKDSTM_DSMINTSCLK_DIV | 0x0020 | W    | 0x0000001F  | I2S SCLK RX Integer Divider Register   |
| RKDSTM_DSM_DIV        | 0x0024 | W    | 0x00000003  | DSM Mode Integer Divider Register      |
| RKDSTM_DSM_CTRL       | 0x0028 | W    | 0x00000000  | DSM Mode Control Register              |
| RKDSTM_DSMCFG1        | 0x0044 | W    | 0x00000004  | DAC Configure Register 1               |
| RKDSTM_DSMMUTE        | 0x0048 | W    | 0x00000000  | DAC Mute Control Register              |
| RKDSTM_DSMMUTEST      | 0x004C | W    | 0x00000000  | DAC Mute Status Register               |
| RKDSTM_DSMVOLLO       | 0x0050 | W    | 0x00000000  | Volume of DAC Left Channel 0 Register  |
| RKDSTM_DSMVOLL1       | 0x0054 | W    | 0x00000000  | Volume of DAC Left Channel 0 Register  |

| Name                | Offset | Size | Reset Value | Description                                     |
|---------------------|--------|------|-------------|-------------------------------------------------|
| RKDSM_DSMVOLL2      | 0x0058 | W    | 0x00000000  | Volume of DAC Left Channel 0 Register           |
| RKDSM_DSMVOLL3      | 0x005C | W    | 0x00000000  | Volume of DAC Left Channel 0 Register           |
| RKDSM_DSMVOLR0      | 0x0060 | W    | 0x00000000  | Volume of DAC right Channel 1 Register          |
| RKDSM_DSMVOLR1      | 0x0064 | W    | 0x00000000  | Volume of DAC right Channel 1 Register          |
| RKDSM_DSMVOLR2      | 0x0068 | W    | 0x00000000  | Volume of DAC right Channel 1 Register          |
| RKDSM_DSMVOLR3      | 0x006C | W    | 0x00000000  | Volume of DAC right Channel 1 Register          |
| RKDSM_DSMVOGP       | 0x0070 | W    | 0x00000000  | DAC Volume Gain Polarity Register               |
| RKDSM_DSMRVOLL0     | 0x0074 | W    | 0x000000FF  | Internal Volume of DAC Left Channel 0 Register  |
| RKDSM_DSMRVOLL1     | 0x0078 | W    | 0x00000000  | Internal Volume of DAC Left Channel 0 Register  |
| RKDSM_DSMRVOLL2     | 0x007C | W    | 0x00000000  | Internal Volume of DAC Left Channel 0 Register  |
| RKDSM_DSMRVOLL3     | 0x0080 | W    | 0x00000000  | Internal Volume of DAC Left Channel 0 Register  |
| RKDSM_DSMRVOLR0     | 0x0084 | W    | 0x000000FF  | Internal Volume of DAC right Channel 1 Register |
| RKDSM_DSMRVOLR1     | 0x0088 | W    | 0x00000000  | Internal Volume of DAC right Channel 1 Register |
| RKDSM_DSMRVOLR2     | 0x008C | W    | 0x00000000  | Internal Volume of DAC right Channel 1 Register |
| RKDSM_DSMRVOLR3     | 0x0090 | W    | 0x00000000  | Internal Volume of DAC right Channel 1 Register |
| RKDSM_DSMLMT0       | 0x0094 | W    | 0x00000000  | DAC Limiter Register 0                          |
| RKDSM_DSMLMT1       | 0x0098 | W    | 0x00000000  | DAC Limiter Register 1                          |
| RKDSM_DSMLMT2       | 0x009C | W    | 0x00000000  | DAC Limiter Register 2                          |
| RKDSM_DSMMIXCTRLL   | 0x00A0 | W    | 0x00000000  | DAC Mixing Control Register Of Left Channels    |
| RKDSM_DSMMIXCTRLR   | 0x00A4 | W    | 0x00000000  | DAC Mixing Control Register Of right Channels   |
| RKDSM_DSMHPF        | 0x00A8 | W    | 0x00000000  | DAC High-pass Filter Control Register           |
| RKDSM_DSM_I2S_RXCR0 | 0x010C | W    | 0x0000000F  | Receive Operation Control Register 0            |
| RKDSM_DSM_I2S_RXCR1 | 0x0110 | W    | 0x00000000  | Receive Operation Control Register 1            |
| RKDSM_DSM_I2S_CKR0  | 0x0114 | W    | 0x00000000  | Clock Generation Register 0                     |
| RKDSM_DSM_I2S_CKR1  | 0x0118 | W    | 0x00000000  | Clock Generation Register 1                     |
| RKDSM_DSM_I2S_XFER  | 0x011C | W    | 0x00000000  | Transfer Start Register                         |
| RKDSM_DSM_I2S_CLR   | 0x0120 | W    | 0x00000000  | SCLK Domain Logic Clear Register                |
| RKDSM_DSM_VERSION   | 0x0140 | W    | 0x00000010  | Version Register                                |

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

### 21.4.3 Detail Registers Description

#### RKDSM\_DSMVUCTL

Address: Operational Base(0xFF4B0000) + offset (0x0000)

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:3 | RO   | 0x00000000  | reserved    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | dac_byps<br>Digital DAC volume control bypass.<br>1'b0: Digital DAC volume control enable<br>1'b1: Digital DAC volume control bypass                                                                                                                         |
| 1          | RW          | 0x0                | dacfade<br>Digital DAC volume adjust mode.<br>1'b0: Update to new volume immediately.<br>1'b1: Update volume as daczdt field describes.                                                                                                                      |
| 0          | RW          | 0x1                | daczdt<br>Digital DAC volume cross zero detect enable. It works when dac_byps is 1'b0 and dacfade is 1'b1.<br>1'b0: Volume adjusts every sample.<br>1'b1: Volume adjusts only when audio waveform crosses zero or volume-control time-limit condition meets. |

**RKDSM\_DSMVUCTIME**

Address: Operational Base(0xFF4B0000) + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                               |
| 7:0        | RW          | 0x00               | dacvuct<br>Volume control time limit, valid only in fade cross zero mode.<br>Time limit = dacvuct*(1/sample rate)<br>Unit: Sample rate |

**RKDSM\_DSMDIGEN**

Address: Operational Base(0xFF4B0000) + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0000000          | reserved                                                                                                                                                                                                  |
| 4          | RW          | 0x0                | dacglben<br>Global enable of all Digital DAC channels. Only when dacglben and the enable signal corresponding to each Digital DAC channel is valid before starting work.<br>1'b0: Disable<br>1'b1: Enable |
| 3:1        | RO          | 0x0                | reserved                                                                                                                                                                                                  |
| 0          | RW          | 0x0                | dacen_l0r1<br>Digital DAC left channel 0 and right channel 1 enable.<br>1'b0: Disable<br>1'b1: Enable                                                                                                     |

**RKDSM\_DSMCLKCTRL**

Address: Operational Base(0xFF4B0000) + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x0000000          | reserved                                                                               |
| 5          | RW          | 0x0                | dac_cke<br>Digital DAC operation clock enable.<br>1'b0: Disable<br>1'b1: Enable        |
| 4          | RW          | 0x0                | i2srx_cke<br>Clock enable of internal I2S RX channel.<br>1'b0: Disable<br>1'b1: Enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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 used internally generated by Digital DAC.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                                                                                                                 |
| 1          | RO          | 0x0                | dac_sync_status<br>There is a counter to generate synchronization signal of Digital DAC. In order to ensure the integrity of synchronization signal, it is necessary to read back dac_sync_status to judge whether the counter stops working when dac_sync_ena is set from 1'b1 to 1'b0. If the signal is read back to 1'b0, it means that the counter stops working and the synchronization signal of Digital DAC is complete. |
| 0          | 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                                                                                                                                                                                                                               |

#### **RKDSM\_DSMINTMOD\_DIV**

Address: Operational Base(0xFF4B0000) + offset (0x0014)

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

#### **RKDSM\_DSMINTSCLK\_DIV**

Address: Operational Base(0xFF4B0000) + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                                                                                                                                |
| 7:0        | RW          | 0x1f               | sckrxdiv<br>Integer clock divider to generate sclk_out_rx when I2S RX works in master mode. It is ignored when in slave mode.<br>Sckrxdiv=((frequency of input operation clock)/(frequency of sclk_out_rx))-1. Sckrxdiv can be any value from 0 to 255. |

#### **RKDSM\_DSM\_DIV**

Address: Operational Base(0xFF4B0000) + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                                                                                                                                          |
| 7:0        | RW          | 0x03               | audio_dsm_div<br>DSM mode division of Digital DAC's operation clock.<br>The operation clock frequency of DSM module is equal to the input operation clock frequency of Digital DAC's divided by audio_dsm_div+1. It's recommended that audio_dsm_div is set 8'h3. |

#### **RKDSM\_DSM\_CTRL**

## RK3506 TRM (Part 1)

Address: Operational Base(0xFF4B0000) + offset (0x0028)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                    |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7 | RO   | 0x00000000  | reserved                                                                                                                                                                                                                                                                       |
| 6    | RW   | 0x0         | dsm_mode_cke<br>Clock enable of 1-bit DSM modulator<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                           |
| 5:4  | RW   | 0x0         | dsm_mode<br>Audio DSM mode selection<br>2'b01: Audio DSM mode 0. The input of 1-bit DSM modulator is from the last filter of Audio DAC.<br>2'b10: Audio DSM mode 1. The input of 1-bit DSM modulator is directly from output of I2S RX inside the ACDCDIG.<br>Others: Reserved |
| 3    | RW   | 0x0         | dsm_en<br>1-bit DSM modulator enable<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                          |
| 2:0  | RW   | 0x0         | dith_sel<br>Dith mode selection of 1-bit DSM modulator.                                                                                                                                                                                                                        |

## RKDSTM DSMCFG1

Address: Operational Base(0xFF4B0000) + offset (0x0044)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | RO   | 0x00000000  | reserved                                                                                                                                                                                                                                                                                                   |
| 4:2  | RW   | 0x1         | dacsrt<br>Sample rates of Digital DAC when in audio DSM mode 0. This field is ignored when in audio DSM mode 1.<br>3'b000: 12kHz/11.024kHz/8kHz<br>3'b001: 24kHz/22.05kHz/16kHz<br>3'b010: 32kHz/48kHz/44.1kHz<br>3'b011: 96kHz/88.2kHz/64kHz<br>3'b100: 192kHz/176.4kHz/128kHz<br>3'b101~3'b111: Reserved |
| 1:0  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                   |

## RKDSTM DSMMUTE

Address: Operational Base(0xFF4B0000) + offset (0x0048)

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

## RKDSTM DSMMUTEST

Address: Operational Base(0xFF4B0000) + offset (0x004C)

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:5 | RO   | 0x00000000  | reserved    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | RO          | 0x0                | unmutest_l0r1<br>Unmute status for Digital DAC left channel 0 and right channel 1.<br>When unmute is done, it indicates that internal volume is equal to the value programmed in DACVOLL* and DACVOLR*.<br>1'b0: Unmute not done<br>1'b1: Unmute done |
| 3:1        | RO          | 0x0                | reserved                                                                                                                                                                                                                                              |
| 0          | RO          | 0x0                | mutest_l0r1<br>Mute status for Digital DAC left channel 0 and right channel 1.<br>1'b0: Not mute<br>1'b1: Mute                                                                                                                                        |

**RKDSM DSMVOLLO**

Address: Operational Base(0xFF4B0000) + offset (0x0050)

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

**RKDSM DSMVOLL1**

Address: Operational Base(0xFF4B0000) + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                                                        |
| 7:0        | RW          | 0x00               | daclv1<br>Volume of Digital DAC left 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 |

**RKDSM DSMVOLL2**

Address: Operational Base(0xFF4B0000) + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                                                        |
| 0          | RW          | 0x0                | daclv2<br>Volume of Digital DAC 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 |

**RKDSM DSMVOLL3**

### **RK3506 TRM (Part 1)**

Address: Operational Base(0xFF4B0000) + offset (0x005C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                                                       |
| 0          | RW          | 0x0                | daclv3<br>Volume of Digital DAC left channel 3.<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 |

### **RKDSM\_DSMVOLR0**

Address: Operational Base(0xFF4B0000) + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                                                        |
| 7:0        | RW          | 0x00               | dacrv0<br>Volume of Digital DAC right 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 |

### **RKDSM\_DSMVOLR1**

Address: Operational Base(0xFF4B0000) + offset (0x0064)

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

### **RKDSM\_DSMVOLR2**

Address: Operational Base(0xFF4B0000) + offset (0x0068)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                                                        |
| 0          | RW          | 0x0                | dacrv2<br>Volume of Digital DAC right 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 |

### **RKDSM\_DSMVOLR3**

Address: Operational Base(0xFF4B0000) + offset (0x006C)

## **RK3506 TRM (Part 1)**

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                                                         |
| 0          | RW          | 0x0                | dacrv3<br>Volume of Digital DAC right channel 3.<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'fff: -95.625db |

### **RKDSM DSMVOGP**

Address: Operational Base(0xFF4B0000) + offset (0x0070)

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

### **RKDSM DSMRVOLLO**

Address: Operational Base(0xFF4B0000) + offset (0x0074)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                           |
| 7:0        | RO          | 0xff               | rvoil0<br>Internal real-time volume of Digital DAC left channel 0. |

### **RKDSM DSMRVOLL1**

Address: Operational Base(0xFF4B0000) + offset (0x0078)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                           |
| 0          | RW          | 0x0                | rvoil1<br>Internal real-time volume of Digital DAC left channel 1. |

### **RKDSM DSMRVOLL2**

Address: Operational Base(0xFF4B0000) + offset (0x007C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                           |
| 0          | RW          | 0x0                | rvoil2<br>Internal real-time volume of Digital DAC left channel 2. |

### **RKDSM DSMRVOLL3**

Address: Operational Base(0xFF4B0000) + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                           |
| 0          | RW          | 0x0                | rvoil3<br>Internal real-time volume of Digital DAC left channel 3. |

### **RKDSM DSMRVOLR0**

Address: Operational Base(0xFF4B0000) + offset (0x0084)

## RK3506 TRM (Part 1)

| Bit  | Attr | Reset Value | Description                                                         |
|------|------|-------------|---------------------------------------------------------------------|
| 31:8 | RO   | 0x0000000   | reserved                                                            |
| 7:0  | RO   | 0xff        | rvolr0<br>Internal real-time volume of Digital DAC right channel 0. |

### RKDSM\_DSMRVOLR1

Address: Operational Base(0xFF4B0000) + offset (0x0088)

| Bit  | Attr | Reset Value | Description                                                         |
|------|------|-------------|---------------------------------------------------------------------|
| 31:1 | RO   | 0x000000000 | reserved                                                            |
| 0    | RW   | 0x0         | rvolr1<br>Internal real-time volume of Digital DAC right channel 1. |

### RKDSM\_DSMRVOLR2

Address: Operational Base(0xFF4B0000) + offset (0x008C)

| Bit  | Attr | Reset Value | Description                                                         |
|------|------|-------------|---------------------------------------------------------------------|
| 31:1 | RO   | 0x000000000 | reserved                                                            |
| 0    | RW   | 0x0         | rvolr2<br>Internal real-time volume of Digital DAC right channel 2. |

### RKDSM\_DSMRVOLR3

Address: Operational Base(0xFF4B0000) + offset (0x0090)

| Bit  | Attr | Reset Value | Description                                                         |
|------|------|-------------|---------------------------------------------------------------------|
| 31:1 | RO   | 0x000000000 | reserved                                                            |
| 0    | RW   | 0x0         | rvolr3<br>Internal real-time volume of Digital DAC right channel 3. |

### RKDSM\_DSMLMT0

Address: Operational Base(0xFF4B0000) + offset (0x0094)

| Bit  | Attr | Reset Value | Description                                                                                                                   |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | RO   | 0x000000000 | 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 |

### RKDSM\_DSMLMT1

Address: Operational Base(0xFF4B0000) + offset (0x0098)

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

### RKDSM\_DSMLMT2

Address: Operational Base(0xFF4B0000) + offset (0x009C)

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:7 | RO   | 0x0000000   | reserved    |

## RK3506 TRM (Part 1)

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

### RKDSM DSMMIXCTRLL

Address: Operational Base(0xFF4B0000) + offset (0x00A0)

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

### RKDSM DSMMIXCTRLR

Address: Operational Base(0xFF4B0000) + offset (0x00A4)

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

### RKDSM DSMHPF

Address: Operational Base(0xFF4B0000) + offset (0x00A8)

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

### RKDSM DSM I2S RXCR0

Address: Operational Base(0xFF4B0000) + offset (0x010C)

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:8 | RO   | 0x00000000  | reserved    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:6        | RW          | 0x0                | pbm<br>PCM bus mode<br>2'b00: PCM no delay mode<br>2'b01: PCM delay 1 mode<br>2'b10: PCM delay 2 mode<br>2'b11: PCM delay 3 mode                                                                                        |
| 5          | RW          | 0x0                | tfs<br>Transfer format select<br>1'b0: I2S format<br>1'b1: PCM format                                                                                                                                                   |
| 4:0        | RW          | 0x0f               | vdw<br>Valid data width<br>5'b00000~5'b01110: Reserved<br>5'b01111: 16bit<br>5'b10000: 17bit<br>5'b10001: 18bit<br>5'b10010: 19bit<br>.....<br>5'b11100: 29bit<br>5'b11101: 30bit<br>5'b11110: 31bit<br>5'b11111: 32bit |

**RKDSM DSM I2S RXCR1**

Address: Operational Base(0xFF4B0000) + offset (0x0110)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                               |
| 7:6        | RW          | 0x0                | rcsr<br>Channel select<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                | fbm<br>First bit mode<br>1'b0: MSB<br>1'b1: LSB                                                                        |
| 1:0        | RW          | 0x0                | ibm<br>I2S bus mode<br>2'b00: I2S normal<br>2'b01: I2S Left justified<br>2'b10: I2S Right justified<br>2'b11: Reserved |

**RKDSM DSM I2S CKR0**

Address: Operational Base(0xFF4B0000) + offset (0x0114)

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

## RK3506 TRM (Part 1)

| Bit | Attr | Reset Value | Description                                                                                      |
|-----|------|-------------|--------------------------------------------------------------------------------------------------|
| 3:2 | RW   | 0x0         | rsd<br>I2S rx sclk divider for rx_irck generator.<br>2'b00: 64<br>2'b01: 128<br>2'b10~2'b11: 256 |
| 1:0 | RO   | 0x0         | reserved                                                                                         |

### RKDSM DSM I2S CKR1

Address: Operational Base(0xFF4B0000) + offset (0x0118)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                  |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | RO   | 0x00000000  | reserved                                                                                                                                                                                                                                                                                                                                                                                     |
| 3    | RW   | 0x0         | mss<br>Master/slave mode select<br>1'b0: Master mode(sclk output)<br>1'b1: Slave mode(sclk input)                                                                                                                                                                                                                                                                                            |
| 2    | RW   | 0x0         | ckp<br>Sclk polarity<br>1'b0: Sample data at posedge sclk and drive data at negedge sclk.<br>1'b1: Sample data at negedge sclk and drive data at posedge sclk.                                                                                                                                                                                                                               |
| 1    | RW   | 0x0         | rlp<br>1'b0: Normal polarity<br>(I2S normal: low for left channel, high for right channel<br>I2S left/right just: high for left channel, low for right channel<br>PCM start signal: high valid)<br>1'b1: Opposite polarity<br>(I2S normal: high for left channel, low for right channel<br>I2S left/right just: low for left channel, high for right channel<br>PCM start signal: low valid) |
| 0    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                     |

### RKDSM DSM I2S XFER

Address: Operational Base(0xFF4B0000) + offset (0x011C)

| Bit  | Attr | Reset Value | Description                                              |
|------|------|-------------|----------------------------------------------------------|
| 31:2 | RO   | 0x00000000  | reserved                                                 |
| 1    | RW   | 0x0         | rxs<br>1'b0: Stop RX transfer<br>1'b1: Start RX transfer |
| 0    | RO   | 0x0         | reserved                                                 |

### RKDSM DSM I2S CLR

Address: Operational Base(0xFF4B0000) + offset (0x0120)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                      |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | RO   | 0x00000000  | reserved                                                                                                                                                                                         |
| 1    | RW   | 0x0         | rxc<br>This is a self-cleared bit. Write 1'b1 to clear all receive logic.<br>This bit can be set only when rxs is 1'b0. After writing rxc to 1'b1,<br>wait until rxc become 1'b0 by polling rxc. |
| 0    | RO   | 0x0         | reserved                                                                                                                                                                                         |

### RKDSM DSM VERSION

Address: Operational Base(0xFF4B0000) + offset (0x0140)

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:8 | RO   | 0x00000000  | reserved    |

| Bit | Attr | Reset Value | Description            |
|-----|------|-------------|------------------------|
| 7:0 | RO   | 0x10        | ver<br>Version of DSM. |

## 21.5 Interface Description

The I2S RX interface of Digital Audio Codec is connected to the TX interface of I2S1 when GRF\_AUDIO\_CON[14] is set to 1'b1.

When operating in audio DSM mode 0 or 1, Digital Audio Codec outputs two pairs of differential signals encoded in DSM format. The following table shows the RK DSM interface description for audio DSM mode.

Table 21-1 Audio DSM M0 Interface Description

| Module Pin    | Direction | Pad Name | IOMUX Setting                        |
|---------------|-----------|----------|--------------------------------------|
| AUDIO_DSM_L_P | O         | GPIO1_D1 | GPIO1_IOC_GPIO1D_IOMUX_SEL_0[7:4]=4  |
| AUDIO_DSM_L_N | O         | GPIO1_D0 | GPIO1_IOC_GPIO1D_IOMUX_SEL_0[3:0]=4  |
| AUDIO_DSM_R_P | O         | GPIO1_C2 | GPIO1_IOC_GPIO1C_IOMUX_SEL_0[11:8]=4 |
| AUDIO_DSM_R_N | O         | GPIO1_C1 | GPIO1_IOC_GPIO1C_IOMUX_SEL_0[7:4]=4  |

Table 21-2 Audio DSM M1 Interface Description

| Module Pin    | Direction | Pad Name | IOMUX Setting                         |
|---------------|-----------|----------|---------------------------------------|
| AUDIO_DSM_L_P | O         | GPIO2_B7 | GPIO2_IOC_GPIO2B_IOMUX_SEL_1[15:12]=2 |
| AUDIO_DSM_L_N | O         | GPIO2_B6 | GPIO2_IOC_GPIO2B_IOMUX_SEL_1[11:8]=2  |
| AUDIO_DSM_R_P | O         | GPIO2_B5 | GPIO2_IOC_GPIO2B_IOMUX_SEL_1[7:4]=2   |
| AUDIO_DSM_R_N | O         | GPIO2_B4 | GPIO2_IOC_GPIO2B_IOMUX_SEL_1[3:0]=2   |

## 21.6 Application Notes

### 21.6.1 Software Application Notes

Steps to configure Digital DAC to work in audio DSM mode 0 are as follows.

1. Program CRU in the SOC system to achieve the operation frequency of Digital DAC.
2. Program DSMINTMOD\_DIV to 0x07.
3. Program DSMCLKCTRL to 0x3d.
4. Program DSMINTSCLK\_DIV if Digital DAC I2S RX acts as master.
5. Program DSMDSM\_CTRL to 0x58.
6. Program DSM\_I2S\_CKR0 and ACDCDIG\_I2S\_CKR1 to set I2S RX related registers.
7. Program DSM\_I2S\_CLR to clear RX logic.
8. Program DSM\_I2S\_RXCR0 and ACDCDIG\_I2S\_RXCR1.
9. Program GRF\_AUDIO\_CON[14] to 1'b1 and program registers of I2S1 that is connected to Digital Audio Codec. Don't start transfer at this time.
10. Program DAC related registers such as DSMHPF, DSMVUCTL and DSMCFG1 to achieve basic configuration.
11. Program ACDCDIG\_I2S\_XFER to start I2S RX.
12. Program registers of I2S1 outside Digital Audio Codec to start TX.
13. Program DSMDIGEN to enable digital DAC channels. From now on, the Digital Audio Codec begins to work.

Steps to configure Digital Audio Codec to end audio DSM mode 0 transfer are as follows.

1. Program registers of I2S1 to stop TX and ACDCDIG\_I2S\_XFER to stop RX.
2. Program DSMDSM\_CTRL to 0x0.
3. Program DSMDIGEN to disable digital DAC channels.
4. Program DSMCLKCTRL to 0x0. Wait DSMCLKCTRL.dac\_sync\_status until read back to be 1'b0.

Steps to configure Digital DAC to work in audio DSM mode 1 are as follows.

1. Program CRU in the SOC system to achieve the operation frequency of Digital DAC.

2. Program DSMCLKCTRL to 0x3d.
  3. Program DMSCLKRXINT\_DIV if Digital DAC I2S RX acts as master.
  4. Program DSMDSM\_CTRL to 0x68.
  5. Program DSM\_I2S\_CKR0 and ACDCDIG\_I2S\_CKR1 to set I2S RX related registers.
  6. Program DSM\_I2S\_CLR to clear RX logic.
  7. Program DSM\_I2S\_RXCR0 and ACDCDIG\_I2S\_RXCR1.
  8. Program GRF\_AUDIO\_CON[14] to 1'b1 and program registers of I2S1 to start TX.
  9. Program DSM\_I2S\_XFER to start I2S RX. From now on, the Digital Audio Codec begins to work.
- Steps to configure Digital Audio Codec to end audio DSM mode 1 transfer are as follows.
1. Program registers of I2S1 to stop TX and DSM\_I2S\_XFER to stop RX.
  2. Program DSMDSM\_CTRL to 0x0.
  3. Program DSMCLKCTRL to 0x0. Wait DSMCLKCTRL.dac\_sync\_status until read back to be 1'b0.

## Chapter 22 Audio ADC

### 22.1 Overview

Audio ADC is a 24-bit digital audio decoder which supports multiple sample rates. The function of Audio ADC is to convert external MIC input analog signal to I2S/PCM format audio data through a series of filters and volume control. The coding process of Audio ADC is controlled by the register through the APB Bus.

Audio ADC supports the following features.

- Support APB bus slave interface
- Support Analog gain between 0~48dB with 3db/step
- Support 1-channel Differential-mode/Single-mode/Pseudo-differential mode ADC
- Support I2S/PCM master and slave 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 16 ~32bit 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
- The passband of filters is  $0.45625 * fs$
- Support passband ripple within +/-0.1dB
- The stopband of filters is  $0.5 * fs$
- Support stopband attenuation at least 60dB
- Support Digital Audio ADC volume control
- Support programmable negative volume gain and positive volume gain.

### 22.2 Block Diagram



Fig. 22-1 Audio ADC Block Diagram

## 22.3 Function Description

### 22.3.1 I2S normal mode

This is the waveform of I2S normal mode. For LRCK (i2s\_lrck\_tx) signal, it goes low to indicate left channel and high to right channel. For SD (i2s\_sdo) 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. The left and right channels transmit the same data.



Fig.22-2 I2S Normal Mode Timing Format

### 22.3.2 I2S left justified mode

This is the waveform of I2S left justified mode. For LRCK (i2s\_lrck\_tx) signal, it goes high to indicate left channel and low to right channel. For SD (i2s\_sdo) 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. The left and right channels transmit the same data.



Fig.22-3 I2S Left Justified Mode Timing Format

### 22.3.3 I2S right justified mode

This is the waveform of I2S right justified mode. For LRCK (i2s\_lrck\_tx) signal, it goes high to indicate left channel and low to right channel. For SD (i2s\_sdo) 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. The left and right channels transmit the same data.



Fig.22-4 I2S Right Justified Mode Timing Format

### 22.3.4 PCM early mode

This is the waveform of PCM early mode. For LRCK (i2s\_lrck\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s\_sdo) 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. The left and right channels transmit the same data.



Fig.22-5 PCM Early Mode Timing Format

### 22.3.5 PCM late1 mode

This is the waveform of PCM late1 mode. For LRCK (i2s\_lrck\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s\_sdo) 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. The left and right channels transmit the same data.



Fig.22-6 PCM Late1 Mode Timing Format

### 22.3.6 PCM late2 mode

This is the waveform of PCM late2 mode. For LRCK (i2s\_lrck\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s\_sdo) 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. The left and right channels transmit the same data.



Fig.22-7 PCM Late2 Mode Timing Format

### 22.3.7 PCM late3 mode

This is the waveform of PCM late3 mode. For LRCK (i2s\_lrck\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s\_sdo) 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. The left and right channels transmit the same data.



Fig.22-8 PCM Late3 Mode Timing Format

### 22.3.8 Digital Filters

In order to achieve PCM format audio data from input 1-bit data stream, a total of 5 filters are embedded in ADC module. It includes a CIC decimation filter, a compensation filter, 2 half-band filters and a high pass filter.

The CIC decimation filter achieves 8-times or 16-times or 32-times or 64-times or 128-times decimation. Which decimation rate is selected depends on the sample rate. For example, in order to output a 12K sample rate signal, 128-times decimation rate need to be selected.

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. It is valid only when CIC decimation filter works in 32-times or 64-times decimation.

The 2 half-band filters each perform 2-times decimation.

The high pass filter is used to filter DC components in audio data stream. The result of high pass filter is sent to the volume control.

### 22.3.9 Volume Control

The PCM format data output from the high pass filter are fed into the volume control. It can be digitally attenuated over a range of -95.625dB~0dB in 0.375dB/step for negative gain.

The ADC IP has an 8-bit register for volume control. For negative gain, 0xff corresponds to digital mute while 0x00 corresponds to 0dB.

### 22.3.10 Frequency Configuration

ACDC\_CLK is the input clock of Audio ADC. All internal clocks are generated by ACDC\_CLK if the I2S module acts as a master. ACDC\_CLK must be homologous to the operation clock of I2S master when the I2S module of Audio ADC acts as a slave. There is another clock named ADC\_CLK acting as sample clock generated from ACDC\_CLK and sent out to the Analogy Audio ADC. The relationship of ACDC\_CLK, ADC\_CLK and sample rates is as follows where the ACDC\_CLK is 8 times of ADC\_CLK. Make sure that the frequency of ACDC\_CLK is at least 8 times of ADC\_CLK.

Table 22-1 Relationship of ACDC\_CLK, ADC\_CLK and Sample Rates in Normal Mode

| ACDC_CLK    | ADC_CLK    | Sample rate supported             |
|-------------|------------|-----------------------------------|
| 49.152MHz   | 6.144MHz   | 12k/24k/48k/96k/192k              |
| 45.1584 MHz | 5.6448 MHz | 11.025k/22.05k/44.1k/88.2k/176.4k |
| 32.768MHz   | 4.096MHz   | 8k/16k/32k/64k/128k               |

## 22.4 Register Description

### 22.4.1 Registers Summary

| Name                   | Offset | Size | Reset Value | Description                               |
|------------------------|--------|------|-------------|-------------------------------------------|
| Audio_ADC_ADC_0        | 0x0008 | W    | 0x00000001  | Main ADC Function Setting Register 0      |
| Audio_ADC_ADC_1        | 0x000C | W    | 0x00000021  | Main ADC Function Setting Register 1      |
| Audio_ADC_ADC_2        | 0x0010 | W    | 0x00000002  | Main ADC Function Setting Register 2      |
| Audio_ADC_MIC_PGA_0    | 0x0014 | W    | 0x00000001  | MIC_PGA Block Setting Register 0          |
| Audio_ADC_MIC_PGA_1    | 0x0018 | W    | 0x00000000  | MIC_PGA Block Setting Register 1          |
| Audio_ADC_MIC_PGA_2    | 0x001C | W    | 0x00000000  | MIC_PGA Block Setting Register 2          |
| Audio_ADC_ADC_LDO      | 0x0020 | W    | 0x00000008  | ADC LDO Setting Register                  |
| Audio_ADC_ADC_HK_0     | 0x0024 | W    | 0x00000000  | ADC Housekeeping Block Setting Register 0 |
| Audio_ADC_ADC_HK_1     | 0x0028 | W    | 0x00000000  | ADC Housekeeping Block Setting Register 1 |
| Audio_ADC_DIG_CLKEN    | 0x002C | W    | 0x00000000  | Digital Enable and Clock Control Register |
| Audio_ADC_VOL_CTL      | 0x0030 | W    | 0x00000000  | Volume of Digital ADC Configure Register  |
| Audio_ADC_ADC_AGCO     | 0x0034 | W    | 0x00000002  | Digital AGC Configure Register 0          |
| Audio_ADC_ADC_AGCI     | 0x0038 | W    | 0x00000000  | Digital AGC Configure Register 1          |
| Audio_ADC_ADC_AGC2     | 0x003C | W    | 0x00000070  | Digital AGC Configure Register 2          |
| Audio_ADC_ADC_AGC3     | 0x0040 | W    | 0x00000006  | Digital AGC Configure Register 3          |
| Audio_ADC_ADC_AGC4     | 0x0044 | W    | 0x00000060  | Digital AGC Configure Register 4          |
| Audio_ADC_ADC_AGC5     | 0x0048 | W    | 0x00000007  | Digital AGC Configure Register 5          |
| Audio_ADC_ADC_AGC6     | 0x004C | W    | 0x0000005A  | Digital AGC Configure Register 6          |
| Audio_ADC_ADC_AGC7     | 0x0050 | W    | 0x00000004  | Digital AGC Configure Register 7          |
| Audio_ADC_ADC_AGC8     | 0x0054 | W    | 0x00000066  | Digital AGC Configure Register 8          |
| Audio_ADC_ADC_STATUS_0 | 0x0058 | W    | 0x00000000  | ADC Status Register 0                     |
| Audio_ADC_ADC_STATUS_1 | 0x005C | W    | 0x00000000  | ADC Status Register 1                     |
| Audio_ADC_ADC_FILTER   | 0x0060 | W    | 0x0000000B  | Digital Filter Configure Register         |
| Audio_ADC_I2S_CKM      | 0x0064 | W    | 0x00000001  | I2S Clock Control Register                |
| Audio_ADC_I2S_TXCR0    | 0x0068 | W    | 0x000000B8  | I2S TX Control Register 0                 |
| Audio_ADC_I2S_TXCR1    | 0x006C | W    | 0x00000000  | I2S TX Control Register 1                 |
| Audio_ADC_I2S_TXCMD    | 0x0070 | W    | 0x00000000  | I2S TX Command Register                   |

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

Double WORD (64 bits) access

### 22.4.2 Detail Registers Description

#### Audio\_ADC\_ADC\_0

## RK3506 TRM (Part 1)

Address: Operational Base(0xFF4F8000) + offset (0x0008)

| Bit  | Attr | Reset Value | Description                                                                                                                                                  |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0000000   | reserved                                                                                                                                                     |
| 7:6  | RW   | 0x0         | adc_delay_clksel<br>ADC sample clock delay control<br>2'b00: Delay 100%<br>2'b01: Delay 75%<br>2'b10: Delay 50%<br>2'b11: Delay 25%                          |
| 5:4  | RW   | 0x0         | adc_delay_intsel<br>Internal ADC delay control<br>2'b00: Delay 100%<br>2'b01: Delay 75%<br>2'b10: Delay 50%<br>2'b11: Delay 25%                              |
| 3:2  | RW   | 0x0         | adc_meth_ctrl<br>Meth code select<br>2'b00: Thermometer code<br>2'b01: Normal math code<br>2'b10: One-direction math code<br>2'b11: Dual-direction math code |
| 1    | RW   | 0x0         | adc_zero<br>ADC integrator reset<br>1'b0: ADC working<br>1'b1: ADC reset to zero                                                                             |
| 0    | RW   | 0x1         | adc_pwd<br>Analog ADC power down configure<br>1'b0: Power on<br>1'b1: Power down                                                                             |

## Audio ADC ADC 1

Address: Operational Base(0xFF4F8000) + offset (0x000C)

| Bit  | Attr | Reset Value | Description                                                                |
|------|------|-------------|----------------------------------------------------------------------------|
| 31:8 | RO   | 0x0000000   | reserved                                                                   |
| 7    | RW   | 0x0         | adc_stop_rtz<br>Turn off the RTZ function<br>1'b0: RTZ on<br>1'b1: RTZ off |

| Bit | Attr | Reset Value | Description                                                                                                                                                |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:4 | RW   | 0x2         | adc_ibctrl<br>ADC ibias control<br>3'b000: 133%<br>3'b001: 114%<br>3'b010: 100%<br>3'b011: 89%<br>3'b100: 80%<br>3'b101: 73%<br>3'b110: 67%<br>3'b111: 62% |
| 3   | RW   | 0x0         | adc_ibop3_inc<br>Increasing ibias of the 3rd integrator<br>1'b0: 100%<br>1'b1: 150%                                                                        |
| 2   | RW   | 0x0         | adc_ibop2_inc<br>Increasing ibias of the 2nd integrator<br>1'b0: 100%<br>1'b1: 200%                                                                        |
| 1:0 | RW   | 0x1         | adc_ibop1_ctrl<br>Ibias of the 1st integrator control<br>2'b00: 50%<br>2'b01: 100%<br>2'b10: 150%<br>2'b11: 200%                                           |

**Audio ADC ADC 2**

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

| Bit  | Attr | Reset Value | Description                                                                                                              |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:7 | RO   | 0x00000000  | reserved                                                                                                                 |
| 6    | RW   | 0x0         | adc_out_sel<br>ADC output data select<br>1'b0: Select SDM output as output data<br>1'b1: Select one clock as output data |
| 5    | RW   | 0x0         | adc_chop_sel<br>ADC chop frequency control<br>1'b0: High speed<br>1'b1: Low speed                                        |
| 4    | RW   | 0x0         | adc_chop_en<br>ADC chop enable<br>1'b0: Chop on<br>1'b1: Chop off                                                        |
| 3    | RW   | 0x0         | adc_eld_off<br>ADC ELD disable control<br>1'b0: ELD on<br>1'b1: ELD off                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                     |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0 | RW   | 0x2         | <p>adc_captrim<br/>Integrator cap calibration control<br/>3'b000: 80%<br/>3'b001: 90%<br/>3'b010: 100%<br/>3'b011: 110%<br/>3'b100: 120%<br/>3'b101: 130%<br/>3'b110: 140%<br/>3'b111: 150%</p> |

**Audio ADC MIC PGA\_0**

Address: Operational Base(0xFF4F8000) + offset (0x0014)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                         |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0000000   | reserved                                                                                                                                                                                                                                                                                                                                                                                            |
| 7:3  | RW   | 0x00        | <p>mic_pga_gain<br/>mic_pga output gain increase<br/>5'b00000: 0dB<br/>5'b10000: 3dB<br/>5'b10001: 6dB<br/>5'b10010: 9dB<br/>5'b10011: 12dB<br/>5'b10100: 15dB<br/>5'b10101: 18dB<br/>5'b10110: 21dB<br/>5'b10111: 24dB<br/>5'b11000: 27dB<br/>5'b11001: 30dB<br/>5'b11010: 33dB<br/>5'b11011: 36dB<br/>5'b11100: 39dB<br/>5'b11101: 42dB<br/>5'b11110: 45dB<br/>5'b11111: 48dB<br/>others: 0dB</p> |
| 2:1  | RW   | 0x0         | <p>mic_pga_input_dec<br/>mic_pga input gain decrease<br/>2'b00: -1.34dB<br/>2'b01: -4.34dB<br/>2'b10: -7.34dB<br/>2'b11: -10.34dB</p>                                                                                                                                                                                                                                                               |
| 0    | RW   | 0x1         | <p>mic_pga_pwd<br/>mic_pga and pga_buf power down<br/>1'b0: mic_pga and pga_buf enable<br/>1'b1: mic_pga and pga_buf disable</p>                                                                                                                                                                                                                                                                    |

**Audio ADC MIC PGA 1**

Address: Operational Base(0xFF4F8000) + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                                                                 |
| 3:2        | RW          | 0x0                | mic_pga_ibias_ctrl<br>mic_pga ibias ctrl<br>2'b00: 100% (default)<br>2'b01: 67%<br>2'b10: 133%<br>2'b11: 167%                            |
| 1:0        | RW          | 0x0                | mic_pga_chop_sel<br>mic_pga chop clock select<br>2'b00: No chop (default)<br>2'b01: fchop=200K<br>2'b10: fchop=400K<br>2'b11: fchop=800K |

**Audio ADC MIC PGA 2**

Address: Operational Base(0xFF4F8000) + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                                                                                       |
| 4:3        | RW          | 0x0                | pga_buf_chop_sel<br>pga_buf chop clock select<br>2'b00: No chop<br>2'b01: fchop=200K<br>2'b10: fchop=400K<br>2'b11: fchop=800K |
| 2:1        | RW          | 0x0                | pga_buf_ib_sel<br>mic_pga ibias ctrl<br>2'b00: 100%<br>2'b01: 67%<br>2'b10: 133%<br>2'b11: 167%                                |
| 0          | RW          | 0x0                | pga_buf_gain_sel<br>pga_buf gain select<br>1'b0: 0dB for differential mod<br>1'b1: 6dB for single mod                          |

**Audio ADC ADC LDO**

Address: Operational Base(0xFF4F8000) + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:8       | RO          | 0x00000000         | reserved                                                 |
| 7          | RW          | 0x0                | adc_ip_en<br>ADC enable<br>1'b0: Disable<br>1'b1: Enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------|
| 6:4        | RO          | 0x0                | reserved                                                                                                 |
| 3:2        | RW          | 0x2                | ldo_vsel<br>LDO 1P6V output voltage select<br>2'b00: 1.5V<br>2'b01: 1.55V<br>2'b10: 1.6V<br>2'b11: 1.65V |
| 1          | RW          | 0x0                | ldo_bypass_en<br>LDO_1P6V bypass mode control.<br>1'b0: Off<br>1'b1: On                                  |
| 0          | RW          | 0x0                | Reserved                                                                                                 |

**Audio ADC ADC HK\_0**

Address: Operational Base(0xFF4F8000) + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                                                       |
| 7:4        | RW          | 0x0                | hk_ibias_sel<br>hk_ibias_current control:<br>4'b0000: 100%<br>4'b0001: 80%<br>4'b0010: 66%<br>4'b0111: 36%<br>4'b1000: 200%<br>4'b1001: 160%<br>4'b1010: 133%<br>4'b1011: 114% |
| 3          | RW          | 0x0                | hk_adc_buf_en<br>adc_buf enable control<br>1'b0: Disable<br>1'b1: Enable                                                                                                       |
| 2          | RW          | 0x0                | hk_vag_buf_en<br>vag_buf enable control<br>1'b0: Disable<br>1'b1: Enable                                                                                                       |
| 1          | RW          | 0x0                | hk_half_adc_buf<br>adc_buf_bias_half enable control<br>1'b0: Disable<br>1'b1: Enable                                                                                           |
| 0          | RW          | 0x0                | hk_half_vag_buf<br>vag_buf_bias_half enable control<br>1'b0: Disable<br>1'b1: Enable                                                                                           |

**Audio ADC ADC HK 1**

Address: Operational Base(0xFF4F8000) + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                                                                      |
| 3:2        | RW          | 0x0                | hk_vag_cur_sel<br>hk_vag_buf_cur_sel control<br>2'b00: 6uA<br>2'b01: 4uA<br>2'b10: 3uA<br>2'b11: 1uA                                          |
| 1:0        | RW          | 0x0                | hk_vref_1p2v_sel<br>hk_vref_1p2v_sel<1:0><br>2'b00: normal (default=1.2)<br>2'b01: normal - 10m<br>2'b10: normal + 10m<br>2'b11: normal - 20m |

**Audio ADC DIG CLKEN**

Address: Operational Base(0xFF4F8000) + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x00000000         | reserved                                                                                               |
| 7          | RW          | 0x0                | adc_cke<br>ADC clock enable.<br>1'b0: Disable<br>1'b1: Enable                                          |
| 6          | RW          | 0x0                | i2stx_cke<br>Clock enable of internal I2S TX channel.<br>1'b0: Disable<br>1'b1: Enable                 |
| 5          | RW          | 0x0                | adc_en<br>ADC channel enable.<br>1'b0: Disable<br>1'b1: Enable                                         |
| 4          | RW          | 0x0                | i2stx_en<br>I2S TX channel enable.<br>1'b0: Disable<br>1'b1: Enable                                    |
| 3          | RW          | 0x0                | srst<br>Soft reset, write 1 to reset all registers to default value.<br>1'b0: Not reset<br>1'b1: Reset |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0        | RW          | 0x0                | <p>adcsrt<br/>Selects which kind of sample rate.<br/>3'b000: 12kHz/11.025kHz/8kHz<br/>3'b001: 24kHz/22.05kHz/16kHz<br/>3'b010: 48kHz/44.1kHz/32kHz<br/>3'b011: 96kHz/88.2kHz/64kHz<br/>3'b100~3'b111: 192kHz/176.4kHz/128kHz</p> |

**Audio ADC VOL CTL**

Address: Operational Base(0xFF4F8000) + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                                                                      |
| 7:0        | RW          | 0x00               | <p>adc_volume<br/>ADC path Digital Volume Register.<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</p> |

**Audio ADC ADC AGC0**

Address: Operational Base(0xFF4F8000) + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7:4        | RW          | 0x0                | <p>adc_agc_offset<br/>LSB 4bits of adc_agc_offset;<br/>adc_agc_offset: Adjust calculated received signal power in dB, it is represented by two's complement with 1 sign bit, 4 integer bits, 4 fractional bits.<br/>9'h000: 0 dB<br/>9'h001: 0.0625 dB<br/>9'h002: 0.125 dB<br/>9'h003: 0.1875 dB<br/>9'h004: 0.25 dB<br/>...<br/>9'h0FF: 15.9375 dB<br/>9'h100: -16 dB<br/>9'h101: -15.9375 dB<br/>9'h102: -15.875 dB<br/>...<br/>9'h1FF: -0.0625 dB</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | adc_byps<br>ADC volume control bypass.<br>1'b0: ADC volume control enable<br>1'b1: ADC volume control bypass |
| 2          | RW          | 0x0                | agc_zerocren<br>Gain adjusting at zero-crossing enable.<br>1'b0: Disable<br>1'b1: Enable                     |
| 1          | RW          | 0x1                | adc_ng_mode_en<br>Noise gate enable.<br>1'b0: Disable<br>1'b1: Enable                                        |
| 0          | RW          | 0x0                | adc_agc_ena<br>Automatic Gain control enable.<br>1'b0: Disable<br>1'b1: Enable                               |

### **Audio ADC ADC AGC1**

Address: Operational Base(0xFF4F8000) + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 4:0        | RW          | 0x00               | adc_agc_offset<br>MSB 5bits of adc_agc_offset;<br>adc_agc_offset: Adjust calculated received signal power in dB, it is represented by two's complement with 1 sign bit, 4 integer bits, 4 fractional bits.<br>9'h000: 0 dB<br>9'h001: 0.0625 dB<br>9'h002: 0.125 dB<br>9'h003: 0.1875 dB<br>9'h004: 0.25 dB<br>...<br>9'h0FF: 15.9375 dB<br>9'h100: -16 dB<br>9'h101: -15.9375 dB<br>9'h102: -15.875 dB<br>...<br>9'h1FF: -0.0625 dB |

### **Audio ADC ADC AGC2**

Address: Operational Base(0xFF4F8000) + offset (0x003C)

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

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                   |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | RW   | 0x70        | <p>adc_ng_rssi_db<br/>LSB 8bits of adc_ng_rssi_db;<br/>adc_ng_rssi_db: noise gate threshold in dB, it is represented by two's complement with 1 sign bit, 7 integer bits, 3 fractional bits.</p> <p>11'h000: 0 dB<br/>11'h001: 0.125 dB<br/>11'h002: 0.25 dB<br/>...<br/>11'h400: -128 dB<br/>11'h401: -127.875 dB<br/>11'h402: -127.75 dB<br/>...<br/>11'h7FF: -0.125 dB</p> |

**Audio ADC ADC AGC3**

Address: Operational Base(0xFF4F8000) + offset (0x0040)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x000000    | reserved                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 7:3  | RW   | 0x00        | <p>adc_ng_pga_gain<br/>Analog ADC PGA gain configure when in noise gate mode.</p> <p>5'b00000: 0dB<br/>5'b10000: 3dB<br/>5'b10001: 6dB<br/>5'b10010: 9dB<br/>5'b10011: 12dB<br/>5'b10100: 15dB<br/>5'b10101: 18dB<br/>5'b10110: 21dB<br/>5'b10111: 24dB<br/>5'b11000: 27dB<br/>5'b11001: 30dB<br/>5'b11010: 33dB<br/>5'b11011: 36dB<br/>5'b11100: 39dB<br/>5'b11101: 42dB<br/>5'b11110: 45dB<br/>5'b11111: 48dB<br/>others: 0dB</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0        | RW          | 0x6                | <p>adc_ng_rssi_db<br/> MSB 3bits of adc_ng_rssi_db;<br/> adc_ng_rssi_db: noise gate threshold in dB, it is represented by two's complement with 1 sign bit, 7 integer bits, 3 fractional bits.</p> <p>11'h000: 0 dB<br/> 11'h001: 0.125 dB<br/> 11'h002: 0.25 dB<br/> ...<br/> 11'h400: -128 dB<br/> 11'h401: -127.875 dB<br/> 11'h402: -127.75 dB<br/> ...<br/> 11'h7FF: -0.125 dB</p> |

**Audio ADC ADC AGC4**

Address: Operational Base(0xFF4F8000) + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                                                                                                                                                                                                                                                          |
| 7:0        | RW          | 0x60               | <p>adc_tar_db<br/> LSB 8bits of adc_tar_db;<br/> adc_tar_db: target output signal power in dB, it is represented by two's complement with 1 sign bit, 7 integer bits, 3 fractional bits.</p> <p>11'h000: 0 dB<br/> 11'h001: 0.125 dB<br/> 11'h002: 0.25 dB<br/> ...<br/> 11'h400: -128 dB<br/> 11'h401: -127.875 dB<br/> 11'h402: -127.75 dB<br/> ...<br/> 11'h7FF: -0.125 dB</p> |

**Audio ADC ADC AGC5**

Address: Operational Base(0xFF4F8000) + offset (0x0048)

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

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:3 | RW   | 0x00        | <p>adc_ini_pga_gain<br/> Initial Analog ADC PGA gain configure when AGC enable.<br/> 5'b00000: 0dB<br/> 5'b10000: 3dB<br/> 5'b10001: 6dB<br/> 5'b10010: 9dB<br/> 5'b10011: 12dB<br/> 5'b10100: 15dB<br/> 5'b10101: 18dB<br/> 5'b10110: 21dB<br/> 5'b10111: 24dB<br/> 5'b11000: 27dB<br/> 5'b11001: 30dB<br/> 5'b11010: 33dB<br/> 5'b11011: 36dB<br/> 5'b11100: 39dB<br/> 5'b11101: 42dB<br/> 5'b11110: 45dB<br/> 5'b11111: 48dB<br/> others: 0dB</p> |
| 2:0 | RW   | 0x7         | <p>adc_tar_db<br/> MSB 3bits of adc_tar_db;<br/> adc_tar_db: target output signal power in dB, it is represented by two's complement with 1 sign bit, 7 integer bits, 3 fractional bits.<br/> 11'h000: 0 dB<br/> 11'h001: 0.125 dB<br/> 11'h002: 0.25 dB<br/> ...<br/> 11'h400: -128 dB<br/> 11'h401: -127.875 dB<br/> 11'h402: -127.75 dB<br/> ...<br/> 11'h7FF: -0.125 dB</p>                                                                      |

**Audio ADC ADC AGC6**

Address: Operational Base(0xFF4F8000) + offset (0x004C)

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:8 | RO   | 0x000000    | reserved    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0        | RW          | 0x5a               | <p>adc_ng_vol_ctrl<br/>Digital volume configure when in noise gate mode.<br/>0dB~ -96dB, -0.375dB/step.</p> <p>8'h0: 0dB<br/>8'h1: -0.375dB<br/>8'h2: -0.75dB<br/>8'h3: -1.125dB<br/>...<br/>8'hff: -95.625dB</p> |

**Audio ADC ADC AGC7**

Address: Operational Base(0xFF4F8000) + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                                                                                           |
| 7:0        | RW          | 0x04               | <p>adc_ini_vol_ctrl<br/>Initial Digital volume configure when AGC enable.<br/>0dB~ -96dB, -0.375dB/step.</p> <p>8'h0: 0dB<br/>8'h1: -0.375dB<br/>8'h2: -0.75dB<br/>8'h3: -1.125dB<br/>...<br/>8'hff: -95.625dB</p> |

**Audio ADC ADC AGC8**

Address: Operational Base(0xFF4F8000) + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                    |
| 7:4        | RW          | 0x6                | adc_pratrate_win<br>Attack/release rate = $2^{\text{adc\_pratrate\_win}}$ . |
| 3:0        | RW          | 0x6                | adc_powdet_win<br>AGC power detect length = $2^{\text{adc\_powdet\_win}}$ . |

**Audio ADC ADC STATUS0**

Address: Operational Base(0xFF4F8000) + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>             |
|------------|-------------|--------------------|--------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                       |
| 7:0        | RO          | 0x00               | adclrv<br>ADC internal volume. |

**Audio ADC ADC STATUS1**

Address: Operational Base(0xFF4F8000) + offset (0x005C)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------|
| 5          | RO          | 0x0                | adc_ngvalid<br>Noise gates valid status.<br>1'b0: Not in NG status<br>1'b1: Now in NG status |
| 4:0        | RO          | 0x00               | adc_pga_gain_r<br>Gain of ADC PGA block.                                                     |

**Audio ADC ADC FILTER**

Address: Operational Base(0xFF4F8000) + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                          |
| 7:6        | RW          | 0x0                | hpfcf<br>HPF Cut Frequency Select.<br>2'b00: 3.79HZ<br>2'b01: 60HZ<br>2'b10: 243HZ<br>2'b11: 493HZ                                |
| 5          | RO          | 0x0                | reserved                                                                                                                          |
| 4          | RW          | 0x0                | hpfl<br>Digital ADC High Pass Filter Enable.<br>1'b0: Disable<br>1'b1: Enable                                                     |
| 3:2        | RW          | 0x2                | ciccomp_cf<br>CIC Compensation Filter Output Scale Coefficient.<br>2'h0: 3/8<br>2'h1: 6/8<br>2'h2,2'h3: 1                         |
| 1          | RW          | 0x1                | ciccomp_ena64<br>CIC compensation filter enable, valid when sample rate is 24kHz/22.05kHz/16kHz.<br>1'b0: Disable<br>1'b1: Enable |
| 0          | RW          | 0x1                | ciccomp_ena32<br>CIC compensation filter enable, valid when sample rate is 48kHz/44.1kHz/32kHz.<br>1'b0: Disable<br>1'b1: Enable  |

**Audio ADC I2S CKM**

Address: Operational Base(0xFF4F8000) + offset (0x0064)

| <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:4        | RW          | 0x0                | sck_div<br>Integer clock divider to generate sclk when I2S TX works in master mode. It is ignored when in slave mode.<br>sck_div = F(mclk2x)/F(sclk) - 1 |
| 3          | RO          | 0x0                | reserved                                                                                                                                                 |
| 2          | RW          | 0x0                | sck_en<br>SCLK clock enable, active in master mode.<br>1'b0: Disable<br>1'b1: Enable                                                                     |
| 1          | RW          | 0x0                | sck_p<br>SCLK polarity.<br>1'b0: Normal<br>1'b1: Inverted                                                                                                |
| 0          | RW          | 0x1                | i2s_mst<br>I2S TX acts as master or slave.<br>1'b0: Slave mode<br>1'b1: Master mode                                                                      |

### **Audio ADC I2S TXCR0**

Address: Operational Base(0xFF4F8000) + offset (0x0068)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                                                                                                                                                                                                       |
| 7:3        | RW          | 0x17               | vdw_tx<br>I2S TX valid data width.<br>5'b00000-5'b01110: reserved<br>5'b01111: 16bit<br>5'b10000: 17bit<br>5'b10001: 18bit<br>5'b10010: 19bit<br>...<br>5'10111: 24bit<br>5'b10111: 25bit<br>5'b10111: 26bit<br>5'b10111: 27bit<br>5'b10111: 28bit<br>5'b10111: 29bit<br>5'b10111: 30bit<br>5'b10111: 31bit<br>5'b10111: 32bit |
| 2:1        | RW          | 0x0                | sckd_tx<br>Sclk divider for tx_lrck generator.<br>2'b00: 64<br>2'b01: 128<br>2'b10~2'b11: 256<br>2'b01 valid only if LRCK <= 96k, 2'b10 valid only if LRCK <= 48k                                                                                                                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------|
| 0          | RW          | 0x0                | txrl_p<br>I2S TX LRCK polarity.<br>1'b0: Normal<br>1'b1: Inverted |

**Audio ADC I2S TXCR1**

Address: Operational Base(0xFF4F8000) + offset (0x006C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x00000000         | reserved                                                                                                                              |
| 6          | RW          | 0x0                | tfs_tx<br>I2S TX transfer mode.<br>1'b0: I2S<br>1'b1: PCM                                                                             |
| 5:4        | RW          | 0x0                | pbm_tx<br>I2S TX PCM bus mode.<br>2'b00: PCM early mode<br>2'b01: PCM late 1 mode<br>2'b10: PCM late 2 mode<br>2'b11: PCM late 3 mode |
| 3:2        | RW          | 0x0                | ibm_tx<br>I2S TX bus mode.<br>2'b00: Normal<br>2'b01: Left<br>2'b10: Right                                                            |
| 1          | RW          | 0x0                | exrl_tx<br>Exchange right/left channel for I2S TX<br>1'b0: Normal<br>1'b1: Exchange right and left channel                            |
| 0          | RW          | 0x0                | lsb_tx<br>I2S TX MSB/LSB send first.<br>1'b0: MSB send first<br>1'b1: LSB send first                                                  |

**Audio ADC I2S TXCMD**

Address: Operational Base(0xFF4F8000) + offset (0x0070)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                                          |
| 7          | RW          | 0x0                | txs<br>I2S TX transfer start.<br>1'b0: Stop I2S TX transfer<br>1'b1: Start I2S TX transfer                                                                        |
| 6          | RW          | 0x0                | txc<br>This is a self-cleared bit. Write 1 to clear all I2S TX transmit logic.<br>1'b0: No clean the I2STX transmit logic<br>1'b1: Clean the I2STX transmit logic |

| Bit | Attr | Reset Value | Description                                                                 |
|-----|------|-------------|-----------------------------------------------------------------------------|
| 5:0 | RW   | 0x00        | rcnt_tx<br>Right justified counter for I2S right justified slave mode only. |

## 22.5 Application Notes

### 22.5.1 Hardware Application Notes:

1. Put the LDO filter cap close to the output Pin of ADC\_LDO.
2. Give a Clean ground to the LDO filter cap and AVSS.

### 22.5.2 Software Application Notes

Steps to configure Audio ADC operates in I2S mode are as follows.

1. Program Audio\_ADC\_ADC\_LDO to power up the HK circuit and LDO circuit.
2. Program the gain of PGA\_Block and PGA\_Buffer by Audio\_ADC\_MIC\_PGA\_0, Audio\_ADC\_MIC\_PGA\_1, Audio\_ADC\_MIC\_PGA\_2.
3. Program Audio\_ADC\_DIG\_CLKEN to enable operation clocks of I2S module and ADC.
4. Program Audio\_ADC\_I2S\_CKM to select sample rate.
5. Program Audio\_ADC\_ADC\_0 to power up the analog ADC circuit.
6. Enable high pass filter if necessary by Programming Audio\_ADC\_ADC\_FILTER.

## Chapter 23 Serial Audio Interface (SAI)

### 23.1 Overview

The SAI controller is designed for interfacing between the AHB bus and the serial audio interface bus. The SAI is a serial link for digital audio data transfer between devices in the system. The SAI interface (Serial Audio Interface) offers a wide set of audio protocols due to its flexibility and wide range of configurations. Many stereo or mono audio applications may be targeted. I2S standards, PCM, and TDM may be addressed.

SAI is widely used in the devices such as ADC, DAC, DSP, CPU, etc. With the SAI interface, we can connect audio devices and the embedded SoC platform together and provide an audio interface solution for the system.

#### 23.1.1 Features

- Support eight internal 32-bit wide and 32-location deep FIFOs, four for transmitting and the other for receiving audio data
- Support AHB bus interface
- Support 8 ~ 32 bits audio data transfer
- Support master and slave mode
- Support DMA handshaking interface and configurable DMA water level
- Support transmit FIFO empty, underflow, receive FIFO full, overflow interrupt and all interrupts can be masked
- Support configurable water level of transmit FIFO empty and receive FIFO full interrupt
- Support combined interrupt output
- Support 8 to 32 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 and support four 8-bit audio data store together in one 32-bit wide location
- Support TX to RX loopback bypass mode
- Support audio protocol: I2S, PCM, TDM
- Support number of bits by frame can be configurable
- Support first active slot position in the frame is configurable
- Support up to 128 slots available with configurable size
- Support slot length 8 to 32 bits configurable
- Support slot valid data length 8 to 32 bits configurable
- Support mono audio mode
- Support slot mask configurable
- Support first active bit position in the slot is configurable
- Support MSB or LSB first serial audio data transfer
- Support configurable SCLK and FS polarity
- Support up to four lanes parallel transceivers
- Support SDI, SDO IOMUX

### 23.2 Block Diagram



Fig. 23-1 SAI Block Diagram

## System Interface

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

## Clock Generator

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

## Transmitters

The Transmitters implement transmission operation. The transmitters can act as either a master or a slave, with I2S, PCM or TDM mode surround serial audio interface.

## Receiver

The Receiver implements receive operation. The receiver can act as either a master or a slave, with I2S, PCM or TDM mode stereo serial audio interface.

## Transmit FIFO

The Transmit FIFO is the buffer to store transmitted audio data. The size of the FIFO is 32bits x 32.

## Receive FIFO

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

## IO\_BUFF

SDO, SDI, LRCK\_IN and LRCK\_OUT register output.

## 23.3 Function Description

In the SAI controller, there are two types:

transmitter-master & receiver-master, transmitter-slave & receiver-slave.

In broadcasting application, the SAI controller is used as a transmitter and external or internal audio CODEC is used as a receiver. In recording application, the SAI controller is used as a receiver and external or internal audio CODEC is used as a transmitter. Either the SAI controller or the audio CODEC can act as a master or a slave, but if one is master, the other must be slave.



Fig.23-2 SAI 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 FS 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 FS signals. CPU should know when the receiver to initialize a transaction and when the transmitter to send data.

When the receiver acts as a master, it sends SCLK and FS 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 SAI register. These includes CPU settings, SAI interface registers settings, and maybe the embedded SoC platform settings. These registers must be set before starting data transfer.

The SAI interface offers a wide set of audio protocols due to its flexibility and wide range of configurations. It can support I2S/PCM/TDM audio protocol by different configuration.

### 23.3.1 I2S normal mode

This is the waveform of I2S normal mode. For FS (sai\_fs\_rx/sai\_fs\_tx) signal, it goes low to

indicate left channel and high to right channel. For SD (sai\_sdo, sai\_sdi) signal, it starts sending the first bit (MSB or LSB) one SCLK clock cycle after FS changes. The range of SD signal width is from 8 to 32bits.



Fig.23-3 I2S Normal Mode Timing Format

### 23.3.2 I2S left justified mode

This is the waveform of I2S left justified mode. For FS (sai\_fs\_rx / sai\_fs\_tx) signal, it goes high to indicate left channel and low to right channel. For SD (sai\_sdo/ sai\_sdi) signal, it starts sending the first bit (MSB or LSB) at the same time when FS changes. The range of SD signal width is from 8 to 32bits.



Fig.23-4 I2S Left Justified Mode Timing Format

### 23.3.3 I2S right justified mode

This is the waveform of I2S right justified mode. For FS (sai\_fs\_rx / sai\_fs\_tx) signal, it goes high to indicate left channel and low to right channel. For SD (sai\_sdo, sai\_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 FS signal while one bit is transferred at one SCLK cycle. The range of SD signal width is from 8 to 32bits.



Fig.23-5 I2S Right Justified Mode Timing Format

### 23.3.4 PCM early mode

This is the waveform of PCM early mode. For FS (sai\_fs\_rx / sai\_fs\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (sai\_sdo, sai\_sdi) signal, it sends the first bit (MSB or LSB) at the same time when FS goes high. The range of SD signal width is from 8 to 32bits.



Fig.23-6 PCM Early Mode Timing Format

### 23.3.5 Flexibility and wide range of configurations

The SAI interface offers a wide set of audio protocols due to its flexibility and wide range of configurations. Many stereo or mono audio applications may be targeted. I2S standards, PCM, and TDM may be addressed.

This is the waveform of PCM mode (SBW==VDW,FW >=SBW \*SNB). For FS (sai\_fs\_rx / sai\_fs\_tx) signal, it goes high to indicate the start of a group of audio data.



Fig.23-7 SAI PCM mode timing format

This is the waveform of I2S left mode(SBW>=VDW,FW >=SBW \*SNB,VDJ==1'b1).



Fig.23-8 SAI I2S left mode timing format

This is the waveform of I2S right mode(SBW>=VDW,FW >=SBW \*SNB,VDJ==1'b0).



Fig.23-9 SAI I2S right mode timing format

This is the waveform of FS and SD delay time, as the posedge of FS (sai\_fs\_rx / sai\_fs\_tx) signal, we can send data at different time, The time between the FS rise edge and the first valid bit can be configured using the fs\_shift register, when fs\_shift[0] == 1'b0, data send at posedge of sclk,when fs\_shift[0] == 1'b1, data send at negedge of sclk.



Fig.23-10 fs shift timing format

## 23.4 Register Description

### 23.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

#### Operational Base

| Name | Base Address |
|------|--------------|
| SAI0 | 0xFF300000   |
| SAI1 | 0xFF310000   |
| SAI2 | 0xFF498000   |
| SAI3 | 0xFF4A0000   |

| Name | Base Address |
|------|--------------|
| SAI4 | 0xFF4A8000   |

### 23.4.2 Registers Summary

| Name              | Offset | Size | Reset Value | Description                                    |
|-------------------|--------|------|-------------|------------------------------------------------|
| SAI_TXCR          | 0x0000 | W    | 0x00000FFF  | Transmit Operation Control Register            |
| SAI_FSCR          | 0x0004 | W    | 0x0001F03F  | Transmit Frame Sync Operation Control Register |
| SAI_RXCR          | 0x0008 | W    | 0x00000FFF  | Receive Operation Control Register             |
| SAI_MONO_CR       | 0x000C | W    | 0x00000000  | Mono mode control                              |
| SAI_XFER          | 0x0010 | W    | 0x00000000  | Transfer Start Register                        |
| SAI_CLR           | 0x0014 | W    | 0x00000000  | Sclk Domain Logic Clear Register               |
| SAI_CKR           | 0x0018 | W    | 0x00000000  | Clock Generation Register                      |
| SAI_TXFIFOLR      | 0x001C | W    | 0x00000000  | TX FIFO Level Register                         |
| SAI_RXFIFOLR      | 0x0020 | W    | 0x00000000  | RX FIFO Level Register                         |
| SAI_DMACR         | 0x0024 | W    | 0x00000000  | DMA Control Register                           |
| SAI_INTCR         | 0x0028 | W    | 0x01F00000  | Interrupt Control Register                     |
| SAI_INTSR         | 0x002C | W    | 0x00000000  | Interrupt Status Register                      |
| SAI_TXDR          | 0x0030 | W    | 0x00000000  | Transmit FIFO Data Register                    |
| SAI_RXDR          | 0x0034 | W    | 0x00000000  | Receive FIFO Data Register                     |
| SAI_PATH_SEL      | 0x0038 | W    | 0x0000E4E4  | Path Select Register                           |
| SAI_TX_SLOT_MASK0 | 0x003C | W    | 0x00000000  | Transmit Slot 0~31 Mask State                  |
| SAI_TX_SLOT_MASK1 | 0x0040 | W    | 0x00000000  | Transmit Slot 32~63 Mask State                 |
| SAI_TX_SLOT_MASK2 | 0x0044 | W    | 0x00000000  | Transmit Slot 64~95 Mask State                 |
| SAI_TX_SLOT_MASK3 | 0x0048 | W    | 0x00000000  | Transmit Slot 96~127 Mask State                |
| SAI_RX_SLOT_MASK0 | 0x004C | W    | 0x00000000  | Receive Slot 0~31 Mask State                   |
| SAI_RX_SLOT_MASK1 | 0x0050 | W    | 0x00000000  | Receive Slot 32~63 Mask State                  |
| SAI_RX_SLOT_MASK2 | 0x0054 | W    | 0x00000000  | Receive Slot 64~95 Mask State                  |
| SAI_RX_SLOT_MASK3 | 0x0058 | W    | 0x00000000  | Receive Slot 96~127 Mask State                 |
| SAI_TX_DATA_CNT   | 0x005C | W    | 0x00000000  | Tx Data Counter Register                       |
| SAI_RX_DATA_CNT   | 0x0060 | W    | 0x00000000  | Rx Data Counter Register                       |
| SAI_SAI_TX_SHIFT  | 0x0064 | W    | 0x00000000  | Tx Shift Register                              |
| SAI_SAI_RX_SHIFT  | 0x0068 | W    | 0x00000000  | Rx Shift Register                              |
| SAI_SAI_RD_STATUS | 0x006C | W    | 0x0000000F  |                                                |
| SAI_VERSION       | 0x0070 | W    | 0x24013506  | Version Register                               |

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

### 23.4.3 Detail Registers Description

#### SAI TXCR

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                                             |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:23 | RO   | 0x000       | reserved                                                                                                                                                                |
| 22    | RW   | 0x0         | tx_delay_en<br>1'b0: NO DELAY<br>1'b1: DELAY fsync pos                                                                                                                  |
| 21:20 | RW   | 0x0         | tcsr<br>Transmit channel select register<br>2'b00: One channel parallel<br>2'b01: Two channel parallel<br>2'b10: Three channel parallel<br>2'b11: Four channel parallel |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19         | RW          | 0x0                | <p>sjm<br/>Store justified mode<br/>(Can be written only when XFER[0] bit is 0.)<br/>8bit~31bit DATA stored in 32 bits width FIFO.<br/>1'b0: Right justified<br/>1'b1: Left justified</p>                                                                            |
| 18         | RW          | 0x0                | <p>fbm<br/>first bit mode<br/>(Can be written only when XFER[0] bit is 0.)<br/>1'b0: MSB<br/>1'b1: LSB</p>                                                                                                                                                           |
| 17:11      | RW          | 0x01               | <p>snb<br/>Transfer slot number<br/>(Can be written only when XFER[0] bit is 0.)<br/>Number of slots in a frame<br/>7'h00: 1slot<br/>7'h01: 2slot<br/>7'h02: 3slot<br/>7'h03: 4slot<br/>.....<br/>7'h7e: 127slot<br/>7'h7f: 128slot</p>                              |
| 10         | RW          | 0x1                | <p>vdj<br/>Valid data justified mode<br/>(Can be written only when XFER[0] bit is 0.)<br/>1'b0: Right justified<br/>1'b1: Left justified</p>                                                                                                                         |
| 9:5        | RW          | 0x1f               | <p>sbw<br/>Transfer slot bits width<br/>(Can be written only when XFER[0] bit is 0.)<br/>5'h00~5'b0e: Reserved<br/>5'h0f: 16bit<br/>5'h10: 17bit<br/>5'h11: 18bit<br/>5'h12: 19bit<br/>.....<br/>5'h1c: 29bit<br/>5'h1d: 30bit<br/>5'h1e: 31bit<br/>5'h1f: 32bit</p> |
| 4:0        | RW          | 0x1f               | <p>vdw<br/>Slot valid data width<br/>(Can be written only when XFER[0] bit is 0.)<br/>5'h00~5'b0e: Reserved<br/>5'h0f: 16bit<br/>5'h10: 17bit<br/>5'h11: 18bit<br/>5'h12: 19bit<br/>.....<br/>5'h1c: 29bit<br/>5'h1d: 30bit<br/>5'h1e: 31bit<br/>5'h1f: 32bit</p>    |

**SAI FSCR**Address: **Operational Base** + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25      | RO          | 0x00               | reserved                                                                                                                                                                               |
| 24         | RW          | 0x0                | edge_sel<br>1'h0: pos<br>1'h1: pos and neg                                                                                                                                             |
| 23:12      | RW          | 0x01f              | fpw<br>Transfer frame pulse width<br>(Can be written only when XFER[0] is 0.)<br>12'h000: 1bit<br>12'h001: 2bit<br>12'h002: 3bit<br>.....<br>12'hffe: 4095bit<br>12'hfff: res          |
| 11:0       | RW          | 0x03f              | fw<br>Transfer frame width<br>(Can be written only when XFER[0] is 0.)<br>12'h000~12'h006: Reserved<br>12'h007: 8bit<br>12'h008: 9bit<br>.....<br>12'hffe: 4095bit<br>12'hfff: 4096bit |

**SAI\_RXCR**

Address: **Operational Base** + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:23      | RO          | 0x000              | reserved                                                                                                                                                                      |
| 22         | RW          | 0x0                | rx_delay_en<br>1'b0: NO DELAY<br>1'b1: DELAY fsync pos                                                                                                                        |
| 21:20      | RW          | 0x0                | rCSR<br>receive channel select register<br>2'b00: One channel parallel<br>2'b01: Two channel parallel<br>2'b10: Three channel parallel<br>2'b11: Four channel parallel        |
| 19         | RW          | 0x0                | sjm<br>Store justified mode<br>(Can be written only when XFER[2] bit is 0.)<br>8bit~31bit DATA stored in 32 bits width FIFO.<br>1'b0: Right justified<br>1'b1: Left justified |
| 18         | RW          | 0x0                | fbm<br>first bit mode<br>(Can be written only when XFER[2] bit is 0.)<br>1'b0: MSB<br>1'b1: LSB                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17:11      | RW          | 0x01               | <p>snb<br/>receive slot number<br/>(Can be written only when XFER[2] bit is 0.)<br/>number of slots in a frame<br/>7'h00: 1slot<br/>7'h01: 2slot<br/>7'h02: 3slot<br/>7'h03: 4slot<br/>.....<br/>7'h7e: 127slot<br/>7'h7f: 128slot</p>                              |
| 10         | RW          | 0x1                | <p>vdj<br/>Valid data justified mode<br/>(Can be written only when XFER[2] bit is 0.)<br/>1'b0: Right justified<br/>1'b1: Left justified</p>                                                                                                                        |
| 9:5        | RW          | 0x1f               | <p>sbw<br/>receive slot bits width<br/>(Can be written only when XFER[2] bit is 0.)<br/>5'h00~5'b0e: Reserved<br/>5'h0f: 16bit<br/>5'h10: 17bit<br/>5'h11: 18bit<br/>5'h12: 19bit<br/>.....<br/>5'h1c: 29bit<br/>5'h1d: 30bit<br/>5'h1e: 31bit<br/>5'h1f: 32bit</p> |
| 4:0        | RW          | 0x1f               | <p>vdw<br/>Valid data width<br/>(Can be written only when XFER[2] bit is 0.)<br/>5'h00~5'b0e: Reserved<br/>5'h0f: 16bit<br/>5'h10: 17bit<br/>5'h11: 18bit<br/>5'h12: 19bit<br/>.....<br/>5'h1c: 29bit<br/>5'h1d: 30bit<br/>5'h1e: 31bit<br/>5'h1f: 32bit</p>        |

**SAI MONO CR**Address: **Operational Base** + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9       | RO          | 0x000000           | reserved                                                                                                                                                                        |
| 8:2        | RW          | 0x00               | <p>rx_mono_slot_sel<br/>Receive mono mode valid slot data select<br/>7'h00: First slot data valid<br/>7'h01: Second slot data valid<br/>.....<br/>7'h7f: Slot128 data valid</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | rx_mono_en<br>Receive mono audio data enable bit<br>1'b0: Normal mode<br>1'b1: Mono mode  |
| 0          | RW          | 0x0                | tx_mono_en<br>Transmit mono audio data enable bit<br>1'b0: Normal mode<br>1'b1: Mono mode |

**SAI\_XFER**Address: **Operational Base** + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                 |
| 5          | RW          | 0x0                | rx_data_cnt_en<br>1'b0: Stop cnt<br>1'b1: Start cnt      |
| 4          | RW          | 0x0                | tx_data_cnt_en<br>1'b0: Stop cnt<br>1'b1: Start cnt      |
| 3          | RW          | 0x0                | rxs<br>1'b0: Stop RX transfer<br>1'b1: Start RX transfer |
| 2          | RW          | 0x0                | txs<br>1'b0: Stop TX transfer<br>1'b1: Start TX transfer |
| 1          | RW          | 0x0                | fss<br>1'b0: Stop frame sync<br>1'b1: Start frame sync   |
| 0          | RW          | 0x0                | clk_gate_en<br>1'b0: Stop clk<br>1'b1: Start clk         |

**SAI\_CLR**Address: **Operational Base** + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                                                  |
| 2          | W1<br>C     | 0x0                | fsc<br>This is a self-cleared bit. write 1 to clear all receive logic.                    |
| 1          | W1<br>C     | 0x0                | rxc<br>RX logic clear<br>This is a self-cleared bit. write 1 to clear all receive logic.  |
| 0          | W1<br>C     | 0x0                | txc<br>TX logic clear<br>This is a self-cleared bit. write 1 to clear all transmit logic. |

**SAI\_CKR**Address: **Operational Base** + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15      | RO          | 0x00000            | reserved                                                                                                                                                          |
| 14:3       | RW          | 0x000              | mdiv<br>(Can be written only when 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. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | mss<br>Transmit master/slave mode select<br>(Can be written only when XFER[0] bit is 0.)<br>1'b0: Master mode(sclk output)<br>1'b1: Slave mode(sclk input)                                                                       |
| 1          | RW          | 0x0                | ckp<br>Transmit sclk polarity<br>(Can be written only when XFER[2] 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 |
| 0          | RW          | 0x0                | fsp<br>Transmit fs polarity<br>(Can be written only when XFER[2] or XFER[0] bit is 0.)<br>1'b0: Frame sync low active<br>1'b1: Frame sync high active                                                                            |

**SAI TXFIFOLR**Address: **Operational Base** + offset (0x001C)

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

**SAI RXFIFOLR**Address: **Operational Base** + offset (0x0020)

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

**SAI DMACR**Address: **Operational Base** + offset (0x0024)

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

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

**SAI\_INTCR**Address: **Operational Base** + offset (0x0028)

| <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                | rfie<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          | W1<br>C     | 0x0                | txuic<br>TX underrun interrupt clear<br>Write 1 to clear TX underrun interrupt.                                                                                        |

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

#### **SAI\_INTSR**

Address: **Operational Base** + offset (0x002C)

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

#### **SAI\_TXDR**

Address: **Operational Base** + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | txdr<br>Transmit fifo fata register<br>When it is written, data are moved into the transmit fifo. |

#### **SAI\_RXDR**

Address: **Operational Base** + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | rxdr<br>Receive fifo data register<br>When the register is read, data in the receive fifo is accessed. |

#### **SAI\_PATH\_SEL**

Address: **Operational Base** + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                    |
| 29:22      | RW          | 0x00               | sdo_to_sdi_path_sel<br>SDO_TO_SD <sub>I</sub> _PATH_SEL<br>[23:22]:sdi0 sel sdo0 or sdo1 or sdo2 or sdo3<br>[25:24]:sdi1 sel sdo0 or sdo1 or sdo2 or sdo3<br>[27:26]:sdi2 sel sdo0 or sdo1 or sdo2 or sdo3<br>[29:28]:sdi3 sel sdo0 or sdo1 or sdo2 or sdo3 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21:18      | RW          | 0x0                | loopback_bypass<br>Loopback by pass enable bit<br>Tx_sdo -> Rx_sdi<br>loopback mode should work at fs_tx_as_common mode and<br>tx=rx=master<br>[18]:Loopback_en0<br>[19]:Loopback_en1<br>[20]:Loopback_en2<br>[21]:Loopback_en3<br>1'b0: No active<br>1'b1: Active |
| 17         | RW          | 0x0                | sync_out_sel<br>Tx sync out select bit<br>1'b0: Tx sclk and fs sync out use out signal<br>1'b1: Tx sclk and fs sync out use in signal                                                                                                                              |
| 16         | RW          | 0x0                | sync_in_sel<br>Tx sync in select bit<br>1'b0: Tx sclk and fs use pad signal<br>1'b1: Tx sclk and fs use sync input port                                                                                                                                            |
| 15:14      | RW          | 0x3                | rx_path_select3<br>Rx path select<br>2'b00: Path3 data from sdi0<br>2'b01: Path3 data from sdi1<br>2'b10: Path3 data from sdi2<br>2'b11: Path3 data from sdi3                                                                                                      |
| 13:12      | RW          | 0x2                | rx_path_select2<br>Rx path select<br>2'b00: Path2 data from sdi0<br>2'b01: Path2 data from sdi1<br>2'b10: Path2 data from sdi2<br>2'b11: Path2 data from sdi3                                                                                                      |
| 11:10      | RW          | 0x1                | rx_path_select1<br>Rx path select<br>2'b00: Path0 data from sdi0<br>2'b01: Path0 data from sdi1<br>2'b10: Path0 data from sdi2<br>2'b11: Path0 data from sdi3                                                                                                      |
| 9:8        | RW          | 0x0                | rx_path_select0<br>Rx path select<br>2'b00: Path0 data from sdi0<br>2'b01: Path0 data from sdi1<br>2'b10: Path0 data from sdi2<br>2'b11: Path0 data from sdi3                                                                                                      |
| 7:6        | RW          | 0x3                | tx_path_select3<br>TX path select<br>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                                                                          |
| 5:4        | RW          | 0x2                | tx_path_select2<br>TX path select<br>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                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:2        | RW          | 0x1                | tx_path_select1<br>TX path select<br>2'b00: Sd01 output data from path0<br>2'b01: Sd01 output data from path1<br>2'b10: Sd01 output data from path2<br>2'b11: Sd01 output data from path3 |
| 1:0        | RW          | 0x0                | tx_path_select0<br>TX path select<br>2'b00: Sd00 output data from path0<br>2'b01: Sd00 output data from path1<br>2'b10: Sd00 output data from path2<br>2'b11: Sd00 output data from path3 |

#### **SAI TX SLOT MASK0**

Address: **Operational Base** + offset (0x003C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | tx_slot_mask0<br>Transmit slot 0~31 mask state<br>slot 0~31 mask state<br>0: Slot active<br>1: Slot mask,data is invalid |

#### **SAI TX SLOT MASK1**

Address: **Operational Base** + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | tx_slot_mask1<br>Transmit slot 32~63 mask state<br>slot 32~63 mask state<br>0: Slot active<br>1: Slot mask,data is invalid |

#### **SAI TX SLOT MASK2**

Address: **Operational Base** + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | tx_slot_mask2<br>Transmit slot 64~95 mask state<br>slot 64~95 mask state<br>0: Slot active<br>1: Slot mask,data is invalid |

#### **SAI TX SLOT MASK3**

Address: **Operational Base** + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | tx_slot_mask3<br>Transmit slot 96~127 mask state<br>slot 96~127 mask state<br>0: Slot active<br>1: Slot mask,data is invalid |

#### **SAI RX SLOT MASK0**

Address: **Operational Base** + offset (0x004C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | rx_slot_mask0<br>Receive slot 0~31 mask state<br>Slot 0~31 mask state<br>0: Slot active<br>1: Slot mask,data is invalid |

**SAI RX SLOT MASK1**Address: **Operational Base** + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | rx_slot_mask1<br>Receive slot 32~63 mask state<br>slot 32~63 mask state<br>0: Slot active<br>1: Slot mask,data is invalid |

**SAI RX SLOT MASK2**Address: **Operational Base** + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | rx_slot_mask2<br>Receive slot 64~95 mask state<br>slot 64~95 mask state<br>0: Slot active<br>1: Slot mask,data is invalid |

**SAI RX SLOT MASK3**Address: **Operational Base** + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | rx_slot_mask3<br>Receive Slot 96~127 mask state<br>slot 96~127 mask state<br>0: Slot active<br>1: Slot mask,data is invalid |

**SAI TX DATA CNT**Address: **Operational Base** + offset (0x005C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>             |
|------------|-------------|--------------------|--------------------------------|
| 31:0       | RO          | 0x00000000         | tx_data_cnt<br>Tx data counter |

**SAI RX DATA CNT**Address: **Operational Base** + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>             |
|------------|-------------|--------------------|--------------------------------|
| 31:0       | RO          | 0x00000000         | rx_data_cnt<br>Rx data counter |

**SAI SAI TX SHIFT**Address: **Operational Base** + offset (0x0064)

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

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                   |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22:0 | RW   | 0x000000    | fs_shift<br>Transfer frame sync pulse shift control<br>24'h00: Normal mode<br>24'h01: Fs 1/2 cycle shift left.<br>24'h02: Fs 1 cycle shift left.<br>24'h03: Fs 3/2 cycle shift left.<br>..... |

**SAI SAI RX SHIFT**Address: **Operational Base** + offset (0x0068)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                   |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:23 | RO   | 0x000       | reserved                                                                                                                                                                                      |
| 22:0  | RW   | 0x000000    | fs_shift<br>Transfer frame sync pulse shift control<br>24'h00: Normal mode<br>24'h01: Fs 1/2 cycle shift left.<br>24'h02: Fs 1 cycle shift left.<br>24'h03: Fs 3/2 cycle shift left.<br>..... |

**SAI SAI RD STATUS**Address: **Operational Base** + offset (0x006C)

| Bit  | Attr | Reset Value | Description                                           |
|------|------|-------------|-------------------------------------------------------|
| 31:4 | RO   | 0x00000000  | reserved                                              |
| 3    | RW   | 0x1         | rx_idle<br>Rx idle status<br>1'b0:Busy<br>1'b1:idle   |
| 2    | RW   | 0x1         | tx_idle<br>Tx idle status<br>1'b0:Busy<br>1'b1:idle   |
| 1    | RW   | 0x1         | fs_idle<br>Fs idle status<br>1'b0:Busy<br>1'b1:idle   |
| 0    | RW   | 0x1         | clk_idle<br>Clk idle status<br>1'b0:Busy<br>1'b1:idle |

**SAI VERSION**Address: **Operational Base** + offset (0x0070)

| Bit  | Attr | Reset Value | Description               |
|------|------|-------------|---------------------------|
| 31:0 | RO   | 0x24013506  | sai_verton<br>SAI version |

**23.5 Interface Description**

The following table shows the SAI interface description.

Table 23-1 SAI0 Interface Description

| Module Pin | Direction | Pad Name | IOMUX Setting                        |
|------------|-----------|----------|--------------------------------------|
| sai0_mclk  | I/O       | GPIO0_A2 | GPIO0_IOC_GPIO0A_IOMUX_SEL_0[11:8]=1 |

| <b>Module Pin</b> | <b>Direction</b> | <b>Pad Name</b> | <b>IOMUX Setting</b>                  |
|-------------------|------------------|-----------------|---------------------------------------|
| sai0_sclk         | I/O              | GPIO0_A1        | GPIO0_IOC_GPIO0A_IOMUX_SEL_0[7:4]=1   |
| sai0_lrck         | I/O              | GPIO0_A0        | GPIO0_IOC_GPIO0A_IOMUX_SEL_0[3:0]=1   |
| sai0_sdo          | O                | GPIO0_A3        | GPIO0_IOC_GPIO0A_IOMUX_SEL_0[15:12]=1 |
| sai0_sdi0         | I                | GPIO0_A4        | GPIO0_IOC_GPIO0A_IOMUX_SEL_1[3:0]=1   |
| sai0_sdi1         | I                | GPIO0_A5        | GPIO0_IOC_GPIO0A_IOMUX_SEL_1[7:4]=1   |
| sai0_sdi2         | I                | GPIO0_A6        | GPIO0_IOC_GPIO0A_IOMUX_SEL_1[11:8]=1  |
| sai0_sdi3         | I                | GPIO0_A7        | GPIO0_IOC_GPIO0A_IOMUX_SEL_1[15:12]=1 |

Table 23-2 SAI0 Rm Interface Description

| <b>Module Pin</b> | <b>Direction</b> | <b>Pad Name</b> | <b>IOMUX Setting</b> |
|-------------------|------------------|-----------------|----------------------|
| sai0_mclk         | I/O              | RM_IO           |                      |
| sai0_sclk         | I/O              | RM_IO           |                      |
| sai0_lrck         | I/O              | RM_IO           |                      |
| sai0_sdo          | O                | RM_IO           |                      |
| sai0_sdi0         | I                | RM_IO           |                      |
| sai0_sdi1         | I                | RM_IO           |                      |
| sai0_sdi2         | I                | RM_IO           |                      |
| sai0_sdi3         | I                | RM_IO           |                      |

Table 23-3 SAI1 Interface Description

| <b>Module Pin</b> | <b>Direction</b> | <b>Pad Name</b> | <b>IOMUX Setting</b>                  |
|-------------------|------------------|-----------------|---------------------------------------|
| sai1_mclk         | I/O              | GPIO0_B0        | GPIO0_IOC_GPIO0B_IOMUX_SEL_0[3:0]=1   |
| sai1_sclk         | I/O              | GPIO0_B1        | GPIO0_IOC_GPIO0B_IOMUX_SEL_0[7:4]=1   |
| sai1_lrck         | I/O              | GPIO0_B2        | GPIO0_IOC_GPIO0B_IOMUX_SEL_0[11:8]=1  |
| sai1_sdo0         | O                | GPIO0_B4        | GPIO0_IOC_GPIO0B_IOMUX_SEL_1[3:0]=1   |
| sai1_sdo1         | O                | GPIO0_B5        | GPIO0_IOC_GPIO0B_IOMUX_SEL_1[7:4]=1   |
| sai1_sdo2         | O                | GPIO0_B6        | GPIO0_IOC_GPIO0B_IOMUX_SEL_1[11:8]=1  |
| sai1_sdo3         | O                | GPIO0_B7        | GPIO0_IOC_GPIO0B_IOMUX_SEL_1[15:12]=1 |
| sai1_sdi          | I                | GPIO0_B3        | GPIO0_IOC_GPIO0B_IOMUX_SEL_0[15:12]=1 |

Table 23-4 SAI1 Rm Interface Description

| <b>Module Pin</b> | <b>Direction</b> | <b>Pad Name</b> | <b>IOMUX Setting</b> |
|-------------------|------------------|-----------------|----------------------|
| sai1_mclk         | I/O              | RM_IO           |                      |
| sai1_sclk         | I/O              | RM_IO           |                      |
| sai1_lrck         | I/O              | RM_IO           |                      |
| sai1_sdo0         | O                | RM_IO           |                      |
| sai1_sdo1         | O                | RM_IO           |                      |
| sai1_sdo2         | O                | RM_IO           |                      |
| sai1_sdo3         | O                | RM_IO           |                      |
| sai1_sdi          | I                | RM_IO           |                      |

Table 23-5 SAI2 M0 Interface Description

| <b>Module Pin</b> | <b>Direction</b> | <b>Pad Name</b> | <b>IOMUX Setting</b>                      |
|-------------------|------------------|-----------------|-------------------------------------------|
| sai2_mclk         | I/O              | GPIO3_B6        | GPIO3_IOC_GPIO3B_IOMU<br>X_SEL_1[11:8]=1  |
| sai2_sclk         | I/O              | GPIO3_A7        | GPIO3_IOC_GPIO3A_IOMU<br>X_SEL_1[15:12]=1 |
| sai2_lrck         | I/O              | GPIO3_B1        | GPIO3_IOC_GPIO3B_IOMU<br>X_SEL_0[7:4]=1   |
| sai2_sdo          | O                | GPIO3_B0        | GPIO3_IOC_GPIO3B_IOMU<br>X_SEL_0[3:0]=1   |
| sai2_sdi          | I                | GPIO3_A6        | GPIO3_IOC_GPIO3A_IOMU<br>X_SEL_1[11:8]=1  |

Table 23-6 SAI2 M1 Interface Description

| <b>Module Pin</b> | <b>Direction</b> | <b>Pad Name</b> | <b>IOMUX Setting</b>                      |
|-------------------|------------------|-----------------|-------------------------------------------|
| sai2_mclk         | I/O              | GPIO1_C1        | GPIO1_IOC_GPIO1C_IOMU<br>X_SEL_0[7:4]=6   |
| sai2_sclk         | I/O              | GPIO1_B2        | GPIO1_IOC_GPIO1B_IOMU<br>X_SEL_0[11:8]=6  |
| sai2_lrck         | I/O              | GPIO1_B3        | GPIO1_IOC_GPIO1B_IOMU<br>X_SEL_0[15:12]=6 |
| sai2_sdo          | O                | GPIO1_C3        | GPIO1_IOC_GPIO1C_IOMU<br>X_SEL_0[15:12]=6 |
| sai2_sdi          | I                | GPIO1_C2        | GPIO1_IOC_GPIO1C_IOMU<br>X_SEL_0[11:8]=6  |

Table 23-7 SAI3 Interface Description

| <b>Module Pin</b> | <b>Direction</b> | <b>Pad Name</b> | <b>IOMUX Setting</b>                      |
|-------------------|------------------|-----------------|-------------------------------------------|
| sai3_mclk         | I/O              | GPIO2_C0        | GPIO2_IOC_GPIO2C_IOMU<br>X_SEL_0[3:0]=3   |
| sai3_sclk         | I/O              | GPIO2_B4        | GPIO2_IOC_GPIO2B_IOMU<br>X_SEL_1[3:0]=3   |
| sai3_lrck         | I/O              | GPIO2_B5        | GPIO2_IOC_GPIO2B_IOMU<br>X_SEL_1[7:4]=3   |
| sai3_sdo          | O                | GPIO2_B7        | GPIO2_IOC_GPIO2B_IOMU<br>X_SEL_1[15:12]=3 |
| sai3_sdi          | I                | GPIO2_B6        | GPIO2_IOC_GPIO2B_IOMU<br>X_SEL_1[11:8]=3  |

Notes: I=input, O=output, I/O=input/output. For the configuration of RM\_IO, please refer to chapter "Rockchip Matrix IO".

## 23.6 Application Notes

### 23.6.1 Software Application Notes



Fig. 23-11 SAI 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 24 Pulse Density Modulation (PDM)

### 24.1 Overview

The Pulse Density Modulation (PDM) is a PDM interface controller that supports 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, the PDM can be used with four stereo or eight mono microphones. Each path is enabled or disabled independently
- Support 16 ~24 bit sample resolution
- Support sample rate:  
8KHz, 16KHz, 32KHz, 64KHz, 128KHz, 11.025KHz, 22.05KHz, 44.1KHz, 88.2KHz, 176.4KHz, 12KHz, 24KHz, 48KHz, 96KHz, 192KHz
- Support two 16-bit audio data store together in one 32-bit wide location
- Support 16 to 31 bit audio data left or right justified in 32-bit wide FIFO
- Support programmable data sampling sensibility (rising or falling edge)
- Support mute function
- Support gain control
- Support 2.4MHz pdm clock

### 24.2 Block Diagram



Fig. 24-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.

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

#### PDM interface

The PDM interface implements PDM bit streams receive operation.

## 24.3 Function Description

### 24.3.1 AHB Interface

There is an AHB slave interface in PDM. It is responsible for accessing registers and internal memories.

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

The following figures show two cases of use of the PDM, but all configurations are possible with stereo and mono digital microphones.



Fig. 24-2 PDM with Eight Mono MIC



Fig. 24-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 tristate their output during one phase of the clock (high or low part of cycle, depending on how they are configured via their L/R input).



Fig. 24-4 PDM interface diagram with external MIC

### 24.3.3 Digital Filter

The external PDM 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.

### 24.3.4 Clock 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 value of PDM\_CLK when selecting the source clock (MCLK).

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

MCLK/PDM\_CLK is more than 10;

## 24.4 Register Description

### 24.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

### 24.4.2 Registers Summary

| Name                | Offset | Size | Reset Value | Description                            |
|---------------------|--------|------|-------------|----------------------------------------|
| PDM_SYSCONFIG       | 0x0000 | W    | 0x00000002  | PDM System Configure Register          |
| PDM_CTRL            | 0x0004 | W    | 0x001C8797  | PDM Control Register                   |
| PDM_FILTER_CTRL     | 0x0008 | W    | 0x00000000  | PDM Filter Control Register            |
| PDM_FIFO_CTRL       | 0x000C | W    | 0x0003E000  | PDM FIFO Control Register              |
| PDM_DATA_VALID      | 0x0010 | W    | 0x00000000  | PDM Path Data Valid Register           |
| PDM_RXFIFO_DATA_REG | 0x0014 | W    | 0x00000000  | PDM Receive FIFO Data Register         |
| PDM_DATA0R          | 0x0018 | W    | 0x00000000  | PDM Path 0 Right Channel Data Register |
| PDM_DATA0L          | 0x001C | W    | 0x00000000  | PDM Path 0 Left Channel Data Register  |
| PDM_DATA1R          | 0x0020 | W    | 0x00000000  | PDM Path 1 Right Channel Data Register |
| PDM_DATA1L          | 0x0024 | W    | 0x00000000  | PDM Path 1 Left Channel Data Register  |

| Name          | Offset | Size | Reset Value | Description                                  |
|---------------|--------|------|-------------|----------------------------------------------|
| PDM DATA2R    | 0x0028 | W    | 0x00000000  | PDM Path 2 Right Channel Data Register       |
| PDM DATA2L    | 0x002C | W    | 0x00000000  | PDM Path 2 Left Channel Data Register        |
| PDM DATA3R    | 0x0030 | W    | 0x00000000  | PDM Path 3 Right Channel Data Register       |
| PDM DATA3L    | 0x0034 | W    | 0x00000000  | PDM Path 3 Left Channel Data Register        |
| PDM VERSION   | 0x0038 | W    | 0x23113506  | PDM Version Register                         |
| PDM GAIN CTRL | 0x003C | W    | 0x00000000  | PDM Gain Control Register                    |
| PDM INCR RXDR | 0x0400 | W    | 0x00000000  | Increment Address Receive FIFO Data Register |

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

#### 24.4.3 Detail Registers Description

##### PDM\_SYS CONFIG

Address: Operational Base(0xFF380000) + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                        |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13 | RO   | 0x00000     | reserved                                                                                                                                                                                           |
| 12:5  | RW   | 0x00        | mute<br>mute[0]: ch0 mute<br>mute[1]: ch1 mute<br>mute[2]: ch2 mute<br>mute[3]: ch3 mute<br>mute[4]: ch4 mute<br>mute[5]: ch5 mute<br>mute[6]: ch6 mute<br>mute[7]: ch7 mute                       |
| 4     | 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. |
| 3     | RW   | 0x0         | num_start<br>Software configuration enable bit.<br>This bit only valid data when num_start = 1'b1.                                                                                                 |
| 2     | RW   | 0x0         | rx_start<br>RX transfer start bit<br>1'b0: Stop RX transfer<br>1'b1: Start RX transfer                                                                                                             |
| 1     | RW   | 0x1         | mem_gate_en<br>1: Memory interface clock auto gating enable<br>0: Memory interface clock auto gating disable                                                                                       |
| 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\_CTRL

Address: Operational Base(0xFF380000) + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 29:27      | RW          | 0x0                | <p>path1_ch_sel<br/> Left and right channel data sel<br/> If path_mode_select = 2'b00<br/> 3'b000: path3 left (R ch) and path2 left (L ch)<br/> 3'b001: path3 right (R ch) and path2 left (L ch)<br/> 3'b010: path3 left (R ch) and path2 right (L ch)<br/> 3'b011: path3 right (R ch) and path2 right (L ch)<br/> 3'b100: path2 left (R ch) and path3 left (L ch)<br/> 3'b101: path2 right (R ch) and path3 left (L ch)<br/> 3'b110: path2 left (R ch) and path3 right (L ch)<br/> 3'b111: path2 right (R ch) and path3 right (L ch)</p> <p>If path_mode_select = 2'b01<br/> 3'b000: path3 left (R ch) and path1 left (L ch)<br/> 3'b001: path3 right (R ch) and path1 left (L ch)<br/> 3'b010: path3 left (R ch) and path1 right (L ch)<br/> 3'b011: path3 right (R ch) and path1 right (L ch)<br/> 3'b100: path1 left (R ch) and path3 left (L ch)<br/> 3'b101: path1 right (R ch) and path3 left (L ch)<br/> 3'b110: path1 left (R ch) and path3 right (L ch)<br/> 3'b111: path1 right (R ch) and path3 right (L ch)</p> <p>If path_mode_select = 2'b10<br/> 3'b000: path2 left (R ch) and path1 left (L ch)<br/> 3'b001: path2 right (R ch) and path1 left (L ch)<br/> 3'b010: path2 left (R ch) and path1 right (L ch)<br/> 3'b011: path2 right (R ch) and path1 right (L ch)<br/> 3'b100: path1 left (R ch) and path2 left (L ch)<br/> 3'b101: path1 right (R ch) and path2 left (L ch)<br/> 3'b110: path1 left (R ch) and path2 right (L ch)<br/> 3'b111: path1 right (R ch) and path2 right (L ch)</p> |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 26:24 | RW   | 0x0         | <p>path0_ch_sel<br/>Left and right channel data sel<br/>If path_mode_select = 2'b00</p> <p>3'b000: path1 left (R ch) and path0 left (L ch)<br/>     3'b001: path1 right (R ch) and path0 left (L ch)<br/>     3'b010: path1 left (R ch) and path0 right (L ch)<br/>     3'b011: path1 right (R ch) and path0 right (L ch)<br/>     3'b100: path0 left (R ch) and path1 left (L ch)<br/>     3'b101: path0 right (R ch) and path1 left (L ch)<br/>     3'b110: path0 left (R ch) and path1 right (L ch)<br/>     3'b111: path0 right (R ch) and path1 right (L ch)</p> <p>If path_mode_select = 2'b01</p> <p>3'b000: path2 left (R ch) and path0 left (L ch)<br/>     3'b001: path2 right (R ch) and path0 left (L ch)<br/>     3'b010: path2 left (R ch) and path0 right (L ch)<br/>     3'b011: path2 right (R ch) and path0 right (L ch)<br/>     3'b100: path0 left (R ch) and path2 left (L ch)<br/>     3'b101: path0 right (R ch) and path2 left (L ch)<br/>     3'b110: path0 left (R ch) and path2 right (L ch)<br/>     3'b111: path0 right (R ch) and path2 right (L ch)</p> <p>If path_mode_select = 2'b10</p> <p>3'b000: path3 left (R ch) and path0 left (L ch)<br/>     3'b001: path3 right (R ch) and path0 left (L ch)<br/>     3'b010: path3 left (R ch) and path0 right (L ch)<br/>     3'b011: path3 right (R ch) and path0 right (L ch)<br/>     3'b100: path0 left (R ch) and path3 left (L ch)<br/>     3'b101: path0 right (R ch) and path3 left (L ch)<br/>     3'b110: path0 left (R ch) and path3 right (L ch)<br/>     3'b111: path0 right (R ch) and path3 right (L ch)</p> |
| 23:22 | RW   | 0x0         | <p>path_mode_select<br/>path Select</p> <p>2'b00: Path0 data and path1 data (path2 data and path3 data)<br/>     2'b01: Path0 data and path2 data (path1 data and path3 data)<br/>     2'b10: Path0 data and path3 data (path1 data and path2 data)</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 21    | RW   | 0x0         | <p>split_en<br/>Split enable</p> <p>1'b1: Enable<br/>     1'b0: Disable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 20:19 | RW   | 0x3         | <p>rx_path_select3<br/>RX Path Select</p> <p>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</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 18:17 | RW   | 0x2         | <p>rx_path_select2<br/>RX Path Select</p> <p>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</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16:15      | 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                                                                                                                                                                                                                      |
| 14:13      | 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                                                                                                                                                                                                                      |
| 12         | RW          | 0x0                | pdm_ch_ex<br>Left and right channel data exchange<br>1'b0: Not inverted, if mono_path_en, the output path is the Left path.<br>1'b1: Inverted, if mono_path_en, the output path is the Right path.                                                                                                                                                                                                     |
| 11         | RW          | 0x0                | sjm_sel<br>Store justified mode<br>This bit 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 1.<br>Because if HWT is 0, 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 |
| 10         | RW          | 0x1                | path3_en<br>Path 3 enable<br>1'b1: Enable<br>1'b0: Disable                                                                                                                                                                                                                                                                                                                                             |
| 9          | RW          | 0x1                | path2_en<br>Path 2 enable<br>1'b1: Enable<br>1'b0: Disable                                                                                                                                                                                                                                                                                                                                             |
| 8          | RW          | 0x1                | path1_en<br>Path 1 enable<br>1'b1: Enable<br>1'b0: Disable                                                                                                                                                                                                                                                                                                                                             |
| 7          | RW          | 0x1                | path0_en<br>Path 0 enable<br>1'b1: Enable<br>1'b0: Disable                                                                                                                                                                                                                                                                                                                                             |
| 6          | 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.                                                                                                                                          |
| 5          | RW          | 0x0                | mono_path_enable<br>Mono path enable bit.<br>If mono path enable, path0/path1/path2/path3 only one path enable, and the right or left path depended on the lr_ch_ex reg.<br>If data_vld_width cfg right/left data only 16bit, the data write to memory is combined by two data, {L1, L0} or {R1, R0}.                                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0        | RW          | 0x17               | <p>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</p> |

**PDM FILTER CTRL**

Address: Operational Base(0xFF380000) + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                    |
| 24:21      | RW          | 0x0                | <p>hpfilter_cfg<br/>High-pass filter configure<br/>4'd0: 0.234Hz<br/>4'd1: 0.468Hz<br/>4'd2: 0.937Hz<br/>4'd3: 1.875Hz<br/>4'd4: 3.75Hz<br/>4'd5: 7.5Hz<br/>4'd6: 15Hz<br/>4'd7: 30Hz<br/>4'd8: 60Hz<br/>4'd9: 122Hz<br/>4'd10: 251Hz<br/>4'd11: 528Hz<br/>4'd12: 1183Hz<br/>4'd13: 3152Hz<br/>4'd14: 23999Hz<br/>4'd15: high frequency</p> |
| 20         | RW          | 0x0                | <p>hpfilter_ctrl<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.</p>                                                                                                                                                        |
| 19         | RW          | 0x0                | <p>hpfilter_ctrlr<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.</p>                                                                                                                                                      |
| 18         | RW          | 0x0                | <p>fir_com_bps<br/>FIR compensate filter bypass<br/>1'b0: Not bypass<br/>1'b1: Bypass</p>                                                                                                                                                                                                                                                   |
| 17         | RW          | 0x0                | <p>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 hpfilter.</p>                                                                                                                                              |
| 16:10      | RW          | 0x00               | cic_scale<br>CIC scale bits                                                                                                                                                                                                                                                                                                                 |
| 9:1        | RW          | 0x000              | cic_value<br>CIC filter extract value                                                                                                                                                                                                                                                                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 0          | RW          | 0x0                | filter_en<br>Contrl hb2 filter en<br>1'b0: Off<br>1'b1:On |

### **PDM FIFO CTRL**

Address: Operational Base(0xFF380000) + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                  |
| 27:20      | RO          | 0x00               | rfl<br>Receive FIFO level<br>Contains the number of valid data entries in the receive FIFO.                                                                                                                                                                                               |
| 19:13      | 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. |
| 12         | RW          | 0x0                | rde<br>Receive DMA enable<br>1'b0: Receive DMA disabled<br>1'b1: Receive DMA enabled                                                                                                                                                                                                      |
| 11         | RO          | 0x0                | rxoi<br>RX overflow interrupt<br>1'b0: Inactive<br>1'b1: Active                                                                                                                                                                                                                           |
| 10         | RO          | 0x0                | rfi<br>RX full interrupt<br>1'b0: Inactive<br>1'b1: Active                                                                                                                                                                                                                                |
| 9          | RW          | 0x0                | rxioc<br>RX overflow interrupt clear (high active, auto clear).                                                                                                                                                                                                                           |
| 8:2        | 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.                                                                                                               |
| 1          | RW          | 0x0                | rxoie<br>RX overflow interrupt enable<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                                    |
| 0          | RW          | 0x0                | rftie<br>RX full threshold interrupt enable<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                              |

### **PDM DATA VALID**

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                                    |
| 3          | RC          | 0x0                | path0_vld<br>1'b0: DATA0R_REG, DATA0L_REG value is invalid.<br>1'b1: DATA0R_REG, DATA0L_REG value is valid. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 2          | RC          | 0x0                | path1_vld<br>1'b0: DATA1R_REG, DATA1L_REG value is invalid.<br>1'b1: DATA1R_REG, DATA1L_REG value is valid. |
| 1          | RC          | 0x0                | path2_vld<br>1'b0: DATA2R_REG, DATA2L_REG value is invalid.<br>1'b1: DATA2R_REG, DATA2L_REG value is valid. |
| 0          | RC          | 0x0                | path3_vld<br>1'b0: DATA3R_REG, DATA3L_REG value is invalid.<br>1'b1: DATA3R_REG, DATA3L_REG value is valid. |

**PDM\_RXFIFO DATA REG**

Address: Operational Base(0xFF380000) + offset (0x0014)

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

Address: Operational Base(0xFF380000) + offset (0x0018)

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

Address: Operational Base(0xFF380000) + offset (0x001C)

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

Address: Operational Base(0xFF380000) + offset (0x0020)

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

Address: Operational Base(0xFF380000) + offset (0x0024)

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

Address: Operational Base(0xFF380000) + offset (0x0028)

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

Address: Operational Base(0xFF380000) + offset (0x002C)

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

Address: Operational Base(0xFF380000) + offset (0x0030)

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

Address: Operational Base(0xFF380000) + offset (0x0034)

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

Address: Operational Base(0xFF380000) + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:0       | RW          | 0x23113506         | ver<br>PDM version |

**PDM GAIN CTRL**

Address: Operational Base(0xFF380000) + offset (0x003C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                           |
| 7:0        | RW          | 0x00               | gain_ctrl<br>0: -65.625dB<br>1: -65.25dB<br>....<br>175: 0dB<br>.....<br>255: 30dB<br>step:0.375dB |

**PDM INCR RXDR**

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

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

## 24.5 Interface Description

The following table shows the PDM interface description.

Table 24-2 PDM Interface Description

| <b>Module Pin</b> | <b>Direction</b> | <b>Rockchip matrix IO</b> | <b>IOMUX Setting</b> |
|-------------------|------------------|---------------------------|----------------------|
| O_pdm_clk(0)      | O                | RM_IO                     |                      |
| O_pdm_clk(1)      | O                | RM_IO                     |                      |
| I_pdm_data0       | I                | RM_IO                     |                      |
| I_pdm_data1       | I                | RM_IO                     |                      |
| I_pdm_data2       | I                | RM_IO                     |                      |
| I_pdm_data3       | I                | RM_IO                     |                      |

Notes: I=input, O=output, I/O=input/output. For the configuration of RM\_IO, please refer to chapter "Rockchip Matrix IO".

## 24.6 Application Notes



Fig. 24-5 PDM operation flow

## Chapter 25 SPDIF TX

### 25.1 Overview

The SPDIF transmitter is a self-clocking, serial, unidirectional interface for the interconnection of digital audio equipment for consumer and professional applications, using linear PCM coded audio samples.

It provides the basic structure of the interface. Separate documents define items specific to particular applications.

When used in a professional application, the interface is primarily intended to carry monophonic or stereophonic programmes, at a 48 kHz sampling frequency and with a resolution of up to 24bits per sample; it may alternatively be used to carry signals sampled at 32 kHz or 44.1 kHz.

When used in a consumer application, the interface is primarily intended to carry stereophonic programmes, with a resolution of up to 20 bits per sample, an extension to 24 bits per sample being possible.

When used for other purposes, the interface is primarily intended to carry audio data coded other than as linear PCM coded audio samples. Provision is also made to allow the interface to carry data related to computer software or signals coded using non-linear PCM. The format specification for these applications is not part of this standard.

In all cases, the clock references and auxiliary information are transmitted along with the programme. MCLK is the operation clock of SPDIF transmitter.

Table 25-1 Maximum Frequency of MCLK for the SPDIF Transmitter

| SPDIF transmitter | Maximum frequency of MCLK |
|-------------------|---------------------------|
| SPDIF             | 100MHz                    |

Each SPDIF transmitter supports following features.

- Support one internal 32-bit wide and 32-location deep sample data buffer
- Support two 16-bit audio data store together in one 32-bit wide location
- Support AHB or APB bus interface
- Support biphasic format stereo audio data output
- Support DMA handshake interface and configurable DMA water level
- Support sample data buffer empty and block terminate interrupt
- Support combine interrupt output
- Support 16 to 31 bit audio data left or right justified in 32-bit wide sample data buffer
- Support 48, 44.1, 32kHz sample rate
- Support MCLK frequencies of 12.288Mhz, 8.192Mhz and 11.2896MHz
- Support 16, 20, 24 bits audio data transfer
- Support frame transmission frequency, fixed to 128 times of audio data sampling rate

### 25.2 Block Diagram



Fig.25-1 SPDIF transmitter Block Diagram

The SPDIF transmitter is composed of following module.

#### System Interface

The system interface implements the AHB slave operation. It contains not only control

registers of transmitters and receiver inside but also interrupt and DMA handshaking interface.

### Clock Divider

The clock divider implements clock generation function. It divides the source clock MCLK to generate the working clock used for the digital audio data transformation and transmission.

### Parallel Audio Buffer

The parallel audio buffer stores the audio data to be transmitted. The size of the FIFO is 32bits x 32.

### Serial Audio Converter

The serial audio converter converts the parallel audio data from the parallel audio buffer to the serial audio data.

### Biphase Audio Generator

The biphase audio generator reads serial audio data from the serial audio converter and generates biphase audio data based on IEC-60958 standard.

## 25.3 Function Description

### 25.3.1 Frame Format

A frame is uniquely composed of two sub-frames. For linear coded audio applications, the rate of transmission of frames corresponds exactly to the source sampling frequency.

In the 2-channel operation mode, the samples taken from both channels are transmitted by time multiplexing in consecutive sub-frames. The first sub-frame (left channel in stereophonic operation and primary channel in monophonic operation) normally use preamble M. However, the preamble is changed to preamble B once every 192 frame to identify the start of the block structure used to organize the channel status information. The second sub-frame (right in stereophonic operation and secondary channel in monophonic operation) always use preamble W.



Fig.25-2 SPDIF Frame Format

In the single channel operation mode in a professional application, the frame format is the same as in the 2-channel mode. Data is carried only in the first sub-frame and may be duplicated in the second sub-frame. If the second sub-frame is not carrying duplicate data, then time slot 28 (validity flag) shall be set to logical '1' (not valid).

### 25.3.2 Sub-frame Format



Fig.25-3 SPDIF Sub-frame Format

Each sub-frame is divided into 32 time slots, numbered from 0 to 31. Time slot 0 to 3 carries one of the three permitted preambles. Time slot 4 to 27 carry the audio sample word in linear 2's complement representation. The MSB is carried by time slot 27. When a 24-bit coding range is used, the LSB is in time slot 4. When a 20-bit coding range is used, time slot 8 to 27 carry the audio sample word with the LSB in time slot 8. Time slot 4 to 7 may be used for other application. Under these circumstances, the bits in the time slot 4 to

7 are designated auxiliary sample bits.

If the source provides fewer bits than the interface allows (either 24 or 20), the unused LSBs are set to a logical '0'. For a non-linear PCM audio application or a data application the main data field may carry any other information. Time slot 28 carries the validity flag associated with the main data field. Time slot 29 carries 1 bit of the user data associated with the audio channel transmitted in the same sub-frame. Time slot 30 carries one bit of the channel status words associated with the main data field channel transmitted in the same sub-frame. Time slot 31 carries a parity bit such that time slots 4 to 31 inclusive carries an even number of ones and an even number of zeros.

### 25.3.3 Channel Coding



Fig.25-4 SPDIF Channel Coding

To minimize the direct current component on the transmission line, to facilitate clock recovery from the data stream and to make the interface insensitive to the polarity of connections, time slots 4 to 31 are encoded in biphase-mark.

Each bit to be transmitted is represented by a symbol comprising two consecutive binary states. The first state of a symbol is always different from the second state of the previous symbol. The second state of the symbol is identical to the first if the bit to be transmitted is logical '0'. However, it is different from the first if the bit is logical '1'.

### 25.3.4 Preamble

Preambles are specific patterns providing synchronization and identification of the sub-frames and blocks.

To achieve synchronization within one sampling period and to make this process completely reliable, these patterns violate the biphase-mark code rules, thereby avoiding the possibility of data imitating the preambles.

A set of three preambles is used. These preambles are transmitted in the time allocated to four time slots (time slots 0 to 3) and are represented by eight successive states. The first state of the preamble is always different from the second state of the previous symbol.



Fig.25-5 SPDIF Preamble

Like biphase code, these preambles are DC free and provide clock recovery. They differ in at least two states from any valid biphase sequence.

## 25.4 Register Description

### 25.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as

follows.

### Operational Base

| Name                            | Base Address |
|---------------------------------|--------------|
| SPDIF_TX_SECURE_BASE_ADDRESS    | 0x40900000   |
| SPDIF_TX_NO-SECURE_BASE_ADDRESS | 0x50900000   |

## 25.4.2 Registers Summary

| Name                    | Offset | Size | Reset Value | Description                                                                                                                                                                                                                                                                                                       |
|-------------------------|--------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SPDIF TX CFGR           | 0x0000 | W    | 0x00000000  | Configuration Register                                                                                                                                                                                                                                                                                            |
| SPDIF TX SDBLR          | 0x0004 | W    | 0x00000000  | Sample Date Buffer Level Register                                                                                                                                                                                                                                                                                 |
| SPDIF TX DMACR          | 0x0008 | W    | 0x00000000  | DMA Control Register                                                                                                                                                                                                                                                                                              |
| SPDIF TX INTCR          | 0x000C | W    | 0x00000000  | Interrupt Control Register                                                                                                                                                                                                                                                                                        |
| SPDIF TX INTSR          | 0x0010 | W    | 0x00000000  | Interrupt Status Register                                                                                                                                                                                                                                                                                         |
| SPDIF TX XFER           | 0x0018 | W    | 0x00000000  | Transfer Start Register                                                                                                                                                                                                                                                                                           |
| SPDIF TX SMPDR          | 0x0020 | W    | 0x00000000  | Sample Data Register                                                                                                                                                                                                                                                                                              |
| SPDIF TX VLDFRn         | 0x0060 | W    | 0x00000000  | Validity Flag Register n                                                                                                                                                                                                                                                                                          |
| SPDIF TX USRDRn         | 0x0090 | W    | 0x00000000  | User Data Register n                                                                                                                                                                                                                                                                                              |
| SPDIF TX CHNSRn         | 0x00C0 | W    | 0x00000000  | Channel Status Register n                                                                                                                                                                                                                                                                                         |
| SPDIF TX BURTSINFO      | 0x00D0 | W    | 0x00000000  | This define the channel burst info when the channel conveys non-linear PCM.                                                                                                                                                                                                                                       |
| SPDIF TX REPETITION     | 0x0104 | W    | 0x00000000  | This register provides the repetition of the bitstream when channel conveys non-linear PCM. In the design, it is define the length between Pa of the two consecutive data-burst. For the same audio format, the definition is different. Please convert the actual repetition in order to comply with the design. |
| SPDIF TX BURTSINFO_SHD  | 0x0108 | W    | 0x00000000  | This define the channel burst info when the channel conveys non-linear PCM.                                                                                                                                                                                                                                       |
| SPDIF TX REPETITION_SHD | 0x010C | W    | 0x00000000  | This register provides the repetition of the bitstream when channel conveys non-linear PCM.                                                                                                                                                                                                                       |
| SPDIF TX USRDR_SHDn     | 0x0190 | W    | 0x00000000  | Shadow User Data Register n                                                                                                                                                                                                                                                                                       |

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

## 25.4.3 Detail Registers Description

### SPDIF TX CFGR

Address: **Operational Base** + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                      |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------|
| 31:24 | RO   | 0x00        | reserved                                                                                                         |
| 23:16 | RW   | 0x00        | MCD<br>Fmclk/Fsdo<br>This parameter can be calculated by Fmclk/(Fs*128).<br>Fs is the sample frequency be wanted |
| 15:10 | RO   | 0x00        | reserved                                                                                                         |
| 9     | RW   | 0x0         | PRECHANGE<br>0: No linear PCM length<br>1: 192 block                                                             |
| 8     | RW   | 0x0         | PCMTYPE<br>0: linear PCM<br>1: non-linear PCM                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------|
| 7          | WO          | 0x0                | CLR<br>Write 1 to clear MCLK domain logic. Read returns zero.                                                        |
| 6          | RW          | 0x0                | CSE<br>0: Disable<br>1: Enable<br>The bit should be set to 1 when the channel conveys non-linear PCM                 |
| 5          | RW          | 0x0                | UDE<br>0: Disable<br>1: Enable                                                                                       |
| 4          | RW          | 0x0                | VFE<br>0: Disable<br>1: Enable                                                                                       |
| 3          | RW          | 0x0                | ADJ<br>0: Right justified<br>1: Left justified                                                                       |
| 2          | RW          | 0x0                | HWT<br>0: Disable<br>1: Enable<br>It is valid only when the valid data width is 16bit.                               |
| 1:0        | RW          | 0x0                | VDW<br>00: 16bit<br>01: 20bit<br>10: 24bit<br>11: reserved<br>The valid data width is 16bit only for non-linear PCM. |

**SPDIF TX SDBLR**Address: **Operational Base** + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                                      |
| 5:0        | RW          | 0x00               | SDBLR<br>Contains the number of valid data entries in the sample data buffer. |

**SPDIF TX DMACR**Address: **Operational Base** + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                           |
| 5          | RW          | 0x0                | TDE<br>0: Transmit DMA disabled<br>1: Transmit DMA enabled                                                                                                                                                                                                                                         |
| 4: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 <code>dma_tx_req</code> signal is generated when the number of valid data entries in the Sample Date Buffer is equal to or below this field value. |

**SPDIF TX INTCR**Address: **Operational Base** + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:18      | RO          | 0x0000             | reserved                                             |
| 17         | W1 C        | 0x0                | UDTIC<br>Write '1' to clear the user data interrupt. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16         | W1<br>C     | 0x0                | BTTIC<br>Write '1' to clear the interrupt.                                                                                                                                                                                            |
| 15:10      | RO          | 0x00               | reserved                                                                                                                                                                                                                              |
| 9:5        | RW          | 0x00               | SDBT<br>Sample Date Buffer Threshold for empty interrupt.                                                                                                                                                                             |
| 4          | RW          | 0x0                | SDBEIE<br>0: Disable<br>1: Enable                                                                                                                                                                                                     |
| 3          | RW          | 0x0                | BTTIE<br>When enabled, an interrupt will be asserted when the block transfer is finished if the channel conveys linear PCM or when the repetition period is reached if the channel conveys non-linear PCM.<br>0: Disable<br>1: Enable |
| 2          | RW          | 0x0                | UDTIE<br>0: Disable<br>1: Enable<br>If enabled, an interrupt will be asserted when the content of the user data register is fed into the corresponding shadow register.                                                               |
| 1:0        | RO          | 0x0                | reserved                                                                                                                                                                                                                              |

### **SPDIF TX INTSR**

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                           |
| 4          | RW          | 0x0                | SDBEIS<br>0: Inactive<br>1: Active |
| 3          | RW          | 0x0                | BTTIS<br>0: Inactive<br>1: Active  |
| 2          | RW          | 0x0                | UDTIS<br>0: Inactive<br>1: Active  |
| 1:0        | RO          | 0x0                | reserved                           |

### **SPDIF TX XFER**

Address: **Operational Base** + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>              |
|------------|-------------|--------------------|---------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                        |
| 0          | RW          | 0x0                | XFER<br>Transfer Start Register |

### **SPDIF TX SMPDR**

Address: **Operational Base** + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>            |
|------------|-------------|--------------------|-------------------------------|
| 31:0       | RW          | 0x00000000         | SMPDR<br>Sample Data Register |

### **SPDIF TX VLDFRN**

Address: **Operational Base** + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                      |
|------------|-------------|--------------------|-----------------------------------------|
| 31:16      | RW          | 0x0000             | VLDFR_SUB_1<br>Validity Flag Register 0 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                          |
|------------|-------------|--------------------|---------------------------------------------|
| 15:0       | RW          | 0x0000             | VLDFR_SUB_0<br>Validity Flag for Subframe 0 |

**SPDIF TX USRDRn**Address: **Operational Base** + offset (0x0090)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                        |
|------------|-------------|--------------------|-------------------------------------------|
| 31:16      | RW          | 0x0000             | USR_SUB_1<br>User Data Bit for Subframe 1 |
| 15:0       | RW          | 0x0000             | USR_SUB_0<br>User Data Bit for Subframe 0 |

**SPDIF TX CHNSRn**Address: **Operational Base** + offset (0x00C0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 31:16      | RW          | 0x0000             | CHNSR_SUB_1<br>Channel Status Bit for Subframe 1 |
| 15:0       | RW          | 0x0000             | CHNSR_SUB_0<br>Channel Status Bit for Subframe 0 |

**SPDIF TX BURTSINFO**Address: **Operational Base** + offset (0x00D0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | PD<br>Preamble Pd for non-linear PCM, indicating the length of burst payload in unit of bytes or bits.  |
| 15:13      | RW          | 0x0                | BSNUM<br>This field indicates the bitstream number. Usually the birstream number is 0.                  |
| 12:8       | RW          | 0x00               | DATAINFO<br>This field gives the data-type-dependent info.                                              |
| 7          | RW          | 0x0                | ERRFLAG<br>0: Indicates a valid burst-payload<br>1: Indicates that the burst-payload may contain errors |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:0 | RW   | 0x00        | DATATYPE<br>0000000: null data<br>0000001: AC-3 data<br>0000011: Pause data<br>0000100: MPEG-1 layer 1 data<br>0000101: MPEG-1 layer 2 or 3 data or MPEG-2 without extension<br>0000110: MPEG-2 data with extension<br>0000111: MPEG-2 AAC<br>0001000: MPEG-2, layer-1 low sampling frequency<br>0001001: MPEG-2, layer-2 low sampling frequency<br>0001010: MPEG-2, layer-3 low sampling frequency<br>0001011: DTS type I<br>0001100: DTS type II<br>0001101: DTS type III<br>0001110: ATRAC<br>0001111: ATRAC 2/3<br>0010000: ATRAC-X<br>0010001: DTS type IV<br>0010010: WMA professional type I<br>0110010: WMA professional type II<br>1010010: WMA professional type III<br>1110010: WMA professional type IV<br>0010011: MPEG-2 AAC low sampling frequency<br>0110011: MPEG-2 AAC low sampling frequency<br>1010011: MPEG-2 AAC low sampling frequency<br>1110011: MPEG-2 AAC low sampling frequency<br>0010100: MPEG-4 AAC<br>0110100: MPEG-4 AAC<br>1010100: MPEG-4 AAC<br>1110100: MPEG-4 AAC<br>0010101: Enhanced AC-3<br>0010110: MAT<br>others: reserved |

**SPDIF TX REPETITION**Address: **Operational Base** + offset (0x0104)

| Bit   | Attr | Reset Value | Description                                                                                     |
|-------|------|-------------|-------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0000      | reserved                                                                                        |
| 15:0  | RW   | 0x0000      | <b>REPETITION</b><br>This define the repetition period when the channel conveys non-linear PCM. |

**SPDIF TX BURTSINFO SHD**Address: **Operational Base** + offset (0x0108)

| Bit   | Attr | Reset Value | Description                                                                                                    |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0000      | <b>PD</b><br>Preamble Pd for non-linear PCM, indicating the length of burst payload in unit of bytes or bits.  |
| 15:13 | RO   | 0x0         | <b>BSNUM</b><br>This field indicates the bitstream number. Usually the birstream number is 0.                  |
| 12:8  | RO   | 0x00        | <b>DATAINFO</b><br>This field gives the data-type-dependent info                                               |
| 7     | RO   | 0x0         | <b>ERRFLAG</b><br>0: Indicates a valid burst-payload<br>1: Indicates that the burst-payload may contain errors |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:0 | RO   | 0x00        | DATATYPE<br>0000000: null data<br>0000001: AC-3 data<br>0000011: Pause data<br>0000100: MPEG-1 layer 1 data<br>0000101: MPEG-1 layer 2 or 3 data or MPEG-2 without extension<br>0000110: MPEG-2 data with extension<br>0000111: MPEG-2 AAC<br>0001000: MPEG-2, layer-1 low sampling frequency<br>0001001: MPEG-2, layer-2 low sampling frequency<br>0001010: MPEG-2, layer-3 low sampling frequency<br>0001011: DTS type I<br>0001100: DTS type II<br>0001101: DTS type III<br>0001110: ATRAC<br>0001111: ATRAC 2/3<br>0010000: ATRAC-X<br>0010001: DTS type IV<br>0010010: WMA professional type I<br>0110010: WMA professional type II<br>1010010: WMA professional type III<br>1110010: WMA professional type IV<br>0010011: MPEG-2 AAC low sampling frequency<br>0110011: MPEG-2 AAC low sampling frequency<br>1010011: MPEG-2 AAC low sampling frequency<br>1110011: MPEG-2 AAC low sampling frequency<br>0010100: MPEG-4 AAC<br>0110100: MPEG-4 AAC<br>1010100: MPEG-4 AAC<br>1110100: MPEG-4 AAC<br>0010101: Enhanced AC-3<br>0010110: MAT<br>others: reserved |

**SPDIF TX REPETITION SHD**Address: **Operational Base** + offset (0x010C)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                            |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0000      | reserved                                                                                                                                                                                                                                                                                                                               |
| 15:0  | RW   | 0x0000      | <b>REPETITION</b><br>This register provides the repetition of the bitstream when channel conveys non-linear PCM. In the design, it is define the length between Pa of the two consecutive data-burst. For the same audio format, the definition is different. Please convert the actual repetition in order to comply with the design. |

**SPDIF TX USRDR SHDn**Address: **Operational Base** + offset (0x0190)

| Bit   | Attr | Reset Value | Description                               |
|-------|------|-------------|-------------------------------------------|
| 31:16 | RO   | 0x0000      | USR_SUB_1<br>User Data Bit for Subframe 1 |
| 15:0  | RO   | 0x0000      | USR_SUB_0<br>User Data Bit for Subframe 0 |

**25.5 Interface Description**

SPDIF are used to communicate with audio equipment outside this chip. Following table

shows the interface of SPDIF.

Table 25-2 SPDIF TX Interface Description

| <b>Module Pin</b> | <b>Direction</b> | <b>Rockchip matrix IO</b> | <b>IOMUX Setting</b> |
|-------------------|------------------|---------------------------|----------------------|
| spdif_sdo         | O                | RM_IO                     |                      |

Notes: *I*=input, *O*=output, *I/O*=input/output. For the configuration of RM\_IO, please refer to chapter "Rockchip Matrix IO".

## 25.6 Application Notes



Fig.25-6 SPDIF transmitter operation flow chart

The above figure shows the operation flow of SPDIF operation. Note that the configuration register can be written only when the transfer is stopped.

## Chapter 26 SPDIF RX

### 26.1 Overview

The SPDIF receiver is a self-clocking, serial, unidirectional interface for the interconnection of digital audio equipment for consumer and professional applications, using linear PCM coded audio samples.

It provides the basic structure of the interface. Separate documents define items specific to particular applications.

When used in a professional application, the interface is primarily intended to receive monophonic or stereophonic programmes, at a 48 kHz sampling frequency and with a resolution of up to 24bits per sample; it may alternatively be used to receive signals sampled at 32 kHz or 44.1 kHz.

When used in a consumer application, the interface is primarily intended to receive stereophonic programmes, with a resolution of up to 24 bits per sample.

When used for other purposes, the interface is primarily intended to receive audio data coded other than as linear PCM coded audio samples. Provision is also made to allow the interface to receive data related to computer software or signals coded using non-linear PCM. The format specification for these applications is not part of this standard.

It supports following features.

- Support AHB bus interface
- Support one internal 30-bit wide and 32-location deep FIFO for receiving audio data
- Support combined interrupt output
- Support DMA handshaking interface and configurable DMA water level
- Support linear PCM(IEC60958) and non-linear PCM(IEC61937)
- Support 16~24 bits audio sample length for liner PCM application
- Support 16 bits audio sample length for non-liner PCM application
- Support up to 192kHz sample rate with the corresponding reference clock equal to 384KHz\*64\*2\*10, that is 245.76MHz
- Support the frequency of reference clock is at least 10 times the frequency of the biphase encoding clock, but not more than 256 times
- Support recovering clock and audio data from input bitstream

### 26.2 Block Diagram



Fig.26-1 SPDIF receiver Block Diagram

The SPDIF receiver is composed of following modules.

#### SPDIF\_RX\_SYS

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

CDR

The CDR is short for clock and data recovery. Clock and data can be recovered from the input bitstream by using a high frequency reference clock.

### **DECODER**

The clock recovered from the CDR is used as the working clock to decode the input bitstream such as extracting audio data, the corresponding preamble code, V/U/C/P flags and other audio information.

RX FIFO

The RX FIFO stores the audio data extracted from input bitstream. The size of the FIFO is 30bitsx32.

## 26.3 Function description

### 26.3.1 Frame Format

SPDIF receiver follows the same protocol (IEC60958/IEC61937) as SPDIF transmitter. A frame is uniquely composed of two sub-frames. For linear coded audio applications, the rate of receiving of frames corresponds exactly to the source sampling frequency.

In the 2-channel operation mode, the samples received from both channels are arranged by time multiplexing in consecutive sub-frames. The first subframe (left channel in stereophonic operation and primary channel in monophonic operation) normally use preamble M. However, the preamble is changed to preamble B once every 192 frame to identify the start of the block structure used to organize the channel status information. The second sub-frame (right in stereophonic operation and secondary channel in monophonic operation) always use preamble W.



Fig.26-2 SPDIF Frame Format

In the single channel operation mode in a professional application, the frame format is the same as in the 2-channel mode. Data is carried only in the first sub-frame and may be duplicated in the second sub-frame. If the second sub-frame is not carrying duplicate data, then time slot 28 (validity flag) shall be set to logical '1' (not valid).

### 26.3.2 Sub-frame Format



Fig.26-3 SPDIF Sub-frame Format

Each sub-frame is divided into 32 time slots, numbered from 0 to 31. Time slot 0 to 3 carries one of the three permitted preambles. Time slot 4 to 27 carry the audio sample word in linear 2's complement representation. The MSB is carried by time slot 27. When a 24-bit coding range is used, the LSB is in time slot 4. When a 20-bit coding range is used, time slot 8 to 27 carry the audio sample word with the LSB in time slot 8. Time slot 4 to 7 may be used for other application. Under these circumstances, the bits in the time slot 4 to 7 are designated auxiliary sample bits.

If the source provides fewer bits than the interface allows (either 24 or 20), the unused LSBs are set to a logical '0'. For a non-linear PCM audio application or a data application the main data field may carry any other information. Time slot 28 carries the validity flag associated with the main data field. Time slot 29 carries 1 bit of the user data associated with the audio channel transmitted in the same sub-frame. Time slot 30 carries one bit of the channel status words associated with the main data field channel transmitted in the same sub-frame. Time slot 31 carries a parity bit such that time slots 4 to 31 inclusive carries an even number of ones and an even number of zeros.

### 26.3.3 Channel Coding



Fig.26-4 SPDIF Channel Coding

To minimize the direct current component on the transmission/receiving line, to facilitate clock recovery from the data stream and to make the interface insensitive to the polarity of connections, time slots 4 to 31 are encoded in biphasic-mark.

Each bit to be transmitted is represented by a symbol comprising two consecutive binary states. The first state of a symbol is always different from the second state of the previous symbol. The second state of the symbol is identical to the first if the bit to be transmitted is logical '0'. However, it is different from the first if the bit is logical '1'.

### 26.3.4 Preamble

Preambles are specific patterns providing synchronization and identification of the sub-frames and blocks.

To achieve synchronization within one sampling period and to make this process completely reliable, these patterns violate the biphasic-mark code rules, thereby avoiding the possibility of data imitating the preambles.

A set of three preambles is used. These preambles are transmitted in the time allocated to four time slots (time slots 0 to 3) and are represented by eight successive states. The first state of the preamble is always different from the second state of the previous symbol.



Fig.26-5 SPDIF Preamble

Like biphasic code, these preambles are dc free and provide clock recovery. They differ in at least two states from any valid biphasic sequence.

## 26.4 Register Description

### 26.4.1 Internal Address Mapping

26.4.2 Slave address can be divided into different length for different usage, which is shown as follows.

### 26.4.3 Registers Summary

| Name               | Offset | Size | Reset Value | Description                             |
|--------------------|--------|------|-------------|-----------------------------------------|
| SPDIF_RX_VERSION   | 0x0000 | W    | 0x23123506  | Version Register                        |
| SPDIF_RX_CFGR      | 0x0004 | W    | 0x00000000  | Configuration Register                  |
| SPDIF_RX_CLR       | 0x0008 | W    | 0x00000000  | Clear Register                          |
| SPDIF_RX_CDR       | 0x000C | W    | 0x000000A1  | Clock And Data Recovery Register        |
| SPDIF_RX_CDRST     | 0x0010 | W    | 0x03FF00FF  | Clock And Data Recovery Status Register |
| SPDIF_RX_DMACR     | 0x0014 | W    | 0x00000000  | DMA Control Register                    |
| SPDIF_RX_FIFOCTRL  | 0x0018 | W    | 0x00000000  | FIFO Control Register                   |
| SPDIF_RX_INTEN     | 0x001C | W    | 0x00000000  | Interrupt Enable Register               |
| SPDIF_RX_INTMASK   | 0x0020 | W    | 0x00000000  | Interrupt Mask Register                 |
| SPDIF_RX_INTSR     | 0x0024 | W    | 0x00000000  | Interrupt Status Register               |
| SPDIF_RX_INTCLR    | 0x0028 | W    | 0x00000000  | Interrupt Clear Register                |
| SPDIF_RX_SMPDR     | 0x002C | W    | 0x00000000  | Sample Data Register                    |
| SPDIF_RX_USRDRn    | 0x0030 | W    | 0x00000000  | User Data Register n(n=0~11)            |
| SPDIF_RX_CHNSRn    | 0x0060 | W    | 0x00000000  | Channel Status Register n(n=0~11)       |
| SPDIF_RX_CDR_TIME  | 0x0090 | W    | 0x03FF03FF  | CDR Time Register                       |
| SPDIF_RX_RX_STATUS | 0x0094 | W    | 0x00000000  | Status Register                         |
| SPDIF_RX_BURTSINFO | 0x0100 | W    | 0x00000000  | Channel Burst Info 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

### 26.4.4 Detail Registers Description

#### SPDIF\_RX\_VERSION

Address: Operational Base(0xFF3B0000) + offset (0x0000)

| Bit  | Attr | Reset Value | Description                 |
|------|------|-------------|-----------------------------|
| 31:0 | RO   | 0x23123506  | VER<br>Version of SPDIF_RX. |

#### SPDIF\_RX\_CFGR

Address: Operational Base(0xFF3B0000) + offset (0x0004)

| Bit  | Attr | Reset Value | Description                                                                                                                           |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | RO   | 0x00000000  | reserved                                                                                                                              |
| 2    | RW   | 0x0         | DAT<br>1'b0: Disable data join<br>1'b1: Enable data join                                                                              |
| 1    | RW   | 0x0         | TWAD<br>1'b0: Only audio data transmitted to FIFO.<br>1'b1: Block start, channel number and VUCP transmitted with audio data to FIFO. |
| 0    | RW   | 0x0         | EN<br>1'b0: Disable SPDIF_RX<br>1'b1: Enable SPDIF_RX                                                                                 |

#### SPDIF\_RX\_CLR

Address: Operational Base(0xFF3B0000) + offset (0x0008)

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:1 | RO   | 0x00000000  | reserved    |

| Bit | Attr | Reset Value | Description                                                                         |
|-----|------|-------------|-------------------------------------------------------------------------------------|
| 0   | RW   | 0x0         | RXSC<br>This is a software self-cleared bit. Write 1'b1 to clear all receive logic. |

**SPDIF RX CDR**

Address: Operational Base(0xFF3B0000) + offset (0x000C)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                         |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | RW   | 0x00        | JITRSH<br>CDR jitter threshold. It is valid only when BYPASS is 1'b0.                                                                                                                                               |
| 23:16 | RW   | 0x00        | MIDRGE<br>CDR jitter middle range. It is valid only when BYPASS is 1'b0.                                                                                                                                            |
| 15:11 | RO   | 0x00        | reserved                                                                                                                                                                                                            |
| 10:9  | RO   | 0x0         | CS<br>CDR state<br>2'b00: Idle state. CDR is idle and waits for rising edge of SPDIF_RX input bitstream.<br>2'b01: Detect state<br>2'b10: Measurement state<br>2'b11: Synchronization state                         |
| 8:7   | RO   | 0x1         | JITST<br>CDR jitter status<br>2'b01: Low<br>2'b10: High<br>2'b11: Normal<br>It is valid only when BYPASS is 1'b0.                                                                                                   |
| 6     | RO   | 0x0         | FULL<br>CDR FIFO full status<br>1'b0: Not full<br>1'b1: Full<br>It is valid only when BYPASS is 1'b0.                                                                                                               |
| 5     | RO   | 0x1         | EMPTY<br>CDR FIFO empty status<br>1'b0: Not empty<br>1'b1: Empty<br>It is valid only when BYPASS is 1'b0.                                                                                                           |
| 4:2   | RW   | 0x0         | AVGWIN<br>Average the non-jitter recovered clock from bitstream at a period of AVGWIN time.                                                                                                                         |
| 1     | RW   | 0x0         | AVGSEL<br>Select if the minimum or average number of cycles from the calculation of SPDIF_RX input bitstream pulse width.<br>1'b0: Minimum number of cycles<br>1'b1: Average number of cycles, that is (max+min)/4. |
| 0     | RW   | 0x1         | BYPASS<br>Write 1'b1 to enable CDR non-jitter bypass mode. It's recommended that this bit set to 1'b1. Please ensure that this bit is set to 1'b1 before starting receiving data.                                   |

**SPDIF RX CDRST**

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

| Bit   | Attr | Reset Value | Description                                                                                                                                                          |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x03ff      | NOSTRTHR<br>The threshold counter determines the latency between input bitstream idle and exit synchronous status. Make sure that this value is large than 16'h03ff. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------|
| 15:8       | RO          | 0x00               | MAXCNT<br>The value indicates the number of reference clock cycles to oversample the maximum pulse width of bitstream. |
| 7:0        | RO          | 0xff               | MINCNT<br>The value indicates the number of reference clock cycles to oversample the minimum pulse width of bitstream. |

### **SPDIF RX DMACR**

Address: Operational Base(0xFF3B0000) + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                  |
| 5          | RW          | 0x0                | RDE<br>1'b0: Receive DMA disabled<br>1'b1: Receive DMA enabled                                                                                                                                                                                                            |
| 4: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 sample date buffer is equal to or above this field value + 1. |

### **SPDIF RX FIFOCTRL**

Address: Operational Base(0xFF3B0000) + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 31:14      | RO          | 0x000000           | reserved                                                                                                                                     |
| 13:8       | RO          | 0x00               | RFL<br>Contains the number of valid data entries in the receive FIFO.                                                                        |
| 7:5        | RO          | 0x0                | reserved                                                                                                                                     |
| 4:0        | RW          | 0x00               | RFT<br>When the number of receive FIFO entries is more than or equal to this threshold plus 1, the receive FIFO full interrupt is triggered. |

### **SPDIF RX INTEN**

Address: Operational Base(0xFF3B0000) + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 31:14      | RO          | 0x000000           | reserved                                                                                                                                    |
| 13         | RW          | 0x0                | CHERRIE<br>1'b0: Disable<br>1'b1: Enable<br>If enabled, an interrupt will generate if current data channel err.                             |
| 12         | RW          | 0x0                | TYPEIE<br>1'b0: Disable<br>1'b1: Enable<br>If enabled, an interrupt will generate if current type bit is different from previous one.       |
| 11         | RW          | 0x0                | VCGIE<br>1'b0: Disable<br>1'b1: Enable<br>If enabled, an interrupt will generate if current valid width bit is different from previous one. |
| 10         | RW          | 0x0                | UBCIE<br>1'b0: Disable<br>1'b1: Enable<br>If enabled, an interrupt will generate if current user bit is different from previous one.        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9          | RW          | 0x0                | ESYNCIE<br>1'b0: Disable<br>1'b1: Enable<br>If enabled, an interrupt will generate when entering synchronous state.                                                                                                                     |
| 8          | RW          | 0x0                | BTEIE<br>1'b0: Disable<br>1'b1: Enable<br>When enabled, an interrupt will generate when the block receive is finished if the channel conveys linear PCM or when the repetition period is reached if the channel conveys non-linear PCM. |
| 7          | RW          | 0x0                | NSYNCIE<br>1'b0: Disable<br>1'b1: Enable<br>If enabled, an interrupt will generate if CDR change from synchronization state to idle state.                                                                                              |
| 6          | RW          | 0x0                | BMDEIE<br>1'b0: Disable<br>1'b1: Enable<br>If enabled, an interrupt will generate if a biphase mark decoding error has occurred.                                                                                                        |
| 5          | RW          | 0x0                | RXOIE<br>1'b0: Disable<br>1'b1: Enable<br>If enabled, an interrupt will generate if FIFO is overrun.                                                                                                                                    |
| 4          | RW          | 0x0                | RXFIE<br>1'b0: Disable<br>1'b1: Enable<br>If enabled, an interrupt will generate if FIFO is full.                                                                                                                                       |
| 3          | RW          | 0x0                | NPSPIE<br>1'b0: Disable<br>1'b1: Enable<br>If enabled, an interrupt will generate if non-liner PCM sync word is received.                                                                                                               |
| 2          | RW          | 0x0                | NVLDIE<br>1'b0: Disable<br>1'b1: Enable<br>If enabled, an interrupt will generate if validity bit received from bitstream is 1'b1.                                                                                                      |
| 1          | RW          | 0x0                | CSCIE<br>1'b0: Disable<br>1'b1: Enable<br>If enabled, an interrupt will generate if current channel status bit is different from previous one.                                                                                          |
| 0          | RW          | 0x0                | PEIE<br>1'b0: Disable<br>1'b1: Enable<br>If enabled, an interrupt will generate if a parity error has occurred.                                                                                                                         |

**SPDIF RX INTMASK**

Address: Operational Base(0xFF3B0000) + offset (0x0020)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                      |
|------------|-------------|--------------------|-----------------------------------------|
| 13         | RW          | 0x0                | CHERRMASK<br>1'b0: Unmask<br>1'b1: Mask |
| 12         | RW          | 0x0                | TYPEMASK<br>1'b0: Unmask<br>1'b1: Mask  |
| 11         | RW          | 0x0                | VCGMASK<br>1'b0: Unmask<br>1'b1: Mask   |
| 10         | RW          | 0x0                | UBCIMSK<br>1'b0: Unmask<br>1'b1: Mask   |
| 9          | RW          | 0x0                | ESYNCIMSK<br>1'b0: Unmask<br>1'b1: Mask |
| 8          | RW          | 0x0                | BTEIMSK<br>1'b0: Unmask<br>1'b1: Mask   |
| 7          | RW          | 0x0                | NSYNCIMSK<br>1'b0: Unmask<br>1'b1: Mask |
| 6          | RW          | 0x0                | BMDEIMSK<br>1'b0: Unmask<br>1'b1: Mask  |
| 5          | RW          | 0x0                | RXOIMSK<br>1'b0: Unmask<br>1'b1: Mask   |
| 4          | RW          | 0x0                | RXFIMSK<br>1'b0: Unmask<br>1'b1: Mask   |
| 3          | RW          | 0x0                | NPSPIMSK<br>1'b0: Unmask<br>1'b1: Mask  |
| 2          | RW          | 0x0                | NVLDIMSK<br>1'b0: Unmask<br>1'b1: Mask  |
| 1          | RW          | 0x0                | CSCIMSK<br>1'b0: Unmask<br>1'b1: Mask   |
| 0          | RW          | 0x0                | PEIMSK<br>1'b0: Unmask<br>1'b1: Mask    |

**SPDIF RX INSR**

Address: Operational Base(0xFF3B0000) + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:14      | RO          | 0x00000            | reserved                                   |
| 13         | RW          | 0x0                | CHERRISR<br>1'b0: Inactive<br>1'b1: Active |
| 12         | RW          | 0x0                | TYPEISR<br>1'b0: Inactive<br>1'b1: Active  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 11         | RW          | 0x0                | VCGISR<br>1'b0: Inactive<br>1'b1: Active   |
| 10         | RO          | 0x0                | UBCISR<br>1'b0: Inactive<br>1'b1: Active   |
| 9          | RO          | 0x0                | ESYNCISR<br>1'b0: Inactive<br>1'b1: Active |
| 8          | RO          | 0x0                | BTEISR<br>1'b0: Inactive<br>1'b1: Active   |
| 7          | RO          | 0x0                | NSYNCISR<br>1'b0: Inactive<br>1'b1: Active |
| 6          | RO          | 0x0                | BMDEISR<br>1'b0: Inactive<br>1'b1: Active  |
| 5          | RO          | 0x0                | RXOIS<br>1'b0: Inactive<br>1'b1: Active    |
| 4          | RO          | 0x0                | RXFIS<br>1'b0: Inactive<br>1'b1: Active    |
| 3          | RO          | 0x0                | NPSPIS<br>1'b0: Inactive<br>1'b1: Active   |
| 2          | RO          | 0x0                | NVLDIS<br>1'b0: Inactive<br>1'b1: Active   |
| 1          | RO          | 0x0                | CSCIS<br>1'b0: Inactive<br>1'b1: Active    |
| 0          | RO          | 0x0                | PEIS<br>1'b0: Inactive<br>1'b1: Active     |

**SPDIF RX INTCLR**

Address: Operational Base(0xFF3B0000) + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------|
| 31:14      | RO          | 0x00000            | reserved                                                                      |
| 13         | RW          | 0x0                | CHERRICL<br>Write 1'b1 to clear user bit change interrupt.                    |
| 12         | RW          | 0x0                | TYPEICL<br>Write 1'b1 to clear user bit change interrupt.                     |
| 11         | RW          | 0x0                | VCGICL<br>Write 1'b1 to clear user bit change interrupt.                      |
| 10         | RW          | 0x0                | UBCICL<br>Write 1'b1 to clear user bit change interrupt.                      |
| 9          | RW          | 0x0                | ESYNCICL<br>Write 1'b1 to clear entering synchronous state interrupt.         |
| 8          | RW          | 0x0                | BTEICL<br>Write 1'b1 to clear block transfer/repetition period end interrupt. |
| 7          | RW          | 0x0                | NSYNCICL<br>Write 1'b1 to clear CDR not synchronization interrupt.            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------|
| 6          | RW          | 0x0                | BMDEICLR<br>Write 1'b1 to clear bi-phase mark decoding interrupt.           |
| 5          | RW          | 0x0                | RXOICLR<br>Write 1'b1 to clear receive overrun interrupt.                   |
| 4          | RW          | 0x0                | RXFICLR<br>Write 1'b1 to clear receive full interrupt.                      |
| 3          | RW          | 0x0                | NPSPICLR<br>Write 1'b1 to clear non-liner PCM sync word received interrupt. |
| 2          | RW          | 0x0                | NVLDICLR<br>Write 1'b1 to clear validity bit received interrupt.            |
| 1          | RW          | 0x0                | CSCICLR<br>Write 1'b1 to clear channel status change interrupt.             |
| 0          | RW          | 0x0                | PEICLR<br>Write 1'b1 to clear parity error interrupt.                       |

### **SPDIF RX SMPDR**

Address: Operational Base(0xFF3B0000) + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>            |
|------------|-------------|--------------------|-------------------------------|
| 31:0       | RO          | 0x00000000         | SMPDR<br>Sample Data Register |

### **SPDIF RX USRDRn**

Address: Operational Base(0xFF3B0000) + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                        |
|------------|-------------|--------------------|-------------------------------------------|
| 31:16      | RO          | 0x0000             | USR_SUB_1<br>User data bit for subframe 1 |
| 15:0       | RO          | 0x0000             | USR_SUB_0<br>User data bit for subframe 0 |

### **SPDIF RX CHNSRn**

Address: Operational Base(0xFF3B0000) + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 31:16      | RW          | 0x0000             | CHNSR_SUB_1<br>Channel status bit for subframe 1 |
| 15:0       | RO          | 0x0000             | CHNSR_SUB_0<br>Channel status bit for subframe 0 |

### **SPDIF RX CDR TIME**

Address: Operational Base(0xFF3B0000) + offset (0x0090)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                       |
|------------|-------------|--------------------|------------------------------------------|
| 31:16      | RW          | 0x03ff             | cdr_count_time<br>Count time cycle value |
| 15:0       | RW          | 0x03ff             | cdr_wait_time<br>Wait time cycle value   |

### **SPDIF RX RX STATUS**

Address: Operational Base(0xFF3B0000) + offset (0x0094)

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

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:5 | RW   | 0x0         | <p>CH1_DATA_VLD<br/>The S/PDIF word length for channel 1. May be decoded as follows (from the S/PDIF standard).</p> <ul style="list-style-type: none"> <li>0: Reserved</li> <li>1: Reserved</li> <li>2: SPDIF_LENGTH_16</li> <li>3: Reserved</li> <li>4: SPDIF_LENGTH_18</li> <li>5: SPDIF_LENGTH_22</li> <li>6: Reserved</li> <li>7: Reserved</li> <li>8: SPDIF_LENGTH_19</li> <li>9: SPDIF_LENGTH_23</li> <li>10: SPDIF_LENGTH_20</li> <li>11: SPDIF_LENGTH_24</li> <li>12: SPDIF_LENGTH_17</li> <li>13: SPDIF_LENGTH_21</li> <li>14: Reserved</li> <li>15: Reserved</li> </ul> |
| 4:1 | RW   | 0x0         | <p>CH0_DATA_VLD<br/>The S/PDIF word length for channel 0. May be decoded as follows (from the S/PDIF standard).</p> <ul style="list-style-type: none"> <li>0: Reserved</li> <li>1: Reserved</li> <li>2: SPDIF_LENGTH_16</li> <li>3: Reserved</li> <li>4: SPDIF_LENGTH_18</li> <li>5: SPDIF_LENGTH_22</li> <li>6: Reserved</li> <li>7: Reserved</li> <li>8: SPDIF_LENGTH_19</li> <li>9: SPDIF_LENGTH_23</li> <li>10: SPDIF_LENGTH_20</li> <li>11: SPDIF_LENGTH_24</li> <li>12: SPDIF_LENGTH_17</li> <li>13: SPDIF_LENGTH_21</li> <li>14: Reserved</li> <li>15: Reserved</li> </ul> |
| 0   | RW   | 0x0         | <p>AUDIO_TYPE<br/>0:PCM data<br/>1:Compressd data</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

**SPDIF RX BURTSINFO**

Address: Operational Base(0xFF3B0000) + offset (0x0100)

| Bit   | Attr | Reset Value | Description                                                                                                              |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | <p>PD<br/>Preamble Pd for non-linear PCM, indicating the length of burst payload in unit of bytes or bits.</p>           |
| 15:13 | RW   | 0x0         | <p>BSNUM<br/>This field indicates the bitstream number. Usually the bitstream number is 0.</p>                           |
| 12:8  | RO   | 0x00        | <p>DATAINFO<br/>This field gives the data-type-dependent info.</p>                                                       |
| 7     | RO   | 0x0         | <p>ERRFLAG<br/>1'b0: Indicates a valid burst-payload.<br/>1'b1: Indicates that the burst-payload may contain errors.</p> |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:0 | RO   | 0x00        | DATATYPE<br>7'b0000000: Null data<br>7'b0000001: AC-3 data<br>7'b0000011: Pause data<br>7'b0000100: MPEG-1 layer 1 data<br>7'b0000101: MPEG-1 layer 2 or 3 data or MPEG-2 without extension<br>7'b0000110: MPEG-2 data with extension<br>7'b0000111: MPEG-2 AAC<br>7'b0001000: MPEG-2, layer-1 low sampling frequency<br>7'b0001001: MPEG-2, layer-2 low sampling frequency<br>7'b0001010: MPEG-2, layer-3 low sampling frequency<br>7'b0001011: DTS type I<br>7'b0001100: DTS type II<br>7'b0001101: DTS type III<br>7'b0001110: ATRAC<br>7'b0001111: ATRAC 2/3<br>7'b0010000: ATRAC-X<br>7'b0010001: DTS type IV<br>7'b0010010: WMA professional type I<br>7'b0110010: WMA professional type II<br>7'b1010010: WMA professional type III<br>7'b1110010: WMA professional type IV<br>7'b0010011: MPEG-2 AAC low sampling frequency<br>7'b0110011: MPEG-2 AAC low sampling frequency<br>7'b1010011: MPEG-2 AAC low sampling frequency<br>7'b1110011: MPEG-2 AAC low sampling frequency<br>7'b0010100: MPEG-4 AAC<br>7'b0110100: MPEG-4 AAC<br>7'b1010100: MPEG-4 AAC<br>7'b1110100: MPEG-4 AAC<br>7'b0010101: Enhanced AC-3<br>7'b0010110: MAT<br>Others: Reserved |

## 26.5 Interface Description

Table 26-1 SPDIF RX Interface Description

| Module Pin | Direction | Rockchip matrix IO | IOMUX Setting |
|------------|-----------|--------------------|---------------|
| spdif_sdi  | O         | RM_IO              |               |

Notes: I=input, O=output, I/O=input/output. For the configuration of RM\_IO, please refer to chapter "Rockchip Matrix IO".

## 26.6 Application Notes



Fig.26-6 SPDIF receiver operation flow chart

The above figure shows the operation flow of SPDIF receiver operation.

## Chapter 27 Asynchronous Sample Rate Converter (ASRC)

### 27.1 Overview

ASRC converts digital audio data from one sample frequency to another. The input sample frequency can be an arbitrary fraction of the output frequency or the same frequency, but based on different clock sources. ASRC fetches audio data through AHB bus and acts as an intermediary for audio interfaces such as SAI, PDM, SPDIF, etc. With the help of ASRC, we can connect audio components with the embedded SOC platform together and provide an audio interface solution for the system.

#### 27.1.1 Features

- Support two 4-channel ASRC0/1
- Support series mode which combines adjacent ASRC (ASRC0~1) into maximum 8-channel
- Support one 32-bit AHB-Lite bus slave interface
- Support DMA handshaking interface and configurable DMA water level
- Support up to 4-channel with same ratio for ASRC0/1, which can be set to 2/4
- Support sample rate and resample rate range from 8 to 384KHz, mainly include three typical rate groups:
  - 1) 8KHz, 16KHz, 32KHz, 64KHz, 128KHz
  - 2) 12KHz, 24KHz, 48KHz, 96KHz, 192KHz, 384KHz
  - 3) 11.025KHz, 22.05KHz, 44.1KHz, 88.2KHz, 176.4KHz, 352.8KHz
- Support up-conversion, down-conversion, and 1:1 asynchronous conversion
- Support conversion ratio ranging from 1:8 (down) to 8:1 (up) with 22-bit resolution
- Support low deterministic latency related to ratio
- Support hard mute and soft mute
- Support typical THD+N below -120dB
- Support real-time transmission mode, which transmits or receives audio data from either audio component or memory with ratio tracking
- Support memory fetch mode, which transmits or receives audio data from memory with manual ratio without tracking
- Support input/output 16/20/24-bit wide audio data transfer
- Support two 16-bit audio data store together in one 32-bit wide location
- Support audio data left or right justified in 32-bit wide FIFO
- Support half channels internal 48-bit wide and 16-location deep FIFOs for transmitting, and half channels 48-bit wide and 64-location deep FIFOs for receiving audio data
- Support fixed and incremental address access to transmit and receive FIFOs
- Support ratio\_init/update\_done, asrc\_out\_start, conv\_done/error, fifo\_in\_empty/full, fifo\_out\_empty/full, ratio/src\_lrck/dst\_lrck\_unlock interrupt, which can be masked
- Support combined interrupt output

### 27.2 Block Diagram



Fig. 27-1 ASRC Block Diagram

#### System Interface

System interface implements the interactions with SOC platform. It contains not only AHB slave interface which controls registers and audio data transfer, but also LRCK interface, DMA handshaking interface and interrupt interface.

### **Clock Divider Block (CLK\_DIV)**

Clock divider block implements clock frequency divide function. The source clock of the divider block are src\_lrck and dst\_lrck, and by the divider, it generates clocks with the same frequency as sample rate or resample rate.

### **Register Block (REG)**

Register block is responsible for the main ASRC functionality including control, status and interrupt generation.

### **Controller Block (ASRC\_CTRL)**

Controller block is the main control block of variable sampling filter, its main functions include filtering output judgment, coefficient position calculation and interpolation filtering.

### **Ratio Detector Block (RATIO\_DET)**

The main function of ratio detector block is to initialize and track ratio related parameters. In the initialization stage, related parameters are fetched directly from register configuration. Then in the tracking stage, ratio tracking is realized through periodic detection of src\_lrck and dst\_lrck. In the meantime, the water level of output FIFO is monitored for negative feedback adjustment.

### **FIR Block (FIR\_FILTER)**

FIR block acts as a poly-phase filter, which interpolates the correct phase and applies the calculated filter coefficients to the set of input samples to form an output sample.

### **Inner FIFO Block (SYNC\_FIFO\_INNER)**

Inner FIFO block is the buffer to store audio data for FIR Filter. The size is 48bits x 512 and the number is half channels.

### **Input FIFO Block (ASYNC\_FIFO\_IN)**

Input FIFO block is the buffer to store received audio data. The size is 48bits x 16 and the number is half channels.

### **Output FIFO Block (ASYNC\_FIFO\_OUT)**

Output FIFO block is the buffer to store transmitted audio data. The size is 48bits x 64 and the number is half channels.

## **27.3 Function Description**

Firstly, we define two basic modes of ASRC, memory fetch mode and real-time transmission mode. Then to enhance throughput, we define an enhancement mode called series mode, which can combine adjacent ASRCs together.

### **27.3.1 Memory Fetch Mode**

In memory fetch mode, ASRC is working based on manual ratio, ratio tracking is disabled, so src\_lrck or dst\_lrck is unused. ASRC acts as peripheral when transmitting or receiving audio data from memory, so both dma\_tx\_req and dma\_rx\_req are started by ASRC. The faster the frequency of working clock, the faster the conversion will be completed.



Fig. 27-2 ASRC Memory Fetch Mode Structure

Based on memory fetch mode, we extend a new sub-pattern called loop mode. With loop mode, multiple discrete audio files can be converted by only one configuration, or one continuous audio files can be split into multiple parts and converted by one configuration. The most significant application of loop mode is to convert more channel real-time audio data than ASRC defined by time division multiplexing. Audio data in the middle part of file

should be recalled additionally for continuous output.

### 27.3.2 Real-time Transmission Mode

In real-time transmission mode, ASRC is working based on both manual ratio and tracking ratio, ratio tracking is enabled, so src\_lrck or dst\_lrck is needed. The faster the frequency of working clock, the more precise the tracking will be completed. Real-time transmission mode can be divided into four sub-patterns based on the component types at the source and destination ends, called MEM2MEM, MEM2DST, SRC2MEM and SRC2DST for short.

- **MEM2MEM**

In MEM2MEM mode, memory serves as both source and destination component. ASRC acts as peripheral when receiving audio data from memory or transmitting audio data to memory. Hence, both dma\_tx\_req and dma\_rx\_req are started by ASRC. Besides, both src\_lrck and dst\_lrck originate from CRU.



Fig. 27-3 ASRC MEM2MEM Mode Structure

- **MEM2DST**

In MEM2DST mode, memory serves as source component, and audio component serves as destination component. ASRC acts as peripheral when receiving audio data from memory, but as memory when transmitting audio data to peripheral. Hence, dma\_tx\_req is started by ASRC, but dma\_rx\_req is started by audio component. Besides, src\_lrck originates from CRU, but dst\_lrck originates from audio component.



Fig. 27-4 ASRC MEM2DST Mode Structure

- **SRC2MEM**

In SRC2MEM mode, audio component serves as source component, and memory serves as destination component. ASRC acts as memory when receiving audio data from audio component, but as peripheral when transmitting audio data to memory. Hence, dma\_tx\_req is started by audio component, but dma\_rx\_req is started by ASRC. Besides, src\_lrck originates from audio component, but dst\_lrck originates from CRU.



Fig. 27-5 ASRC SRC2MEM Mode Structure

### ● SRC2DST

In SRC2DST mode, audio component serves as both source component and destination component. ASRC acts as memory when receiving audio data from audio component or transmitting audio data to audio component. Hence, both `dma_tx_req` and `dma_rx_req` are started by audio component. Besides, both `src_lrck` and `dst_lrck` originate from audio component.



Fig. 27-6 ASRC SRC2DST Mode Structure

### 27.3.3 Series Mode

In series mode, adjacent ASRCs can be combined together to enhance throughput. We can appoint the ASRC at the front as master and other ASRCs as slave. All combined ASRCs can be viewed as a whole and interact with the outside world using the interface of master only. We can take MEM2MEM series mode as an example in the following figure. Note, the letter M stands for master and the letter S stands for slave.



Fig. 27-7 ASRC MEM2MEM Series Mode Structure

In RK3506, ASRC0 and ASRC1 can be combined together into maximum 8-channel.

### 27.3.4 ASRC Latency

In real-time transmission mode, the latency of ASRC is determined by the phase delay of the FIR filter and fill level of the FIFO. For any given configuration and ratio, the latency of ASRC is fixed as follow:

$$\text{Latency} = \text{phase delay} + \text{FIFO delay}$$

Where phase delay equals 32 input sample periods when ratio is not more than one, or equals  $(32 * \text{ratio})$  input sample periods otherwise. FIFO delay equals  $(\text{asrc\_in\_thresh} + 1)$

input sample periods plus (asrc\_out\_thresh+1) output sample periods.

In memory fetch mode, the conversion will be completed as fast as possible according to working clock only, regardless of src\_lrck and dst\_lrck, the latency can be ignored.

## 27.4 Register Description

### 27.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

**Operational Base**

| Name                  | Base Address |
|-----------------------|--------------|
| ASRC4CH0 base address | 0xFF3C0000   |
| ASRC4CH1 base address | 0xFF3D0000   |

### 27.4.2 Registers Summary

| Name                   | Offset | Size | Reset Value | Description                                 |
|------------------------|--------|------|-------------|---------------------------------------------|
| ASRC VERSION           | 0x0000 | W    | 0x01010000  | Version register                            |
| ASRC ASRC CON          | 0x0004 | W    | 0x00280030  | ASRC control register                       |
| ASRC CLKDIV CON        | 0x0008 | W    | 0x00000000  | LRCK divider control register               |
| ASRC DATA FMT          | 0x000C | W    | 0x00000000  | Data format register                        |
| ASRC LOOP CON0         | 0x0010 | W    | 0x00000000  | Loop control register 0                     |
| ASRC LOOP CON1         | 0x0014 | W    | 0x00000000  | Loop control register 1                     |
| ASRC LOOP CON2         | 0x0018 | W    | 0x00000000  | Loop control register 2                     |
| ASRC MANUAL RATIO      | 0x0020 | W    | 0x00000000  | Manual ratio register                       |
| ASRC SAMPLE RATE       | 0x0024 | W    | 0x0002EE00  | Sample rate register                        |
| ASRC RESAMPLE RATE     | 0x0028 | W    | 0x0002EE00  | Resample rate register                      |
| ASRC TRACK PERIOD      | 0x002C | W    | 0x000003FF  | Track period register                       |
| ASRC RATIO MARGIN      | 0x0030 | W    | 0x03FFFF    | Ratio margin register                       |
| ASRC LRCK MARGIN       | 0x0034 | W    | 0x7FFF7FFF  | LRCK margin register                        |
| ASRC FETCH LEN         | 0x0040 | W    | 0x3F000000  | Fetch length register                       |
| ASRC DMA THRESH        | 0x0050 | W    | 0xEC40B333  | DMA thresh register                         |
| ASRC INT CON           | 0x0060 | W    | 0x00000000  | Interrupt control register                  |
| ASRC INT ST            | 0x0064 | W    | 0x00000000  | Interrupt status register                   |
| ASRC ASRC ST0          | 0x0070 | W    | 0x00000000  | ASRC status register 0                      |
| ASRC ASRC ST1          | 0x0074 | W    | 0x00000000  | ASRC status register 1                      |
| ASRC RATIO ST          | 0x0080 | W    | 0x00000000  | Ratio status register                       |
| ASRC RESAMPLE RATE ST  | 0x0084 | W    | 0x00000000  | Resample rate status register               |
| ASRC THETA CNT ST      | 0x0090 | W    | 0x00000000  | Theta counter status register               |
| ASRC DECI THETA ACC ST | 0x0094 | W    | 0x00000000  | Decimal theta accumulator status register   |
| ASRC FIFO IN WRCNT     | 0x00A0 | W    | 0x00000000  | Input FIFO write counter register           |
| ASRC FIFO IN RDCNT     | 0x00A4 | W    | 0x00000000  | Input FIFO read counter register            |
| ASRC FIFO OUT WRCNT    | 0x00B0 | W    | 0x00000000  | Output FIFO write counter register          |
| ASRC FIFO OUT RDCNT    | 0x00B4 | W    | 0x00000000  | Output FIFO read counter register           |
| ASRC FIFO IN FIXED DR  | 0x00C0 | W    | 0x00000000  | Input FIFO fixed address data register      |
| ASRC FIFO OUT FIXED DR | 0x00C4 | W    | 0x00000000  | Output FIFO fixed address data register     |
| ASRC FIFO IN INCR DR   | 0x1000 | W    | 0x00000000  | Input FIFO increment address data register  |
| ASRC FIFO OUT INCR DR  | 0x5000 | W    | 0x00000000  | Output FIFO increment address data 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

### 27.4.3 Detail Registers Description

#### ASRC VERSION

Address: **Operational Base** + offset (0x0000)

| Bit  | Attr | Reset Value | Description                     |
|------|------|-------------|---------------------------------|
| 31:0 | RO   | 0x01010000  | version<br>ASRC version number. |

#### ASRC ASRC CON

Address: **Operational Base** + offset (0x0004)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                     |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | RW   | 0x0         | soft_mute_en<br>Soft mute enable. Each lane is controlled independently, bit 0~3 is corresponding to lane 0~3.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                 |
| 27:24 | RW   | 0x0         | hard_mute_en<br>Hard mute enable. Each lane is controlled independently, bit 0~3 is corresponding to lane 0~3.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                 |
| 23:22 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                        |
| 21:20 | RW   | 0x2         | ratio_filt_win<br>Ratio filter sliding window select.<br>2'b00: window width 2<br>2'b01: window width 4<br>2'b10: window width 8<br>2'b11: window width 16                                                                                                      |
| 19    | RW   | 0x1         | ratio_track_mode<br>Ratio track mode select.<br>1'b0: Update src_lrck_cnt and dst_lrck_cnt once track period reached<br>1'b1: Update src_lrck_cnt and dst_lrck_cnt only when track period reached and the value change by more than one from the previous value |
| 18    | RW   | 0x0         | ratio_exc_dis<br>Ratio exceed detect disable. This bit works only when ratio_track_dis equal 0.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                |
| 17    | RW   | 0x0         | ratio_filt_dis<br>Ratio track filter disable. This bit works only when ratio_track_dis equal 0.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                |
| 16    | RW   | 0x0         | ratio_track_dis<br>Ratio track disable.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                        |
| 15    | RW   | 0x0         | series_rx_apart<br>ASRC series enable but use respective rx request.                                                                                                                                                                                            |
| 14    | RW   | 0x0         | series_tx_apart<br>ASRC series enable but use respective tx request.                                                                                                                                                                                            |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                   |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:12 | RW   | 0x0         | series_en<br>ASRC series enable.<br>2'b00: series disable<br>2'b01: serve as series master<br>2'b10: serve as series slave                                                                                                                                                                                                                                                    |
| 11    | RW   | 0x0         | series_post_end<br>ASRC series post end flag. This bit works only when asrc_mode equal 1.                                                                                                                                                                                                                                                                                     |
| 10    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                      |
| 9     | RW   | 0x0         | asrc_out_stop<br>ASRC stop transmitting data to destination component. This bit works only when asrc_mode equal 0.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                                           |
| 8     | RW   | 0x0         | asrc_in_stop<br>ASRC stop receiving data from source component. This bit works only when asrc_mode equal 0.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                                                  |
| 7:6   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                      |
| 5:4   | RW   | 0x3         | chan_num<br>Channel number select.<br>2'b00: 2 channel used<br>2'b01: 4 channel used<br>2'b10: 6 channel used<br>2'b11: 8 channel used                                                                                                                                                                                                                                        |
| 3:2   | RW   | 0x0         | real_time_mode<br>Real-time transmission mode select. This bit works only when asrc_mode equal 0.<br>2'b00: Memory as both source and destination component<br>2'b01: Peripheral as source component, Memory as destination component<br>2'b10: Memory as source component, Peripheral as destination component<br>2'b11: Peripheral as both source and destination component |
| 1     | RW   | 0x0         | asrc_mode<br>ASRC mode select.<br>1'b0: Real-time transmission mode<br>1'b1: Memory fetch mode                                                                                                                                                                                                                                                                                |
| 0     | RW   | 0x0         | asrc_en<br>ASRC enable.<br>1'b0: Disable<br>1'b1: Enable<br>In loop mode, this bit must be set after loop_en. When asrc_en equal 0, FIFOs in ASRC are self-cleared.                                                                                                                                                                                                           |

**ASRC CLKDIV CON**

Address: Operational Base + offset (0x0008)

| Bit   | Attr | Reset Value | Description                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------|
| 31    | RW   | 0x0         | dst_lrck_div_en<br>dst_lrck divider enable.<br>1'b0: Disable<br>1'b1: Enable      |
| 30:16 | RW   | 0x0000      | dst_lrck_div_con<br>dst_lrck divider. dst_lrck_div_con=Fdst_lrck/resample_rate-1. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 15         | RW          | 0x0                | src_lrck_div_en<br>src_lrck divider enable.<br>1'b0: Disable<br>1'b1: Enable    |
| 14:0       | RW          | 0x0000             | src_lrck_div_con<br>src_lrck divider. src_lrck_div_con=Fsrc_lrck/sample_rate-1. |

### **ASRC DATA FMT**

Address: **Operational Base** + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                                                                                                                                                              |
| 28:24      | RW          | 0x00               | OSJM<br>Output data store justified mode, which indicate LSB of output data.                                                                                                                          |
| 23:21      | RO          | 0x0                | reserved                                                                                                                                                                                              |
| 20:16      | RW          | 0x00               | ISJM<br>Input data store justified mode, which indicate LSB of input data.                                                                                                                            |
| 15:13      | RO          | 0x0                | reserved                                                                                                                                                                                              |
| 12         | RW          | 0x0                | OFMT<br>Output data format.<br>1'b0: low bits data valid to AHB bus, high bits data invalid.<br>1'b1: 32 bit data valid to AHB bus. Low 16 bit for left channel and high 16 bit for right channel.    |
| 11:9       | RO          | 0x0                | reserved                                                                                                                                                                                              |
| 8          | RW          | 0x0                | IFMT<br>Input data format.<br>1'b0: low bits data valid from AHB bus, high bits data invalid.<br>1'b1: 32 bit data valid from AHB bus. Low 16 bit for left channel and high 16 bit for right channel. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                              |
| 5:4        | RW          | 0x0                | OWL<br>Output data bit wide.<br>2'b00: 24 bits<br>2'b01: 20 bits<br>2'b10: 16 bits<br>2'b01: Reserved                                                                                                 |
| 3:2        | RO          | 0x0                | reserved                                                                                                                                                                                              |
| 1:0        | RW          | 0x0                | IWL<br>Input data bit wide.<br>2'b00: 24 bits<br>2'b01: 20 bits<br>2'b10: 16 bits<br>2'b01: Reserved                                                                                                  |

### **ASRC LOOP CON0**

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                             |
| 15:8       | RW          | 0x00               | loop_end_con<br>Loop end mode. Each loop is controlled independently, bit 0~7 is corresponding to loop time 0~7.<br>1'b0: Convert the end part of a file<br>1'b1: Not convert the end part of a file |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0        | R/W<br>SC   | 0x00               | loop_start_con<br>Loop start mode. Each loop is controlled independently, bit 0~7 is corresponding to loop time 0~7.<br>1'b0: Convert the start part of a file<br>1'b1: Not convert the start part of a file |

**ASRC LOOP CON1**Address: **Operational Base** + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------|
| 31:11      | RO          | 0x000000           | reserved                                                                                                                   |
| 10:8       | RW          | 0x0                | chan_times<br>Channel times, which means the actual channel to be converted is (chan_times+1) much as (chan_num+1).        |
| 7          | RO          | 0x0                | reserved                                                                                                                   |
| 6:4        | RW          | 0x0                | loop_times<br>Loop times, which means (loop_times+1) conversion is done continuously.                                      |
| 3:1        | RO          | 0x0                | reserved                                                                                                                   |
| 0          | R/W<br>SC   | 0x0                | loop_en<br>ASRC loop enable. This bit is automatically cleared when loop conversion done.<br>1'b0: Disable<br>1'b1: Enable |

**ASRC LOOP CON2**Address: **Operational Base** + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                 |
| 15:0       | R/W<br>SC   | 0x0000             | loop_gap_thresh<br>ASRC loop gap thresh, which sets the interval between two conversion. |

**ASRC MANUAL RATIO**Address: **Operational Base** + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:26      | RO          | 0x00               | reserved                                                                                                                                                        |
| 25:0       | RW          | 0x00000000         | manual_ratio<br>Manual ratio with fixed-point 26Q22. High 4 bits shows integer part, low 22 bits shows decimal part.<br>manual_ratio=sample_rate/resample_rate. |

**ASRC SAMPLE RATE**Address: **Operational Base** + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 31:19      | RO          | 0x0000             | reserved                                               |
| 18:0       | RW          | 0x2ee00            | sample_rate<br>Sample rate ranges from 8KHz to 384KHz. |

**ASRC RESAMPLE RATE**Address: **Operational Base** + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:19      | RO          | 0x0000             | reserved                                                   |
| 18:0       | RW          | 0x2ee00            | resample_rate<br>Resample rate ranges from 8KHz to 384KHz. |

**ASRC TRACK PERIOD**Address: **Operational Base** + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                                                   |
| 27:16      | RW          | 0x000              | ratio_track_div<br>Ratio track divider, which scale down the frequency of src_lrck and dst_lrck for higher precision of ratio tracking.    |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                   |
| 11:0       | RW          | 0x3ff              | ratio_track_period<br>Ratio track period, which means tracking information updates every (ratio_track_period+1)*(ratio_track_div+1) clock. |

**ASRC RATIO MARGIN**Address: **Operational Base** + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22      | RO          | 0x000              | reserved                                                                                                                                                                                |
| 21:0       | RW          | 0x3fffff           | ratio_margin<br>Ratio margin with fixed-point 22Q22, which shows decimal part of ratio. Ratio unlock occurs when the difference between ratio_st and manual_ratio exceeds ratio_margin. |

**ASRC LRCK MARGIN**Address: **Operational Base** + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | dst_lrck_margin_dis<br>Dst_lrck drift detect disable.<br>1'b0: Disable<br>1'b1: Enable                                   |
| 30:16      | RW          | 0x7fff             | dst_lrck_margin<br>Dst_lrck drift margin. Dst_lrck unlock occurs when the variation of dst_lrck exceeds dst_lrck_margin. |
| 15         | RW          | 0x0                | src_lrck_margin_dis<br>Src_lrck drift detect disable.<br>1'b0: Disable<br>1'b1: Enable                                   |
| 14:0       | RW          | 0x7fff             | src_lrck_margin<br>Src_lrck drift margin. Src_lrck unlock occurs when the variation of src_lrck exceeds src_lrck_margin. |

**ASRC FETCH LEN**Address: **Operational Base** + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RW          | 0x3f               | mem_fetch_ext_cnt<br>Memory fetch extend counter, is used only when asrc_mode equal 1. It extends the interval of filter operation, which works only when series_en not equal 0.                                                                                                                                                                             |
| 23:20      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                     |
| 19:0       | RW          | 0x00000            | fetch_length<br>Memory fetch length, is used only when asrc_mode equal 1. It indicates the number of input data per channel. As input data is written by AHB bus in word, if the number written is called INPUT_WORD_NUM, the equation is as follows:<br>$\text{fetch\_length} = \text{INPUT\_WORD\_NUM} * (\text{IFMT} + 1) / (2 * (\text{chan\_num} + 1))$ |

**ASRC DMA THRESH**Address: **Operational Base** + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:26      | RW          | 0x3b               | asrc_pos_thresh<br>Output FIFO positive thresh, unit channel_num.<br>Exceed positive occurs once the number of valid data entries in the output FIFO is above this field value.<br>Note, asrc_pos_thresh had better be higher than 59.      |
| 25:20      | RW          | 0x04               | asrc_neg_thresh<br>Output FIFO negative thresh, unit channel_num.<br>Exceed negative occurs once the number of valid data entries in the output FIFO is below this field value.<br>Note, asrc_neg_thresh had better be lower than 4.        |
| 19:18      | RO          | 0x0                | reserved                                                                                                                                                                                                                                    |
| 17:12      | RW          | 0x0b               | asrc_out_thresh<br>ASRC start output thresh, unit channel_num.<br>Output will start once the number of valid data entries in the output FIFO is above this field value.<br>Note, asrc_out_thresh must be higher than dma_rx_thresh.         |
| 11:8       | RW          | 0x3                | asrc_in_thresh<br>ASRC start conversion thresh, unit channel_num.<br>Conversion will start once the number of valid data entries in the input FIFO is above this field value.<br>Note, asrc_in_thresh must be no more than dma_tx_thresh.   |
| 7:4        | RW          | 0x3                | dma_rx_thresh<br>DMA rx request thresh, unit channel_num.<br>The watermark level = dma_rx_thresh+1; that is, dma_rx_req is generated when the number of valid data entries in the output FIFO is equal to or above this field value + 1.    |
| 3:0        | RW          | 0x3                | dma_tx_thresh<br>DMA tx request thresh, unit channel_num.<br>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 input FIFO is equal to or below this field value. |

**ASRC INT CON**Address: **Operational Base** + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------|
| 31:13      | RO          | 0x00000            | reserved                                                                                  |
| 12         | RW          | 0x0                | dst_lrck_unlock_en<br>Enable dst_lrck unlock interrupt.<br>1'b0: Disable<br>1'b1: Enable  |
| 11         | RW          | 0x0                | src_lrck_unlock_en<br>Enable src_lrck unlock interrupt.<br>1'b0: Disable<br>1'b1: Enable  |
| 10         | RW          | 0x0                | ratio_unlock_en<br>Enable ratio unlock interrupt.<br>1'b0: Disable<br>1'b1: Enable        |
| 9          | RW          | 0x0                | fifo_out_empty_en<br>Enable output FIFO empty interrupt.<br>1'b0: Disable<br>1'b1: Enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------|
| 8          | RW          | 0x0                | fifo_out_full_en<br>Enable output FIFO full interrupt.<br>1'b0: Disable<br>1'b1: Enable      |
| 7          | RW          | 0x0                | fifo_in_empty_en<br>Enable input FIFO empty interrupt.<br>1'b0: Disable<br>1'b1: Enable      |
| 6          | RW          | 0x0                | fifo_in_full_en<br>Enable input FIFO full interrupt.<br>1'b0: Disable<br>1'b1: Enable        |
| 5          | RW          | 0x0                | ratio_update_done_en<br>Enable ratio update done interrupt.<br>1'b0: Disable<br>1'b1: Enable |
| 4          | RW          | 0x0                | ratio_change_done_en<br>Enable ratio change done interrupt.<br>1'b0: Disable<br>1'b1: Enable |
| 3          | RW          | 0x0                | ratio_init_done_en<br>Enable ratio initial done interrupt.<br>1'b0: Disable<br>1'b1: Enable  |
| 2          | RW          | 0x0                | conv_error_en<br>Enable conversion error interrupt.<br>1'b0: Disable<br>1'b1: Enable         |
| 1          | RW          | 0x0                | conv_done_en<br>Enable conversion done interrupt.<br>1'b0: Disable<br>1'b1: Enable           |
| 0          | RW          | 0x0                | asrc_out_start_en<br>Enable ASRC output start interrupt.<br>1'b0: Disable<br>1'b1: Enable    |

**ASRC INT ST**Address: **Operational Base** + offset (0x0064)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 31:13      | RO          | 0x00000            | reserved                                                                                                                             |
| 12         | RO          | 0x0                | dst_lrck_unlock_st<br>Dst_Lrck unlock interrupt status.<br>Level interrupt which can be clear by mask dst_lrck_unlock_en of INT_CON. |
| 11         | RO          | 0x0                | src_lrck_unlock_st<br>Src_Lrck unlock interrupt status.<br>Level interrupt which can be clear by mask src_lrck_unlock_en of INT_CON. |
| 10         | RO          | 0x0                | ratio_unlock_st<br>Ratio unlock interrupt status.<br>Level interrupt which can be clear by mask ratio_unlock_en of INT_CON.          |
| 9          | W1 C        | 0x0                | fifo_out_empty_st<br>Output FIFO empty interrupt status.                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 8          | W1<br>C     | 0x0                | fifo_out_full_st<br>Output FIFO full interrupt status.                                                                                  |
| 7          | W1<br>C     | 0x0                | fifo_in_empty_st<br>Input FIFO empty interrupt status.                                                                                  |
| 6          | W1<br>C     | 0x0                | fifo_in_full_st<br>Input FIFO full interrupt status.                                                                                    |
| 5          | W1<br>C     | 0x0                | ratio_update_done_st<br>Ratio update interrupt status.                                                                                  |
| 4          | W1<br>C     | 0x0                | ratio_change_done_st<br>Ratio change interrupt status.                                                                                  |
| 3          | RO          | 0x0                | ratio_init_done_st<br>Ratio initial done interrupt status.<br>Level interrupt which can be clear by mask ratio_init_done_en of INT_CON. |
| 2          | W1<br>C     | 0x0                | conv_error_st<br>Conversion error interrupt status.                                                                                     |
| 1          | RO          | 0x0                | conv_done_st<br>Conversion done interrupt status.<br>Level interrupt which can be clear by mask conv_done_en of INT_CON.                |
| 0          | RO          | 0x0                | asrc_out_start_st<br>ASRC output start interrupt status.<br>Level interrupt which can be clear by mask asrc_out_start_en of INT_CON.    |

#### **ASRC\_ASRC\_ST0**

Address: **Operational Base** + offset (0x0070)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:13      | RO          | 0x00000            | reserved                                                      |
| 12:8       | RO          | 0x00               | chan_num_series<br>Used channel number status in series mode. |
| 7          | RO          | 0x0                | dma_rx_ack<br>DMA rx acknowledge status.                      |
| 6          | RO          | 0x0                | dma_rx_req<br>DMA rx request status.                          |
| 5          | RO          | 0x0                | dma_tx_ack<br>DMA tx acknowledge status.                      |
| 4          | RO          | 0x0                | dma_tx_req<br>DMA tx request status.                          |
| 3          | RO          | 0x0                | reserved                                                      |
| 2          | RO          | 0x0                | filt_delay_done<br>ASRC filter delay done status.             |
| 1          | RO          | 0x0                | asrc_out_start<br>ASRC out start status.                      |
| 0          | RO          | 0x0                | asrc_in_start<br>ASRC in start status.                        |

#### **ASRC\_ASRC\_ST1**

Address: **Operational Base** + offset (0x0074)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | ratio_state<br>Ratio track state.<br>2'h0: IDLE<br>2'h1: RATIO_INIT<br>2'h2: RATIO_TRACK<br>2'h3: RATIO_STOP          |
| 29         | RO          | 0x0                | exceed_pos<br>Output FIFO positive exceed status.                                                                     |
| 28         | RO          | 0x0                | exceed_neg<br>Output FIFO negative exceed status.                                                                     |
| 27:26      | RO          | 0x0                | reserved                                                                                                              |
| 25:20      | RO          | 0x00               | pos_thresh<br>Output FIFO positive thresh status, unit channel_num.                                                   |
| 19:18      | RO          | 0x0                | reserved                                                                                                              |
| 17:12      | RO          | 0x00               | neg_thresh<br>Output FIFO negative thresh status, unit channel_num.                                                   |
| 11:10      | RO          | 0x0                | reserved                                                                                                              |
| 9:4        | RO          | 0x00               | fifo_out_level<br>Output FIFO level, contains the number of valid data entries in the receive FIFO, unit channel_num. |
| 3:0        | RO          | 0x0                | fifo_in_level<br>Input FIFO level, contains the number of valid data entries in the transmit FIFO, unit channel_num.  |

#### **ASRC RATIO ST**

Address: **Operational Base** + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 31:26      | RO          | 0x00               | reserved                                                                                                            |
| 25:0       | RO          | 0x00000000         | ratio_st<br>Calculate ratio with fixed-point 26Q22. High 4 bits shows integer part, low 22 bits shows decimal part. |

#### **ASRC RESAMPLE RATE ST**

Address: **Operational Base** + offset (0x0084)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:19      | RO          | 0x0000             | reserved                                            |
| 18:0       | RO          | 0x000000           | resample_rate_st<br>Calculate resample rate status. |

#### **ASRC THETA CNT ST**

Address: **Operational Base** + offset (0x0090)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                    |
|------------|-------------|--------------------|---------------------------------------|
| 31:26      | RO          | 0x00               | reserved                              |
| 25:0       | RO          | 0x00000000         | theta_cnt_st<br>Theta counter status. |

#### **ASRC DECI THETA ACC ST**

Address: **Operational Base** + offset (0x0094)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 31:19      | RO          | 0x0000             | reserved                                               |
| 18:0       | RO          | 0x000000           | deci_theta_acc_st<br>Decimal theta accumulator status. |

#### **ASRC FIFO IN WRCNT**

Address: **Operational Base** + offset (0x00A0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                            |
| 19:0       | RO          | 0x00000            | fifo_in_wrcnt<br>Input FIFO write counter status, unit channel_num. |

**ASRC FIFO IN RDCNT**Address: **Operational Base** + offset (0x00A4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                           |
| 19:0       | RO          | 0x00000            | fifo_in_rdcnt<br>Input FIFO read counter status, unit channel_num. |

**ASRC FIFO OUT WRCNT**Address: **Operational Base** + offset (0x00B0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                              |
| 19:0       | RO          | 0x00000            | fifo_out_wrcnt<br>Output FIFO write counter status, unit channel_num. |

**ASRC FIFO OUT RDCNT**Address: **Operational Base** + offset (0x00B4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                             |
| 19:0       | RO          | 0x00000            | fifo_out_rdcnt<br>Output FIFO read counter status, unit channel_num. |

**ASRC FIFO IN FIXED DR**Address: **Operational Base** + offset (0x00C0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | fifo_in_data<br>Input FIFO fixed address data register. |

**ASRC FIFO OUT FIXED DR**Address: **Operational Base** + offset (0x00C4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | fifo_out_data<br>Output FIFO fixed address data register. |

**ASRC FIFO IN INCR DR**Address: **Operational Base** + offset (0x1000)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | fifo_in_data<br>Input FIFO increment address data register, which ranges from 0x1000 to 0x4FFF. |

**ASRC FIFO OUT INCR DR**Address: **Operational Base** + offset (0x5000)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | fifo_out_data<br>Output FIFO increment address data register, which ranges from 0x5000 to x8FFF. |

## 27.5 Application Notes

### 27.5.1 LRCK Multiplexing Setting

There are src\_lrck and dst\_lrck interface which source from audio component or CRU. In real-time transmission mode, the following multiplexing selector need to be set.

Table 27-1 ASRC4ch0 Src\_lrck Selector Description

| Register Name    | MUX Setting | LRCK Source Select                                                                                                                                                                                                                                  |
|------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CRU_CLKSEL_CON47 | 3:0         | 5'd0: mclk_asrc0<br>5'd1: mclk_asrc1<br>5'd2: mclk_asrc2<br>5'd3: mclk_asrc3<br>5'd4: mclk_spdiftx_to_asrc<br>5'd5: mclk_spdifrx_to_asrc<br>5'd6: clkout_pdm<br>5'd7: sai0_fs<br>5'd8: sai1_fs<br>5'd9: sai2_fs<br>5'd10: sai3_fs<br>5'd11: sai4_fs |

Table 27-2 ASRC4ch0 Dst\_lrck Selector Description

| Register Name    | MUX Setting | LRCK Source Select                                                                                                                                                                                                                                  |
|------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CRU_CLKSEL_CON47 | 7:4         | 5'd0: mclk_asrc0<br>5'd1: mclk_asrc1<br>5'd2: mclk_asrc2<br>5'd3: mclk_asrc3<br>5'd4: mclk_spdiftx_to_asrc<br>5'd5: mclk_spdifrx_to_asrc<br>5'd6: clkout_pdm<br>5'd7: sai0_fs<br>5'd8: sai1_fs<br>5'd9: sai2_fs<br>5'd10: sai3_fs<br>5'd11: sai4_fs |

Table 27-3 ASRC4ch1 Src\_lrck Selector Description

| Register Name    | MUX Setting | LRCK Source Select                                                                                                                                                                                                                                  |
|------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CRU_CLKSEL_CON47 | 11:8        | 5'd0: mclk_asrc0<br>5'd1: mclk_asrc1<br>5'd2: mclk_asrc2<br>5'd3: mclk_asrc3<br>5'd4: mclk_spdiftx_to_asrc<br>5'd5: mclk_spdifrx_to_asrc<br>5'd6: clkout_pdm<br>5'd7: sai0_fs<br>5'd8: sai1_fs<br>5'd9: sai2_fs<br>5'd10: sai3_fs<br>5'd11: sai4_fs |

Table 27-4 ASRC4ch1 Dst\_lrck Selector Description

| Register Name    | MUX Setting | LRCK Source Select                                                                                         |
|------------------|-------------|------------------------------------------------------------------------------------------------------------|
| CRU_CLKSEL_CON47 | 15:12       | 5'd0: mclk_asrc0<br>5'd1: mclk_asrc1<br>5'd2: mclk_asrc2<br>5'd3: mclk_asrc3<br>5'd4: mclk_spdiftx_to_asrc |

| Register Name | MUX Setting | LRCK Source Select                                                                                                                    |
|---------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
|               |             | 5'd5: mclk_spdifrx_to_asrc<br>5'd6: clkout_pdm<br>5'd7: sai0_fs<br>5'd8: sai1_fs<br>5'd9: sai2_fs<br>5'd10: sai3_fs<br>5'd11: sai4_fs |

## 27.5.2 LRCK Divider Setting

In real-time transmission mode, src\_lrck and dst\_lrck are treated as data and sampled by working clock to realize periodic detection for ratio tracking. Frequency of src\_lrck must be the same as sample rate of audio data, and frequency of dst\_lrck must be the same as resample rate of audio data. To guarantee this, two clock dividers are integrating into ASRC. In the following condition, the corresponding divider ought to be set and we ought to wait for the generated clock to stabilize before starting ASRC.

- Using PDM as source component, set src\_lrck\_div\_con to (pdm\_oversample\_rate-1)
- Using SPDIF\_RX as source component, set src\_lrck\_div\_con to 127
- Using SPDIF\_TX as destination component, set dst\_lrck\_div\_con to (128\*spdiftx\_div-1)

## 27.5.3 Tracking Period Setting

In real-time transmission mode, ratio tracking is enabled. Tracking period is determined by the value of ratio\_track\_period and ratio\_track\_div, which means track information updates every (ratio\_track\_period+1)\*(ratio\_track\_div+1) working clock. The longer the period, the more precise the tracking. Besides, the following format must be meet to ensure ratio resolution:

$$(ratio\_track\_period+1)*(ratio\_track\_div+1) >=$$

$$TwClk*Fsrc_Irck*(1/Resolution+Fsrc_Irck/(Resolution*Fdst_Irck)+1)$$

Where TwClk is the period of working clock, Resolution is the bit wide of ratio, Fsrc\_Irck is the frequency of src\_lrck, and Fdst\_Irck is the frequency of dst\_lrck. Note that the smaller ratio\_track\_div is, the better, given the equation.

Besides, once lrck sources from CRU for audio component like USB or MAC, the fractional divider in the clock path of src\_lrck or dst\_lrck ought to be used for seamless switching. In this scenario, tracking period must be an integer multiple of the frequency division period, to guarantee ratio tracking accuracy.

## 27.5.4 DMA Setting

For transmitting data to ASRC and receiving data from ASRC, two DMA channels are need called DMA\_TX and DMA\_RX here. DMA mode used for various ASRC mode is shown below.

Table 27-5 ASRC DMA Mode Description

| ASRC Mode         | DMA_TX | DMA_RX |
|-------------------|--------|--------|
| Memory Fetch Mode | M2P    | P2M    |
| MEM2MEM           | M2P    | P2M    |
| MEM2DST           | M2P    | M2P    |
| SRC2MEM           | P2M    | P2M    |
| SRC2DST           | P2M    | M2P    |

In a word, once interacting with audio component, ASRC acts as memory and audio component issues DMA request, once interacting with memory, ASRC acts as peripheral and issues DMA request according to dma\_tx\_thresh and dma\_rx\_thresh.

Both dma\_tx\_thresh and dma\_rx\_thresh are in the unit of chan\_num. That is, the relation between real DMA burst (called dma\_tx/rx\_burst) and dma\_tx/rx\_thresh is shown below:

$$\text{dma\_tx\_thresh} = \text{dma\_tx\_burst} * (\text{IFMT}+1) / (\text{chan\_num}+1) / 2 - 1$$

$$\text{dma\_rx\_thresh} = \text{dma\_rx\_burst} * (\text{OFMT}+1) / (\text{chan\_num}+1) / 2 - 1$$

## 27.5.5 Memory Fetch Mode Setting

### ● Setting order

- Set and start DMA\_TX and DMA\_RX.
- Set and start ASRC.

- **ASRC start Flow**

- Set used channel number, chan\_num.
- Set data format, OFMT, IFMT, OWL, IWL, OSJM and ISJM.
- Set manual\_ratio, sample\_rate and resample\_rate.
- Set thresh, dma\_rx\_thresh, dma\_tx\_thresh, asrc\_out\_thresh and asrc\_in\_thresh;
- Set asrc\_mode to 1.
- Set conversion length, fetch\_length.
- Set conv\_done\_en to enable conversion done interrupt.
- In loop mode, set continuous conversion times (loop\_times), file channel number divided by used channel number (chan\_times), file type (loop\_start/end\_mode) and conversion interval (loop\_gap\_thresh), then enable loop\_en.
- Set asrc\_en to enable ASRC.

- **ASRC end Flow**

- Wait for conv\_done and DMA\_RX done interrupt.
- Set asrc\_en to disable ASRC.

### **27.5.6 Real-time Transmission Mode Setting**

- **Setting order**

- Set the source of src\_lrck and dst\_lrck.
- Set src\_lrck\_div\_con, src\_lrck\_div\_en, dst\_lrck\_div\_con, dst\_lrck\_div\_en if needed.
- Set and start DMA\_TX and DMA\_RX.
- Set and start ASRC; ASRC must be set before source and destination component to make sure audio data is aligned by channel.
- Set and start source component in the mode SRC2MEM or SRC2DST.
- Set and start destination component in the mode MEM2DST or SRC2DST.
- Destination component had better start when asrc\_out\_start interrupt assert which means destination data is ready.

- **ASRC start Flow**

- Set used channel number, chan\_num.
- Set data format, OFMT, IFMT, OWL, IWL, OSJM and ISJM.
- Set manual\_ratio, sample\_rate and resample\_rate.
- Set thresh, dma\_rx\_thresh, dma\_tx\_thresh, asrc\_out\_thresh and asrc\_in\_thresh.
- Set asrc\_mode to 0; set real\_time\_mode.
- Set ratio\_track\_period and ratio\_track\_div.
- Set ratio\_track\_dis to disable ratio tracking, ratio\_filt\_dis to disable ratio tracking filter, or ratio\_exc\_dis to disable ratio tracking feedback if needed.
- Set conv\_done\_en to enable conversion done interrupt.

- **ASRC end Flow**

- Set asrc\_in\_stop to end conversion if source component stop.
- Set asrc\_out\_stop to end conversion if destination component stop.
- Wait for conv\_done and DMA\_RX done interrupt.
- Set asrc\_en to disable ASRC.

### **27.5.7 Series Mode Setting**

In series mode, we can set each ASRC as mentioned above. Several additional setting is needed shown as follow:

- Set series\_en to appoint master and slave; Note that series\_en can't be set if series mode is disabled.
- Set series\_post\_end to appoint the last slave if memory fetch mode is selected.
- Set asrc\_en of the series master at the end after all other configurations are set.

The following table shows all the cascading combinations in RK3506. Note, the letter M stands for master and the letter S stands for slave.

Table 27-6 ASRC Series Description

| Series Setting             | Series Combination |
|----------------------------|--------------------|
| ASRC0_ASRC_CON[13:12]=2'h1 | ASRC0(M), ASRC1(S) |
| ASRC1_ASRC_CON[13:12]=2'h2 |                    |

## Chapter 28 Flexible Serial Peripheral Interface (FSPI)

### 28.1 Overview

The FSPI is a flexible serial peripheral interface host controller to interface with external device.

The FSPI supports the following features:

- Support various vendor devices with flexible command sequencer engine
  - Serial NOR Flash
  - Serial NAND Flash
  - Serial pSRAM
  - Serial SRAM
- Support SDR mode
- Support Single/Dual/Quad IO mode
- Support a 32-bit AHB slave to read and write controller register bank and initiate command sequence, including transfer data from/to external device indirectly
- Support a 32-bit AHB master with embedded DMA engine to transfer data from/to external device indirectly
- Support independent clock for system bus HCLK and controller core SCLK
- Support maskable interrupts generation
- Support sampling clock with optionally configurable delay line
- Support 1 CS# operation

### 28.2 Block Diagram



Fig. 28-1 FSPI Architecture

Memory-Mapped AHB slave is available when XIP feature is present. In current chip, this feature is not provided.

## 28.3 Function Description

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

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

### 28.3.3 REG File

The REG File is configurable register bank to control the store the static configuration and dynamic status of controller.

### 28.3.4 DMA CTRL

The block is responsible for splitting a long length transfer trans into AHB bus transaction and interfacing with ASYNC TX or RX FIFO.

### 28.3.5 FIFO

There are four FIFO in the FSPI controller. ASYNC TX FIFO and ASYNC RX FIFO is for normal transaction that initiated by command sequence driver. The ASYNC MM (Memory-Mapped) TX FIFO and ASYNC MM (Memory-Mapped) RX FIFO is only used to buffer DATA from or to external device initiated by system bus master directly.

### 28.3.6 NSPI CTRL

Sequence decode engine which generates specialized timing sequence for various device. The NSPI decode the transaction from TX FIFO and Memory-Mapped Controller and convert it to relative CMD/ADDR/DATA frame based on the configuration.

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

### 28.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                         |
| FSPI_AX0      | 0x0014 | W    | 0x00000000  | FSPI Auxiliary Data Value for CS0 Device      |
| FSPI_ABTO     | 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    | 0x00000009  | Version Register                              |
| FSPI_QOP      | 0x0030 | W    | 0x00000000  | Quad Line Operation IO Level Pre-set Register |
| FSPI_EXT_CTRL | 0x0034 | W    | 0x00004023  | Extend Control Register                       |

| Name                | Offset | Size | Reset Value | Description                                                 |
|---------------------|--------|------|-------------|-------------------------------------------------------------|
| 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 DEVREGN        | 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 DBG IO CTRL    | 0x022C | W    | 0x00000000  | Debug IO Control                                            |
| FSPI DLL CTRL1      | 0x023C | W    | 0x00000001  | Delay Line Control Register for CS1 Device                  |
| FSPI XMMC WCMD1     | 0x0250 | W    | 0x00000000  | Memory Mapped Control Write Command Register for CS1 Device |
| FSPI XMMC RCMD1     | 0x0254 | W    | 0x00000000  | Memory-Mapped Command Control Register for CS1 Device       |
| FSPI DEVSIZE1       | 0x0264 | W    | 0x00000012  | Device Size Register for CS1 Device                         |
| FSPI TME1           | 0x0268 | W    | 0x00000000  | Timeout Enable Control Register for CS1 Device              |

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

## 28.4.3 Detail Registers Description

### FSPI\_CTRL0

Address: Operational Base(0xFF488000) + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                              |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                 |
| 29    | RW   | 0x0         | WP_EN<br>WP# Port Enable<br>1'b0: Disable<br>1'b1: Enable. The WP# port will always be driven by QOP[SO123] when QOP[SO123BP] is set to disable.                                                                                                                                                                                                                         |
| 28:14 | RO   | 0x0000      | reserved                                                                                                                                                                                                                                                                                                                                                                 |
| 13:12 | RW   | 0x0         | DATB<br>Data Line Width<br>2'b00: 1 bit, x1 mode<br>2'b01: 2 bits, x2 mode<br>2'b10: 4 bits, x4 mode<br>2'b11: Reserved<br>Set this DATB to match the CMD sequence before doing indirect access mode and memory mapped access mode.                                                                                                                                      |
| 11:10 | RW   | 0x0         | ADRB<br>Address Line Width<br>2'b00: 1 bit, x1 mode<br>2'b01: 2 bits, x2 mode<br>2'b10: 4 bits, x4 mode<br>2'b11: Reserved<br>Set this ADRB to match the CMD sequence before doing indirect access mode and memory mapped access mode.                                                                                                                                   |
| 9:8   | RW   | 0x0         | CMDB<br>Command Line Width<br>2'b00: 1 bit, x1 mode<br>2'b01: 2 bits, x2 mode<br>2'b10: 4 bits, x4 mode<br>2'b11: Reserved<br>Set this CMDB to match the CMD sequence before doing indirect access mode and memory mapped access mode.                                                                                                                                   |
| 7:4   | RW   | 0x0         | IDLE_CYCLE<br>Idle Cycles When Switching IO from Output to Input<br>4'h0: Idle hold is disable<br>4'h1: Hold the SCLK in idle for 2 cycles when switch to shift in<br>...<br>4'hf: Hold the SCLK in idle for 16 cycles when switch to shift in<br>To improve the transform IO timing, the application can set this register to hold the SCLK in low state or high state. |
| 3:2   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                 |

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

**FSPI IMR**

Address: Operational Base(0xFF488000) + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                                                                           |
| 7          | RW          | 0x1                | <p>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.</p>                            |
| 6          | RW          | 0x1                | <p>NSPI<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.</p>                            |
| 5          | RW          | 0x1                | <p>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.</p>                |
| 4          | RW          | 0x1                | <p>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.</p>           |
| 3          | RW          | 0x1                | <p>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.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2          | RW          | 0x1                | TXOM<br>Transmit FIFO Overflow Interrupt Mask<br>1'b0: Transmit FIFO overflow interrupt is not masked<br>1'b1: Transmit FIFO overflow interrupt is masked<br>Only valid in indirect access mode. |
| 1          | RW          | 0x1                | RXUM<br>Receive FIFO Underflow Interrupt Mask<br>1'b0: Receive FIFO underflow interrupt is not masked<br>1'b1: Receive FIFO underflow interrupt is masked<br>Only valid in indirect access mode. |
| 0          | RW          | 0x1                | RXFM<br>Receive FIFO Full Interrupt Mask<br>1'b0: Receive FIFO full interrupt is not masked<br>1'b1: Receive FIFO full interrupt is masked<br>Only valid in indirect access mode.                |

**FSPI\_ICLR**

Address: Operational Base(0xFF488000) + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                |
| 7          | W1C         | 0x0                | DMAC<br>DMA Finish Interrupt Clear<br>1'b0: No action<br>1'b1: Clear interrupt<br>Write "1" to clear the DMAS           |
| 6          | W1C         | 0x0                | NSPIC<br>NSPI Error Interrupt Clear<br>1'b0: No action<br>1'b1: Clear interrupt<br>Write "1" to clear the NSPIS.        |
| 5          | W1C         | 0x0                | AHBC<br>AMBA AHB Error Interrupt Clear<br>1'b0: No action<br>1'b1: Clear interrupt<br>Write "1" to clear the AHBS.      |
| 4          | W1C         | 0x0                | TRANSC<br>Transfer Finish Interrupt Clear<br>1'b0: No action<br>1'b1: Clear interrupt<br>Write "1" to clear the TRANSS. |
| 3          | W1C         | 0x0                | TXEC<br>Transmit FIFO Empty Interrupt Clear<br>1'b0: No action<br>1'b1: Clear interrupt<br>Write "1" to clear the TXES. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------|
| 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(0xFF488000) + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                               |
| 15:8       | RW          | 0x10               | RXFTLR<br>Receive FIFO Threshold Level<br>8'h0: 0 entry level<br>8'h1: 1 entry level<br>...<br>8'h10: 16 entry level(default)<br>...<br>When the number of receive FIFO entries is bigger than or equal to this value, the receive FIFO full interrupt is triggered.   |
| 7:0        | RW          | 0x10               | TXFTLR<br>Transmit FIFO Threshold Level<br>8'h0: 0 entry level<br>8'h1: 1 entry level<br>...<br>8'h10: 16 entry level(default)<br>...<br>When the number of transmit FIFO entries is less than or equal to this value, the transmit FIFO empty interrupt is triggered. |

**FSPI\_RCVR**

Address: Operational Base(0xFF488000) + 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          | R/W<br>SC   | 0x0                | RCVR<br>FSPI Recover<br>Write any values to trigger the recovery of SMC NSPI state machine, FIFO state and other logic state. |

**FSPI\_AX0**

Address: Operational Base(0xFF488000) + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                 |
| 7:0        | RW          | 0x00               | AX<br>Auxiliary Data<br>The AX value when doing the continuous read (enhance mode or XIP mode). That is M7-M0 in "Continuous Read Mode". |

**FSPI\_ABITO**

Address: Operational Base(0xFF488000) + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0000000          | reserved                                                                                                                      |
| 4:0        | RW          | 0x00               | ABIT<br>Address Bits Extend<br>5'h0: 1 bit<br>5'h1: 2 bits<br>...<br>5'h1f: 32 bits<br>Only valid when ADDRB is set to 2'b11. |

**FSPI\_ISR**

Address: Operational Base(0xFF488000) + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                          |
| 7          | RO          | 0x0                | DMAS<br>DMA Finish Interrupt Status<br>1'b0: No interrupt<br>1'b1: Active interrupt generated                     |
| 6          | RO          | 0x0                | NSPIS<br>NSPI Transaction Decode Error Interrupt Status<br>1'b0: No interrupt<br>1'b1: Active interrupt generated |
| 5          | RO          | 0x0                | AHBS<br>AMBA AHB Error Interrupt Status<br>1'b0: No interrupt<br>1'b1: Active interrupt generated                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------|
| 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(0xFF488000) + 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                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------|
| 2          | RO          | 0x0                | RXES<br>Receive FIFO Empty Status<br>1'b0: RX FIFO is not empty<br>1'b1: RX FIFO is empty  |
| 1          | RO          | 0x0                | TXES<br>Transmit FIFO Empty Status<br>1'b0: TX FIFO is not empty<br>1'b1: TX FIFO is empty |
| 0          | RO          | 0x1                | TXFS<br>Transmit FIFO Full Status<br>1'b0: TX FIFO is not full<br>1'b1: TX FIFO is full    |

**FSPI\_SR**

Address: Operational Base(0xFF488000) + 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(0xFF488000) + 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. |

| <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 active raw interrupt<br>1'b1: Active raw interrupt is generated<br>Cleared by writing corresponding ICLR bit to clear raw interrupt status.         |
| 4          | RO          | 0x0                | TRANSS<br>Transfer Finish Interrupt Status<br>1'b0: No active raw interrupt<br>1'b1: Active raw interrupt is generated<br>Cleared by writing corresponding ICLR bit to clear raw interrupt status.      |
| 3          | RO          | 0x0                | TXES<br>Transmit FIFO Empty Interrupt Status<br>1'b0: No active raw interrupt<br>1'b1: Active raw interrupt is generated<br>Cleared by writing corresponding ICLR bit to clear raw interrupt status.    |
| 2          | RO          | 0x0                | TXOS<br>Transmit FIFO Overflow Interrupt Status<br>1'b0: No active raw interrupt<br>1'b1: Active raw interrupt is generated<br>Cleared by writing corresponding ICLR bit to clear raw interrupt status. |
| 1          | RO          | 0x0                | RXUS<br>Receive FIFO Underflow Interrupt Status<br>1'b0: No active raw interrupt<br>1'b1: Active raw interrupt is generated<br>Cleared by writing corresponding ICLR bit to clear raw interrupt status. |
| 0          | RO          | 0x0                | RXFS<br>Receive FIFO Full Interrupt Status<br>1'b0: No active raw interrupt<br>1'b1: Active raw interrupt is generated<br>Cleared by writing corresponding ICLR bit to clear raw interrupt status.      |

### **FSPI VER**

Address: Operational Base(0xFF488000) + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>            |
|------------|-------------|--------------------|-------------------------------|
| 31:16      | RO          | 0x0000             | reserved                      |
| 15:0       | RO          | 0x0009             | VER<br>The Version ID of FSPI |

### **FSPI QOP**

## RK3506 TRM (Part 1)

Address: Operational Base(0xFF488000) + offset (0x0030)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                    |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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(0xFF488000) + offset (0x0034)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                            |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15 | RO   | 0x00000     | reserved                                                                                                                                                                                                                                                               |
| 14    | RW   | 0x1         | SR_GEN_MODE<br>Status Register Generation Mode<br>1'b0: Compatible mode with old controller<br>1'b1: Robust generation to indicates the status of controller<br>If set to "1", the controller will only clear the SR bit after operation sequence done and CS is high. |
| 13    | RW   | 0x0         | TRANS_INT_MODE<br>Transmit Done Interrupt Generation Mode<br>1'b0: Trigger NSPI end in data done<br>1'b1: Trigger NSPI end in CS inactive<br>Default Generation is compatible with old controller.                                                                     |
| 12    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                               |
| 11:8  | RW   | 0x0         | SWITCH_IO_O2I_CNT<br>Switch IO Attribute Cycles in O2I Idle Phase<br>4'h0: 1st cycle<br>4'h1: 2nd cycle<br>4'h2: 3rd cycle<br>4'h3: 4th cycle<br>...<br>4'hf: 16th cycle<br>The target cycle when switching from output to input in O2I idle phase.                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4        | RW          | 0x2                | <p>SWITCH_IO_DUMM_CNT<br/>Switch IO Attribute Cycles in Dummy Phase<br/>4'h0: 1st cycle<br/>4'h1: 2nd cycle<br/>4'h2: 3rd cycle<br/>4'h3: 4th cycle<br/>...<br/>4'hf: 16th cycle<br/>The target cycle when switching from output to input in Dummy data phase.</p>                              |
| 3:0        | RW          | 0x3                | <p>CS_DESEL_CTRL<br/>CS Inactive Control<br/>4'h0: Not support<br/>4'h1: 2 cycles<br/>4'h2: 3 cycles<br/>4'h3: 4 cycles<br/>...<br/>4'hf: 16 cycles<br/>The target cycles to hold CS inactive after de-assert the CS.<br/>Default value are 4 SCLK cycles that is enough for normal device.</p> |

**FSPI DLL CTRL0**

Address: Operational Base(0xFF488000) + offset (0x003C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                      |
| 15         | RW          | 0x0                | <p>SCLK_SMP_SEL<br/>SCLK Sampling Selection<br/>1'b0: Bypass DLL<br/>1'b1: From DLL<br/>The sampling SCLK source selection.</p>                                                                                                                                                                               |
| 14:9       | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                      |
| 8:0        | RW          | 0x001              | <p>SMP_DLL_CFG<br/>Sample Delay Line Configuration<br/>9'h0: 1 DLL element cell<br/>9'h1: 1 DLL element cell<br/>9'h2: 2 DLL element cells<br/>...<br/>9'h1ff: 511 DLL element cells<br/>This register to control the sampling delay line cell used. The maximum DLL element cells is decided by process.</p> |

**FSPI EXT AX**

Address: Operational Base(0xFF488000) + offset (0x0044)

| <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: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(0xFF488000) + 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(0xFF488000) + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                              |
| 15:14      | WO          | 0x0                | ADDRB<br>Address Bits<br>2'b00: 0 bit<br>2'b01: 24 bits<br>2'b10: 32 bits<br>2'b11: From the ABIT register<br>Address bits number select in memory mapped mode, if there is not address command to send, set to zero. |
| 13         | WO          | 0x0                | CONT<br>Continuous<br>1'b0: Disable continuous mode<br>1'b1: Enable continuous mode<br>AX mode or Continuous mode or XIP mode for device which begins with address.                                                   |
| 12         | RO          | 0x0                | reserved                                                                                                                                                                                                              |
| 11:8       | WO          | 0x0                | DUMM<br>Dummy Cycles<br>4'h0: No dummy cycle<br>...<br>4'h8: 8 cycles<br>...<br>Dummy bit cycles in memory mapped mode.                                                                                               |

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

Address: Operational Base(0xFF488000) + 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(0xFF488000) + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x00000000         | reserved                                                                                                                                       |
| 6          | RW          | 0x1                | PFT_EN<br>Prefetch Enable<br>1'b0: Disable<br>1'b1: Enable<br>Should disable prefetch if controller communicate with pSRAM which need refresh. |

| <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(0xFF488000) + 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(0xFF488000) + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x000000           | reserved                                                                                                                                                                                                                                                          |
| 9:8        | RW          | 0x0                | DEC_CTRL<br>Decode Control<br>2'b00: 1 CS#<br>2'b01: 2 CS#<br>2'b10: 4 CS#<br>2'b11: Reserved<br>Only valid in XMMC mode.                                                                                                                                         |
| 7:5        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                          |
| 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(0xFF488000) + offset (0x0064)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                            |
| 4:0        | RW          | 0x12               | <p>DSIZE<br/>Device Size<br/>5'd0: 1 byte<br/>5'd1: 2 bytes<br/>5'd2: 4 bytes<br/>.....<br/>5'd10: 1K bytes<br/>.....<br/>5'd20: 1M bytes<br/>.....<br/>5'd31: 4G byte</p> <p>Device size is used to generate slop over status.</p> |

**FSPI TME0**

Address: Operational Base(0xFF488000) + offset (0x0068)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                                 |
| 1          | RW          | 0x0                | <p>SCLK_INATM_EN<br/>SCLK Inactive Timeout Enable<br/>1'b0: Disable<br/>1'b1: Enable</p> |
| 0          | RO          | 0x0                | reserved                                                                                 |

**FSPI XMMC RX WTMRK**

Address: Operational Base(0xFF488000) + offset (0x0070)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                     |
| 7:0        | RW          | 0x02               | <p>RX_FULL_WTMRK<br/>Memory Mapped Mode Receiver FIFO Water Mark.<br/>Default is enough.</p> |

**FSPI DMATR**

Address: Operational Base(0xFF488000) + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                              |
| 0          | W1C         | 0x0                | <p>DMATR<br/>DMA Trigger<br/>Write "1" to start the DMA transfer.</p> |

**FSPI DMAADDR**

Address: Operational Base(0xFF488000) + 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(0xFF488000) + 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(0xFF488000) + 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(0xFF488000) + 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(0xFF488000) + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | WO          | 0x0                | CS<br>Device Chip Select.<br>2'b00: Chip select 0<br>2'b01: Chip select 1<br>2'b10: Reserved<br>2'b11: Reserved                                                                                                         |
| 29:16      | WO          | 0x0000             | TRB<br>Total Transfer Bytes<br>14'd0: No data<br>14'd1: 1 Byte<br>14'd2: 2 Bytes<br>...<br>Total data bytes number that will write to or read from the device.                                                          |
| 15:14      | WO          | 0x0                | ADDRB<br>Address Bits<br>2'b00: 0 bit<br>2'b01: 24 bits<br>2'b10: 32 bits<br>2'b11: From the ABIT register<br>Address bits number select in indirect access mode. If there is not address command to send, set to zero. |
| 13         | WO          | 0x0                | CONT<br>Continuous<br>1'b0: Disable continuous mode<br>1'b1: Enable continuous mode<br>AX mode or Continuous mode or XIP mode for device which begins with address.                                                     |
| 12         | WO          | 0x0                | WR<br>Write or Read<br>1'b0: Read<br>1'b1: Write                                                                                                                                                                        |
| 11:8       | WO          | 0x0                | DUMM<br>Dummy Cycles<br>4'h0: No dummy cycle<br>...<br>4'h8: 8 cycles<br>...<br>Dummy bit cycles in indirect access mode.                                                                                               |
| 7:0        | WO          | 0x00               | CMD<br>Command<br>Command data in indirect access mode.                                                                                                                                                                 |

**FSPI ADDR**

Address: Operational Base(0xFF488000) + 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(0xFF488000) + 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(0xFF488000) + offset (0x0200)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                                                                                               |
| 29         | RW          | 0x0                | WP_EN<br>WP# Port Enable<br>1'b0: Disable<br>1'b1: Enable. The WP# port will always be driven by QOP[SO123] when QOP[SO123BP] is setted to disable.                                                                                    |
| 28:14      | RO          | 0x0000             | reserved                                                                                                                                                                                                                               |
| 13:12      | RW          | 0x0                | DATB<br>Data Line Width<br>2'b00: 1 bit, x1 mode<br>2'b01: 2 bits, x2 mode<br>2'b10: 4 bits, x4 mode<br>2'b11: Reserved<br>Set this DATB to match the CMD sequence before doing indirect access mode and memory mapped access mode.    |
| 11:10      | RW          | 0x0                | ADRB<br>Address Line Width<br>2'b00: 1 bit, x1 mode<br>2'b01: 2 bits, x2 mode<br>2'b10: 4 bits, x4 mode<br>2'b11: Reserved<br>Set this ADRB to match the CMD sequence before doing indirect access mode and memory mapped access mode. |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                 |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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/>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>SPI M<br/>Serial Peripheral Interface Mode<br/>1'b0: Mode 0<br/>1'b1: Mode 3<br/>SPI M 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 AX1**

Address: Operational Base(0xFF488000) + offset (0x0214)

| Bit  | Attr | Reset Value | Description                                                                                                                                       |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0000000   | 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 ABIT1**

Address: Operational Base(0xFF488000) + offset (0x0218)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0000000          | reserved                                                                                                                      |
| 4:0        | RW          | 0x00               | ABIT<br>Address Bits Extend<br>5'h0: 1 bit<br>5'h1: 2 bits<br>...<br>5'h1f: 32 bits<br>Only valid when ADDRB is set to 2'b11. |

### **FSPI DBG IO CTRL**

Address: Operational Base(0xFF488000) + offset (0x022C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------|
| 31:17      | RO          | 0x0000             | reserved                                                                                                             |
| 16         | RW          | 0x0                | DLL_DBG_EN<br>Delayline IO Debug Enable<br>1'b0 : Disable<br>1'b1 : Enable                                           |
| 15:4       | RO          | 0x000              | reserved                                                                                                             |
| 3:2        | RW          | 0x0                | DBG_OUT1_MUX<br>Debug IO1 Output Mux<br>2'b00 : Output Data[2] ;<br>2'b01 : Output Data[3] ;<br>2'b10 : Output CLK . |
| 1:0        | RW          | 0x0                | DBG_OUT0_MUX<br>Debug IO0 Output Mux<br>2'b00 : Output Data[0] ;<br>2'b01 : Output Data[1] ;<br>2'b10 : Output CLK . |

### **FSPI DLL CTRL1**

Address: Operational Base(0xFF488000) + 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                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:0        | RW          | 0x001              | <p>SMP_DLL_CFG<br/>Sample Delay Line Configuration<br/>9'h0: 1 DLL element cell<br/>9'h1: 1 DLL element cell<br/>9'h2: 2 DLL element cells<br/>...<br/>9'h1ff: 511 DLL element cells</p> <p>This register to control the sampling delay line cell used. The maximum DLL element cells is decided by process.</p> |

**FSPI XMMC WCMD1**

Address: Operational Base(0xFF488000) + offset (0x0250)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                                           |
| 15:14      | WO          | 0x0                | <p>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.</p> |
| 13         | WO          | 0x0                | <p>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.</p>                                                     |
| 12         | RO          | 0x0                | reserved                                                                                                                                                                                                                           |
| 11:8       | WO          | 0x0                | <p>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.</p>                                                                                               |
| 7:0        | WO          | 0x00               | <p>CMD<br/>Command<br/>Command data in memory mapped access mode.</p>                                                                                                                                                              |

**FSPI XMMC RCMD1**

Address: Operational Base(0xFF488000) + offset (0x0254)

| <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: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(0xFF488000) + 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(0xFF488000) + offset (0x0268)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                       |
| 1          | RW          | 0x0                | SCLK_INATM_EN<br>SCLK Inactive Timeout Enable<br>1'b0: Disable<br>1'b1: Enable |
| 0          | RO          | 0x0                | reserved                                                                       |

## 28.5 Interface Description

Table 28-1 FSPI Interface Description

| <b>Module Pin</b> | <b>Direction</b> | <b>Pad Name</b>   | <b>IOMUX Setting</b>                         |
|-------------------|------------------|-------------------|----------------------------------------------|
| sfc_sclk          | O                | FSPI_CLK/GPIO2_A1 | GPIO2_IOC_GPIO2A_IOMUX_SEL_0[3:0] =4'h1      |
| sfc_cs0n          | O                | FSPI_CSN/GPIO2_A0 | GPIO2_IOC_GPIO2A_IOMUX_SEL_0[7:4] =4'h1      |
| sfc_sio0          | I/O              | FSPI_D0/GPIO2_A2  | GPIO2_IOC_GPIO2A_IOMUX_SEL_0[11:8] =4'h1     |
| sfc_sio1          | I/O              | FSPI_D1/GPIO2_A3  | GPIO2_IOC_GPIO2A_IOMUX_SEL_0[15:12] =4'h1    |
| sfc_sio2          | I/O              | FSPI_D2/GPIO2_A4  | GPIO2_IOC_GPIO2A_IOMUX_SEL_1[3:0] =4'h1      |
| sfc_sio3          | I/O              | FSPI_D3/GPIO2_A5  | GPIO2_IOC_GPIO2A_IOMUX_SEL_1[7:4] =4'h1=4'h2 |

Notes: I=input, O=output, I/O=input/output, bidirectional

## 28.6 Application Notes

### 28.6.1 Typical Program Flow without DMA



Fig. 28-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.

## 28.6.2 Typical READ Flow without DMA



Fig. 28-3 Read Flow

### 28.6.3 Command Flow with DMA



Fig. 28-4 Command with DMA Flow

The total transfer bytes is decided by TRB register in FSPI\_CMD and must be aligned to 2 bytes.

### 28.6.4 SPI Mode and Sampling Phase Control

The register SPIM in FSPI\_CTRL will decide the default value of SCLK when CS# is inactive. When SPIM=0, the default value is 0, means Mode 0. When SPIM=1, the default value is 1,

means SPI Mode 3.

The register SHIFTPAHSE in FSPI\_CTRL will decide when to sample the SIO data. If SHIFTPAHSE=0, it will sample the data at the posedge of SCLK sampling clock. If SHIFTPHASE=1, it will sample the data at the negedge of SCLK sampling. The phase delay of sampling clock SCLK is configurable by SMP\_DLL\_CFG. It is strongly recommended that the SMP\_DLL\_CFG is set to 1 when SCLK\_SMP\_SEL is in bypass mode.

Individual FSPI\_DLL\_CTRL[n] allows flexibly control the DLL for each CSN channel, and the DLL is switched dynamically when the CSN is in operation.



Fig. 28-5 SPI mode

### 28.6.5 Idle Cycles

The FSPI\_CTRL register is a global control register, when the controller is in busy state (FSPI\_SR), FSPI\_CTRL cannot be set. The field IDLE\_CYCLE (FSPI\_CTRL[7:4]) of this register are used to configure the idle level cycles of FSPI core clock (SCLK) before reading the first bit of the read command.

Like the following picture shows, the highlighted line of the SCLK is the idle cycles, during these cycles, the chip pad is switched to output. When IDLE\_CYCLE =0, it means there will be no idle level cycles.



Fig. 28-6 Idle cycles

## Chapter 29 Serial Peripheral Interface (SPI)

### 29.1 Overview

The Serial Peripheral Interface is an APB slave device. There are four possible combinations for the serial clock phase and polarity. The clock phase (SCPH) determines whether the serial transfer begins with the falling edge of slave select signals or the first edge of the serial clock. The slave select line is held high when the SPI is idle or disabled. This SPI controller can work as either master or slave mode.

SPI Controller supports the following features:

- Support Motorola SPI, TI Synchronous Serial Protocol and National Semiconductor Micro wire interface
- Support 32-bit APB bus
- Support two internal 16-bit wide and 64-location deep FIFOs, one for transmitting and the other for receiving serial data
- Support two chip select signals in master mode
- Support 4,8,16 bit serial data transfer
- Support configurable interrupt polarity
- Support asynchronous APB bus and SPI clock
- Support master and slave mode
- Support DMA handshake interface and configurable DMA water level
- Support transmit FIFO empty, underflow, receive FIFO full, overflow, interrupt and all interrupts can be masked
- Support configurable water level of transmit FIFO empty and receive FIFO full interrupt
- Support combining interrupt output
- Support up to half of SPI clock frequency transfer in master mode and one quarter of SPI clock frequency transfer in slave mode
- Support full and half duplex mode transfer
- Stop transmitting SCLK if transmit FIFO is empty or receive FIFO is full in master mode
- Support configurable delay from chip select active to SCLK active in master mode
- Support configurable period of chip select inactive between two parallel data in master mode
- Support big and little endian, MSB and LSB first transfer
- Support two 8-bit audio data store together in one 16-bit wide location
- Support sample MISO 0~3 SPI clock cycles later at master mode
- 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 MISO and MOSI logic are driven by SCLK\_IN directly instead of spi\_clk

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

## 29.3 Function Description



Fig. 29-2 SPI Master and Slave Interconnection

The SPI controller support dynamic switching between master and slave in a system. The diagram shows how the SPI controller connects with other SPI devices.

### Operation Modes

The SPI can be configured in the following two fundamental modes of operation: Master Mode when SPI\_CTRLR0 [20] is 1'b0, Slave Mode when SPI\_CTRLR0 [20] is 1'b1, bypass Slave Mode when SPI\_BYPASS[0] is 1'b1, additionally.

### 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 normal slave, the  $F_{spi\_clk} \geq 4 \times (\text{maximum } F_{sclk\_in})$

When SPI Controller works as bypass slave, no frequency ratio restrictions

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 MISO and MOSI 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. 29-3 SPI Format (SCPH=0 SCPOL=0)


**Fig. 29-4 SPI Format (SCPH=0 SCPOL=1)**

When the configuration parameter  $\text{SCPH} = 1$ , both master and slave peripherals begin transmitting data on the first serial clock edge after the slave select line is activated. The first data bit is captured on the second (trailing) serial clock edge. Data are propagated by the master and slave peripherals on the leading edge of the serial clock. During continuous data frame transfers, the slave select line may be held active-low until the last bit of the last frame has been captured. The following two figures show the timing diagram for the SPI format when the configuration parameter  $\text{SCPH} = 1$ .


**Fig. 29-5 SPI Format (SCPH=1 SCPOL=0)**

**Fig. 29-6 SPI Format (SCPH=1 SCPOL=1)**

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

**Operational Base**

| Name | Base Address |
|------|--------------|
| SPI0 | 0xff120000   |
| SPI1 | 0xff130000   |

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

| Name        | Offset | Size | Reset Value | Description                |
|-------------|--------|------|-------------|----------------------------|
| 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_VERSION | 0x0048 | W    | 0x03110003  | IP version                 |
| SPI_TIMEOUT | 0x004C | W    | 0x00000000  | Timeout control register   |
| SPI_BYPASS  | 0x0050 | W    | 0x00000000  | BYPASS control register    |
| SPI_BPENR   | 0x0054 | W    | 0x00000000  | SPI BYPASS Enable Register |
| SPI_TXDR    | 0x0400 | W    | 0x00000000  | Transmit FIFO Data         |
| SPI_RXDR    | 0x0800 | W    | 0x00000000  | Receive FIFO Data          |

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

### 29.4.3 Detail Registers Description

#### SPI\_CTRLR0

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                 |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 31:26 | RO   | 0x00        | reserved                                                                                                                                    |
| 25    | RW   | 0x0         | lbk<br>Loop back mode select.<br>1'b0: Normal mode.<br>1'b1: Loop back mode, rxd is connected to txd.                                       |
| 24:23 | RW   | 0x0         | soi<br>SS_N output inverted.<br>1'b0: Corresponding bit of ss_in is not inverted.<br>1'b1: Corresponding bit of ss_in is inverted.          |
| 22    | RW   | 0x0         | sm<br>SCLK_IN is masked by SS_N or not.<br>1'b0: SCLK_IN is masked<br>1'b1: SCLK_IN is not masked                                           |
| 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                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:14      | RW          | 0x0                | <p>rsd</p> <p>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.</p> <p>2'b00: Do not delay<br/>2'b01: 1 cycle delay<br/>2'b10: 2 cycles delay<br/>2'b11: 3 cycles delay</p> |
| 13         | RW          | 0x0                | <p>bht</p> <p>Valid when data frame size is 8bit.</p> <p>1'b0: APB 16bit write/read, spi 8bit write/read.<br/>1'b1: APB 8bit write/read, spi 8bit write/read.</p>                                                                                                                                                                                                                                               |
| 12         | RW          | 0x0                | <p>fbm</p> <p>1'b0: First bit is MSB.<br/>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<br/>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.<br/>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.<br/>2'b01: ss_n be high for half sclk_out cycles after every frame data is transferred.<br/>2'b10: ss_n be high for one sclk_out cycle after every frame data is transferred.<br/>2'b11: Reserved</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.<br/>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.<br/>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. Therein, the slave bypass mode does not support the 4bits data 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             | <p>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/> <math>F_{sclk\_out} = F_{spi\_clk} / SCKDV</math><br/> Where SCKDV is any even value between 2 and 65534.<br/> For example:<br/> for <math>F_{spi\_clk} = 3.6864\text{MHz}</math> and <math>SCKDV = 2</math><br/> <math>F_{sclk\_out} = 3.6864/2 = 1.8432\text{MHz}</math></p> |

### **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               | <p>txftlr<br/>When the number of transmit FIFO entries is less than or equal to this value, the transmit FIFO empty interrupt is triggered.</p> |

### **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               | <p>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.</p> |

### **SPI TXFLR**

Address: Operational Base + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                     |
| 6:0        | RO          | 0x00               | <p>txflr<br/>Contains the number of valid data entries in the transmit FIFO. (Note: When the bypass slave scph is 1, the master cannot provide redundant clocks according to the SPI protocol. Therefore, The actual value is the read value minus one.)</p> |

### **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               | <p>rxflr<br/>Contains the number of valid data entries in the receive FIFO.</p> |

### **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                | <p>ssi<br/>1'b0: ss_in_n is low.<br/>1'b1: ss_in_n is high.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | RO          | 0x0                | stb<br>1'b0: Slave tx not busy.<br>1'b1: Slave tx busy.                                                                                                                                                   |
| 4          | RO          | 0x0                | rff<br>1'b0: Receive FIFO is not full.<br>1'b1: Receive FIFO is full.                                                                                                                                     |
| 3          | RO          | 0x1                | rfe<br>1'b0: Receive FIFO is not empty.<br>1'b1: Receive FIFO is empty.                                                                                                                                   |
| 2          | RO          | 0x1                | tfe<br>1'b0: Transmit FIFO is not empty.<br>1'b1: Transmit FIFO is empty.                                                                                                                                 |
| 1          | RO          | 0x0                | tff<br>1'b0: Transmit FIFO is not full.<br>1'b1: Transmit FIFO is full.                                                                                                                                   |
| 0          | RO          | 0x0                | bsf<br>When set, indicates that a serial transfer is in progress; when cleared, indicates that the SPI is idle or disabled.<br>1'b0: SPI is idle or disabled.<br>1'b1: SPI is actively transferring data. |

**SPI IPR**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                               |
| 0          | RW          | 0x0                | ipr<br>Interrupt Polarity Register.<br>1'b0: Active Interrupt Polarity Level is HIGH.<br>1'b1: Active Interrupt Polarity Level is LOW. |

**SPI IMR**

Address: Operational Base + offset (0x002C)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | tfeim<br>1'b0: spi_txe_intr interrupt is masked.<br>1'b1: spi_txe_intr interrupt is not masked. |

**SPI ISR**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                          |
| 7          | RW          | 0x0                | txfis<br>1'b0: TX finish interrupt is not active after masking.<br>1'b1: TX finish interrupt is active after masking.             |
| 6          | RW          | 0x0                | sspis<br>1'b0: ss_in_n posedge interrupt is not active after masking.<br>1'b1: ss_in_n posedge interrupt is active after masking. |
| 5          | RW          | 0x0                | tois<br>1'b0: spi timeout interrupt is not active after masking.<br>1'b1: spi timeout interrupt is active after masking.          |
| 4          | RO          | 0x0                | rffis<br>1'b0: spi_rxf_intr interrupt is not active after masking.<br>1'b1: spi_rxf_intr interrupt is full after masking.         |
| 3          | RO          | 0x0                | rfois<br>1'b0: spi_rxo_intr interrupt is not active after masking.<br>1'b1: spi_rxo_intr interrupt is active after masking.       |
| 2          | RO          | 0x0                | rfuis<br>1'b0: spi_rxu_intr interrupt is not active after masking.<br>1'b1: spi_rxu_intr interrupt is active after masking.       |
| 1          | RO          | 0x0                | tfois<br>1'b0: spi_txo_intr interrupt is not active after masking.<br>1'b1: spi_txo_intr interrupt is active after masking.       |
| 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          | 0x000000           | 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.       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RO          | 0x0                | tforis<br>1'b0: spi_txo_intr interrupt is not active prior to masking.<br>1'b1: spi_txo_intr interrupt is active prior to masking. |
| 0          | RO          | 0x1                | tferis<br>1'b0: spi_txe_intr interrupt is not active prior to masking.<br>1'b1: spi_txe_intr interrupt is active prior to masking. |

**SPI ICR**

Address: Operational Base + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:7       | RO          | 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 posedge Interrupt.        |
| 4          | WO          | 0x0                | ctoi<br>Write 1 to Clear Timeout Interrupt.                 |
| 3          | WO          | 0x0                | ctfoi<br>Write 1 to Clear Transmit FIFO Overflow Interrupt. |
| 2          | WO          | 0x0                | crfoi<br>Write 1 to Clear Receive FIFO Overflow Interrupt.  |
| 1          | WO          | 0x0                | crfui<br>Write 1 to Clear Receive FIFO Underflow Interrupt. |
| 0          | WO          | 0x0                | cci<br>Write 1 to Clear Combined Interrupt.                 |

**SPI DMACR**

Address: Operational Base + offset (0x003C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                           |
| 1          | RW          | 0x0                | tde<br>1'b0: Transmit DMA disabled.<br>1'b1: Transmit DMA enabled. |
| 0          | RW          | 0x0                | rde<br>1'b0: Receive DMA disabled.<br>1'b1: Receive DMA enabled.   |

**SPI DMATDLR**

Address: Operational Base + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                     |
| 5:0        | RW          | 0x00               | tdl<br>This bit field controls the level at which a DMA request is made by the transmit logic. It is equal to the watermark level; that is, the dma_tx_req signal is generated when the number of valid data entries in the transmit FIFO is equal to or below this field value, and transmit DMA is enabled (DMACR[1] = 1). |

**SPI DMARDLR**

Address: Operational Base + offset (0x0044)

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

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                 |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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 VERSION**

Address: Operational Base + offset (0x0048)

| Bit  | Attr | Reset Value | Description           |
|------|------|-------------|-----------------------|
| 31:0 | RO   | 0x03110003  | version<br>IP version |

**SPI TIMEOUT**

Address: Operational Base + offset (0x004C)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19 | RO   | 0x0000      | reserved                                                                                                                                                                                   |
| 18    | RW   | 0x0         | dtsr<br>DMA Timeout single request enable.<br>1'b0: DMA Timeout single request disable.<br>1'b1: DMA Timeout single request enable.                                                        |
| 17    | RW   | 0x0         | tsb<br>Timeout sclkcnt_bypass<br>1'b0: Timeout counter will be active after the first rising edge of sclk_in.<br>1'b1: Timeout counter will be active after the first rising edge of pclk. |
| 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_period*16.                     |

**SPI BYPASS**

Address: Operational Base + offset (0x0050)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                          |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | RO   | 0x00000000  | reserved                                                                                                                                                                                                                             |
| 3:2  | RW   | 0x0         | ckgen<br>clock gating enable.<br>2'b00: no gating works.<br>2'b01: gating sclk for bypass module, when work at normal mode.<br>2'b10: gating spi_clk, when work at bypass mode.<br>2'b11: gating sclk and spi_clk, when spi is idle. |
| 1    | RW   | 0x0         | txfie<br>Bypass Slave TX Finish Interrupt Enable<br>1'b0: TX finish interrupt disable.<br>1'b1: TX finish interrupt enable.                                                                                                          |

| <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 driven by SCLK. |

**SPI\_BPENR**

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                | bpenr<br>Enable and disable all SPI operations at bypass mode. Transmit and receive FIFO buffers are cleared when the device is disabled. |

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

## 29.5 Interface Description

Table 29-1 SPI Interface Description

| <b>Module Pin</b> | <b>Dir</b> | <b>Pin Name</b> | <b>IOMUX Setting</b>                        |
|-------------------|------------|-----------------|---------------------------------------------|
| <b>IOMUX0</b>     |            |                 |                                             |
| spi0_sclk         | I/O        | GPIO0_C0        | GPIO0_IOC_GPIO0C_IOMU_X_SEL_0[3:0] = 4'h2   |
| spi0_mosi         | I/O        | GPIO0_C1        | GPIO0_IOC_GPIO0C_IOMU_X_SEL_0[7:4] = 4'h2   |
| spi0_miso         | I/O        | GPIO0_C2        | GPIO0_IOC_GPIO0C_IOMU_X_SEL_0[11:8] = 4'h2  |
| spi0_csn0         | I/O        | GPIO0_C3        | GPIO0_IOC_GPIO0C_IOMU_X_SEL_0[15:12] = 4'h2 |
| spi0_csn1         | O          | GPIO0_B7        | GPIO0_IOC_GPIO0B_IOMU_X_SEL_1[15:12] = 4'h2 |
| spi1_sclk         | I/O        | GPIO0_B0        | GPIO0_IOC_GPIO0B_IOMU_X_SEL_0[3:0] = 4'h2   |
| spi1_mosi         | I/O        | GPIO0_B1        | GPIO0_IOC_GPIO0B_IOMU_X_SEL_0[7:4] = 4'h2   |
| spi1_miso         | I/O        | GPIO0_B2        | GPIO0_IOC_GPIO0B_IOMU_X_SEL_0[11:8] = 4'h2  |
| spi1_csn0         | I/O        | GPIO0_B6        | GPIO0_IOC_GPIO0B_IOMU_X_SEL_1[11:8] = 4'h2  |
| spi1_csn1         | O          | GPIO0_A7        | GPIO0_IOC_GPIO0A_IOMU_X_SEL_1[15:12] = 4'h2 |

Notes: I=input, O=output, I/O=input/output.

Table 29-2 SPI Rockchip Matrix IO Interface Description

| Module Pin    | Dir | Rockchip Matrix IO | IOMUX Setting |
|---------------|-----|--------------------|---------------|
| <b>IOMUX1</b> |     |                    |               |
| spi0_sclk     | I/O | RM_IO              |               |
| spi0_mosi     | I/O | RM_IO              |               |
| spi0_miso     | I/O | RM_IO              |               |
| spi0_csn0     | I/O | RM_IO              |               |
| spi0_csn1     | O   | RM_IO              |               |
| spi1_sclk     | I/O | RM_IO              |               |
| spi1_mosi     | I/O | RM_IO              |               |
| spi1_miso     | I/O | RM_IO              |               |
| spi1_csn0     | I/O | RM_IO              |               |
| spi1_csn1     | O   | RM_IO              |               |

Notes: I=input, O=output, I/O=input/output. For the configuration of RM\_IO, please refer to chapter "Rockchip Matrix IO".

## 29.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_{\text{spi\_clk}} \geq 2 \times (\text{maximum } F_{\text{sclk\_out}})$

When SPI Controller works as slave, the  $F_{\text{spi\_clk}} \geq 4 \times (\text{maximum } F_{\text{sclk\_in}})$

When SPI Controller works as bypass slave, no frequency ratio restrictions

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

Note that when the SPI works at bypass slave mode, since MISO and MOSI are directly driven by sclk\_in, data can be received and transmit quickly, and spi\_clk can be gated by configuring SPI\_BYPASS[3:2].



Fig. 29-7 SPI Master Transfer Flow Diagram



Fig. 29-8 SPI Slave Transfer Flow Diagram

## Chapter 30 SPI2APB

### 30.1 Overview

SPI2 is an alias for SPI2APB in this system. The SPI2APB module supports the following features:

- External SPI master can access the accessible address space in the chip through SPI2APB convertor
- Support two groups of registers in SGRF to control accessible address space in the chip
- A transaction states register and a message register can be read by external SPI master by query operation
- Two 32 bit registers can be written by external SPI master, and one of them can generate an interrupt after been written. This two register can be read by masters such as CPU and MCU

### 30.2 Block Diagram

The figure below shows SPI2APB block structure.



Fig. 30-1 SPI2APB Block Diagram

### 30.3 Function Description

#### 30.3.1 Overview

SPI2APB convertor receives data from SPI wires, parses the command, and operates according to the protocol.

#### 30.3.2 Protocol Description

SPI2APB supports four types of operation: Write, Read, Query and Write Message. By default, the command, address and data are all transferred in 32 bits packets in little endian, and the first bit to be transferred is the LSB. The operations begin at the negative edge of CS and end at the positive edge of CS. Between two operation, CS should keep high for a time longer than one SCLK period.

##### Write

External SPI master should dessert CS firstly. The Write command, address and data packets should be transferred according to the order of the figure. The first data (data0 in the Fig. 30-2) will be written to the address ADDR, the second data will be written to the address ADDR+4, and so on. External SPI master can terminate the write operation by setting the CS to high level.



Fig. 30-2 Write Operation

### Read

After receiving READ command and address, the convertor will read N data from the address and push the data into the RD\_FIFO (N is a parameter in READ command). Dummy packets can be inserted to ensure there is available data in the RD\_FIFO. When SPI master is ready to receive data, it should send a RD\_BEGIN command packet. The first packets following RD\_BEGIN packets (data0 in the Fig. 30-3) is the data read from address ADDR, the second packets is the data read from address ADDR+4, and so on. After N data packets have been transferred, SPI2APB will begin to transfer state information.



Fig. 30-3 Read Operation

### Query

There are two registers that can be queried: State Register and Message Register 2. State register contains transfer state information such as whether the transfer is complete or not, detail is shown in the Table 30-1. Message Register 2 can be written by DSP. The query result is immediately following the query command without delay.



Fig. 30-4 Query Operation  
Table 30-1 State Register Information

| Bit   | Attr | Reset Value | Description                                                                                                          |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x1608      | Chip ID                                                                                                              |
| 15:11 | RW   | 0x0         | reserved                                                                                                             |
| 10    | RW   | 0x0         | pre_err<br>Error response is received when APB master is doing pre-read transaction.                                 |
| 9     | RW   | 0x0         | rd_udflw<br>Read FIFO is underflow.                                                                                  |
| 8     | RW   | 0x0         | rd_err<br>Data with error response has been transmitted.                                                             |
| 7:4   | RW   | 0x0         | reserved                                                                                                             |
| 3     | RW   | 0x0         | trans_cfl<br>Transaction conflict. Previous transaction is unfinished and new transaction is launched by SPI master. |
| 2     | RW   | 0x0         | trans_unfi<br>Transaction is unfinished.                                                                             |
| 1     | RW   | 0x0         | wr_ovfl<br>Write FIFO is overflow                                                                                    |
| 0     | RW   | 0x0         | wr_err<br>Error response is received when APB master is writing                                                      |

### Write Message

There are two message registers can be written by external SPI master: Message Register 0 and Message Register 1. These two registers can be read by DSP. After Message Register 1 has been written, an interrupt will be generated.

The control register (CTRL0) can be written by using this command too.



Fig. 30-5 Write Message Operation

### Command Encoding

All command are 32bits.

Table 30-2 Command Encoding Information

| Command                         | Format                | Description                                                                                                                                                                                        |
|---------------------------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| READ                            | 0x0077+(PRE_NUM <<16) | PRE_NUM is pre_read number.<br>For example, 0x00100077 indicates pre_read number is 16. If PRE_NUM is 0, convertor will read data when RD_FIFO is not full and read transaction is not terminated. |
| READ_BEGIN                      | 0x000000aa            | Command for read begin.                                                                                                                                                                            |
| WRITE                           | 0x00000011            | Command for write data.                                                                                                                                                                            |
| WRITE MESSAGE<br>(Message Reg0) | 0x00010011            | Write message register 0.                                                                                                                                                                          |
| WRITE MESSAGE<br>(Message Reg1) | 0x00020011            | Write message register 1 will generate an interrupt.                                                                                                                                               |
| WRITE MESSAGE<br>(CTRL0)        | 0x00030011            | Write the ctrl0 register.                                                                                                                                                                          |

| Command                       | Format     | Description                  |
|-------------------------------|------------|------------------------------|
| QUERY<br>(State)              | 0x000000ff | Query the state register.    |
| QUERY<br>(Message Register 2) | 0x000001ff | Query the message register 2 |

## 30.4 Register Description

### 30.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

| Operational Base |              |
|------------------|--------------|
| Name             | Base Address |
| SPI2APB          | 0xff4c0000   |

### 30.4.2 Registers Summary

| Name               | Offset | Size | Reset Value | Description           |
|--------------------|--------|------|-------------|-----------------------|
| SPI2APB CTRL0      | 0x0000 | W    | 0x00000000  | Control Register 0    |
| SPI2APB SR         | 0x0024 | W    | 0x00000014  | SPI2APB status        |
| SPI2APB IMR        | 0x002C | W    | 0x00000000  | Interrupt Mask        |
| SPI2APB RISR       | 0x0034 | W    | 0x00000000  | Raw Interrupt Status  |
| SPI2APB ICR        | 0x0038 | W    | 0x00000000  | Interrupt Clear       |
| SPI2APB VERSION    | 0x0048 | W    | 0x063B0002  | Version               |
| SPI2APB QUICK REG0 | 0x0050 | W    | 0x00000000  | Quick Write Register0 |
| SPI2APB QUICK REG1 | 0x0054 | W    | 0x00000000  | Quick Write Register1 |
| SPI2APB QUICK REG2 | 0x0058 | W    | 0x00000000  | Quick Read Register2  |

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.3 Detail Registers Description

#### SPI2APB CTRL0

Address: **Operational Base** + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                                                                                                                 |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | RO   | 0x00000000  | reserved                                                                                                                                    |
| 3    | RW   | 0x0         | TXCP<br>1'b0: TX clock is not inverted<br>1'b1: TX clock is inverted                                                                        |
| 2    | RW   | 0x0         | RXCP<br>1'b0: RX clock is not inverted<br>1'b1: RX clock is inverted                                                                        |
| 1    | RW   | 0x0         | EM<br>Serial endian mode can be configured by this bit. APB endian mode is always little endian.<br>1'b0: little endian<br>1'b1: big endian |
| 0    | RW   | 0x0         | FBM<br>1'b0: first bit is LSB<br>1'b1: first bit is MSB                                                                                     |

#### SPI2APB SR

Address: **Operational Base** + offset (0x0024)

| Bit  | Attr | Reset Value | Description                                                           |
|------|------|-------------|-----------------------------------------------------------------------|
| 31:5 | RO   | 0x00000000  | reserved                                                              |
| 4    | RO   | 0x1         | RFE<br>1'b0: Receive FIFO is not empty<br>1'b1: Receive FIFO is empty |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------|
| 3          | RO          | 0x0                | RFF<br>1'b0: Receive FIFO is not full<br>1'b1: Receive FIFO is full                                                       |
| 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 the ss_in signal is active low.<br>1'b0: ss_in is not active<br>1'b1: ss_in is active low |

**SPI2APB IMR**Address: **Operational Base** + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                             |
| 0          | RW          | 0x0                | QWIM<br>1'b0: spi2apb reg1 quick write interrupt is masked<br>1'b1: spi2apb reg1 quick write interrupt is not masked |

**SPI2APB RISR**Address: **Operational Base** + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                              |
| 0          | RO          | 0x0                | QWRIS<br>1'b0: spi2apb reg1 quick write interrupt is not active<br>1'b1: spi2apb reg1 quick write interrupt is active |

**SPI2APB ICR**Address: **Operational Base** + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                    |
| 0          | W1<br>C     | 0x0                | CQWI<br>Write 1 to clear spi2apb quick write reg1 interrupt |

**SPI2APB VERSION**Address: **Operational Base** + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:0       | RO          | 0x063b0002         | VER<br>Version     |

**SPI2APB QUICK REG0**Address: **Operational Base** + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | QWV0<br>SPI master write to this register, and CPU read it. |

**SPI2APB QUICK REG1**Address: **Operational Base** + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | QWV1<br>SPI master write to this register, generate a interrupt, and CPU read it. |

**SPI2APB QUICK REG2**Address: **Operational Base** + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | QRV<br>CPU write a value to this register, and SPI master read it. |

**30.5 Interface Description**

Table 30-3 SPI0 Interface Description

| <b>Module Pin</b> | <b>Dir</b> | <b>Pad Name</b> | <b>IOMUX Setting</b>                          |
|-------------------|------------|-----------------|-----------------------------------------------|
| <b>IOMUX0</b>     |            |                 |                                               |
| SPI2_CSN          | I/O        | GPIO2_B1        | GPIO2_IOC_GPIO2B_IOMUX_S<br>EL_0 [7:4]=4'h2   |
| SPI2_CLK          | I/O        | GPIO2_B0        | GPIO2_IOC_GPIO2B_IOMUX_S<br>EL_0 [3:0]=4'h2   |
| SPI2_MOSI         | I/O        | GPIO2_B2        | GPIO2_IOC_GPIO2B_IOMUX_S<br>EL_0 [11:8]=4'h2  |
| SPI2_MISO         | I/O        | GPIO2_B3        | GPIO2_IOC_GPIO2B_IOMUX_S<br>EL_0 [15:12]=4'h2 |

Notes: I=input, O=output, I/O=input/output.

**30.6 Application Notes**

1. External SPI master should query the transaction state after every write and read operation to ensure the operation is completed correctly.
2. The frequency of clock for APB should be higher or equal to the frequency of SCLK\_IN.

## **Chapter 31 Pulse Width Modulation (PWM)**

### **31.1 Overview**

The Pulse-Width Modulator (PWM) provides a way to generate a pulse periodic waveform for motor control, it can also act as a digital-to-analog converter with some external components.

The PWM Module supports the following common features:

- Support input capture mode
  - Support measures the high/low polarity effective cycles of input waveform
  - Support generates an interrupt at the transition of input waveform polarity
  - Support a 32-bits high polarity capture counter
  - Support a 32-bits low polarity capture counter
  - Support an input filter to remove glitch
- Support continuous mode and one-shot output mode
  - Support a 32-bits period counter
  - Support a 32-bits duty counter
  - Support configure the polarity in inactive state and duty cycle
  - Support center or left aligned mode
  - Support a 16-bit first dimensional repeat counter and an interrupt for reload operation
  - Support a 16-bit second dimensional repeat counter and an interrupt for one-shot operation
  - Support global synchronization of various channels
- Supports two-stage frequency division of working clock

RK3506 support two PWM controllers, they support some individual feature as following:

- PWM0
  - Support 4 channels
  - Support power key capture mode
  - Support generates waveform through lookup table
- PWM1
  - Support 8 channels
  - Support biphasic counter
  - Support clock frequency meter
  - Support clock counter
  - Support IR transmission in NEC with full repeat, NEC with simple repeat, TC9012 or SONY mode

## 31.2 Block Diagram



Fig. 31-1 PWM Block Diagram

The host processor gets access to PWM register through the APB slave interface with 32-bit bus width. PWM controller support 1~8 channels, and the offset address of each channel is 4k-byte as interval. PWM supports one interrupt for each channel, user should refer to interrupt register to know the raw interrupt status when an interrupt is asserted.

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

PWM also supports some additional function, such as clock counter, clock frequency meter and biphasic Counter.

### 31.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 PWM\_HPC register, while the number of the low effective cycles is recorded in the PWM\_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 PWM\_HPC and PWM\_LPC.*



Fig. 31-2 PWM Capture Mode

The PWM supports 32-bits power key capture mode. User can configure 16 power keys to match, the interrupt will be asserted when the capture value matches any one.

### 31.3.2 Continuous Mode

In continuous mode, the PWM channel generates a series of the pulses continuously as expected once the channel is enabled. It supports 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 (PWM\_CTRL.duty\_pol). Once duty cycle number (PWM\_DUTY) is reached, the output is switched to the opposite polarity. After the period number (PWM\_PERIOD) is reached, the output is again switched to the opposite polarity to start another period of desired pulse.



Fig. 31-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 (PWM\_CTRL.duty\_pol). Once one half of duty cycle number (PWM\_DUTY) 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 (PWM\_PERIOD) is reached, the output starts another period of desired pulse.



Fig. 31-4 PWM Continuous Center-aligned Output Mode

PWM support a 16 bits first dimensional repeat counter. A reload interrupt is generated every N+1 periods of the waveform when PWM\_RPT.rpt\_first\_dimensional is configured to N. User can update the duty and period configuration for next N+1 periods when receive the interrupt.

PWM also support generates waveform through lookup table, the duty and period can be updated by lookup table automatic every N+1 periods of the waveform.

Continuous mode will generate the waveform continuously until disabled by user. It's will fix to inactive polarity (PWM\_CTRL.inactive\_pol) when it's disabled.

### 31.3.3 One-shot Mode

In one-shot mode, the PWM channel generates limited periods of waveforms.

In addition to the first dimensional repeat counter, it also supports a 16 bits second dimensional repeat counter. PWM channel will stop and assert an interrupt after second dimensional counter reach M+1 when PWM\_RPT.rpt\_second\_dimensional is configured to M. The total waveform periods are (N + 1) multi by (M + 1).

The reload interrupt and lookup table is also supported in one-shot mode.

The left-aligned and the center-aligned is also supported in one-shot mode.



Fig. 31-5 PWM One-shot Center-aligned Output Mode

### 31.3.4 Clock Counter

PWM support a 64-bits counter which clock can select from any PWM channel input and a clock from system CRU.

### 31.3.5 Clock Frequency Meter

PWM support a 32-bits frequency meter which clock can select from any PWM channel input and a clock from system CRU. It supports a reference clock and timer to schedule a period time, user can calculate the frequency by getting the counter value that counted by the measured clock in the period time.

### 31.3.6 Biphasic Counter

PWM supports biphasic counter which uses two IO to compose an A/B phase channel.

PWM1 controller support 7 channel biphasic counters.

For channel 0~channel5, the A phase is from PWM1\_BIP\_CNTR\_A0~A5 (RM\_IO), the B

phase is from PWM1\_BIP\_CNTR\_B0~B5 (RM\_IO).

For channel 6, the A phase is from PWM1\_CH6 (RM\_IO), the B phase is from PWM1\_CH7 (RM\_IO). The biphasic counter register is only located at PWM1\_CH6. User only needs to configure the IOMUX of PWM1\_CH7.

Biphasic counter support 5 modes as following:

- Mode 0: Single phase increase mode with A-phase.

When A-phase input is OFF->ON, the count increases by 1. In this mode, it can be used as clock frequency meter or clock counter.

- Mode 1: Single phase increase/decrease mode with A-phase.

When the B-phase input is OFF and the A-phase input is OFF->ON, the count increases by 1.

When the B-phase input is ON and the A-phase input is OFF->ON, the count decreases by 1.

- Mode 2: Dual phase with A/B-phase mode.

When the A-phase input is ON and the B-phase input is OFF->ON, the count increases by 1.

When the A-phase input is ON and the B-phase input is ON->OFF, the count decreases by 1.

- Mode 3: Dual phase with A/B-phase 2 times frequency mode.

When the A-phase input is ON and the B-phase input is OFF->ON, the count increases by 1.

When the A-phase input is OFF and the B-phase input is ON->OFF, the count increases by 1.

When the A-phase input is ON and the B-phase input is ON->OFF, the count decreases by 1.

When the A-phase input is OFF and the B-phase input is OFF->ON, the count decreases by 1.

- Mode 4: Dual phase with A/B-phase 4 times frequency mode.

When the input of phase B is OFF and phase A is OFF->ON, the count increases by 1.

When the A-phase input is ON and the B-phase input is OFF->ON, the count increases by 1.

When the input of phase B is ON and phase A is ON->OFF, the count increases by 1.

When the A-phase input is OFF and the B-phase input is ON\_.OFF, the count increases by 1.

When the A-phase input is OFF and the B-phase input is OFF->ON, the count decreases by 1.

When the input of phase B is ON and phase A is OFF->ON, the count decreases by 1.

When the A-phase input is ON and the B-phase input is ON->OFF, the count decreases by 1.

When the input of phase B is OFF and the input of phase A is ON->OFF, the count decreases by 1.

## 31.4 Register Description

### 31.4.1 Internal Address Mapping

Slave address can be divided into different length for different controller, which is shown as follows.

#### Operational Base

| Name | Base Address |
|------|--------------|
| PWM0 | 0xFF930000   |
| PWM1 | 0xFF170000   |

Slave address can be divided into different length for different channels in one controller, which is shown as follows.

Table 31-1 PWM Channel Address Map

| Channel   | Offset Address |
|-----------|----------------|
| Channel 0 | 0x0000         |

|           |        |
|-----------|--------|
| Channel 1 | 0x1000 |
| Channel 2 | 0x2000 |
| Channel 3 | 0x3000 |
| Channel 4 | 0x4000 |
| Channel 5 | 0x5000 |
| Channel 6 | 0x6000 |
| Channel 7 | 0x7000 |

### 31.4.2 Registers Summary

| Name                                       | Offset | Size | Reset Value | Description                                |
|--------------------------------------------|--------|------|-------------|--------------------------------------------|
| PWM VERSION ID                             | 0x0000 | W    | 0x04000044  | Version ID Register                        |
| PWM ENABLE                                 | 0x0004 | W    | 0x00000000  | Enable Register                            |
| PWM CLK CTRL                               | 0x0008 | W    | 0x00000000  | Clock Control Register                     |
| PWM CTRL                                   | 0x000C | W    | 0x00000000  | Control Register                           |
| PWM PERIOD                                 | 0x0010 | W    | 0x00000000  | Period Register                            |
| PWM DUTY                                   | 0x0014 | W    | 0x00000000  | Duty Register                              |
| PWM OFFSET                                 | 0x0018 | W    | 0x00000000  | Output Offset Register                     |
| PWM RPT                                    | 0x001C | W    | 0x00000000  | Repeat Register                            |
| PWM FILTER CTRL                            | 0x0020 | W    | 0x00000000  | Filter Control Register                    |
| PWM CNT                                    | 0x0024 | W    | 0x00000000  | Counter Register                           |
| PWM ENABLE DELAY                           | 0x0028 | W    | 0x00000000  | Enable Delay Register                      |
| PWM HPC                                    | 0x002C | W    | 0x00000000  | High Polarity Capture Register             |
| PWM LPC                                    | 0x0030 | W    | 0x00000000  | Low Polarity Capture Register              |
| PWM_BIPHASIC_COUNTE<br>R_CTRL0             | 0x0040 | W    | 0x00000000  | Biphasic counter control 0 register        |
| PWM_BIPHASIC_COUNTE<br>R_CTRL1             | 0x0044 | W    | 0x00000000  | Biphasic counter control 1 register        |
| PWM_BIPHASIC_COUNTE<br>R_TIMER_VALUE       | 0x0048 | W    | 0x00000000  | Biphasic counter timer value register      |
| PWM_BIPHASIC_COUNTE<br>R_RESULT_VALUE      | 0x004C | W    | 0x00000000  | Biphasic counter result value register     |
| PWM_BIPHASIC_COUNTE<br>R_RESULT_VALUE_SYNC | 0x0050 | W    | 0x00000000  | Biphasic counter result value register     |
| PWM INTSTS                                 | 0x0070 | W    | 0x00000000  | Interrupt Status Register                  |
| PWM INT EN                                 | 0x0074 | W    | 0x00000000  | Interrupt Enable Register                  |
| PWM INT MASK                               | 0x0078 | W    | 0x00000000  | Interrupt Mask Register                    |
| PWM_WAVE_MEM_ARBITE<br>R                   | 0x0080 | W    | 0x00000000  | Waveform Generator Memory Arbiter Register |
| PWM_WAVE_MEM_STATU<br>S                    | 0x0084 | W    | 0x00000000  | Waveform Generator Memory Status Register  |
| PWM_WAVE_CTRL                              | 0x0088 | W    | 0x00000010  | Waveform Generator control register        |
| PWM_WAVE_MAX                               | 0x008C | W    | 0x00000000  | Waveform Generator maximum register        |

| Name                  | Offset | Size | Reset Value | Description                                    |
|-----------------------|--------|------|-------------|------------------------------------------------|
| PWM WAVE MIN          | 0x0090 | W    | 0x00000000  | Waveform Generator minimum register            |
| PWM WAVE OFFSET       | 0x0094 | W    | 0x00000000  | Waveform Generator offset register             |
| PWM WAVE MIDDLE       | 0x0098 | W    | 0x00000000  | Waveform Generator middle register             |
| PWM WAVE HOLD         | 0x009C | W    | 0x00000000  | Waveform Generator hold register               |
| PWM GLOBAL ARBITER    | 0x00C0 | W    | 0x00000000  | Global Arbiter Register                        |
| PWM GLOBAL CTRL       | 0x00C4 | W    | 0x00000000  | Global Control Register                        |
| PWM PWRMATCH ARBITER  | 0x0100 | W    | 0x00000000  | Power Key Match Arbiter Register               |
| PWM PWRMATCH CTRL     | 0x0104 | W    | 0x00000000  | Power Key Match Control Register               |
| PWM PWRMATCH LPRE     | 0x0108 | W    | 0x238C22C4  | Power Key Match of Low Preload Register        |
| PWM PWRMATCH HPRE     | 0x010C | W    | 0x11F81130  | Power Key Match of High Preload Register       |
| PWM PWRMATCH LD       | 0x0110 | W    | 0x029401CC  | Power Key Match of Low Data Register           |
| PWM PWRMATCH HD ZERO  | 0x0114 | W    | 0x029401CC  | Power Key Match of High Data for Zero Register |
| PWM PWRMATCH HD ONE   | 0x0118 | W    | 0x06FE0636  | Power Key Match of High Data for One Register  |
| PWM PWRMATCH VALUE 0  | 0x011C | W    | 0x00000000  | Power Key Match Value 0 Register               |
| PWM PWRMATCH VALUE 1  | 0x0120 | W    | 0x00000000  | Power Key Match Value 1 Register               |
| PWM PWRMATCH VALUE 2  | 0x0124 | W    | 0x00000000  | Power Key Match Value 2 Register               |
| PWM PWRMATCH VALUE 3  | 0x0128 | W    | 0x00000000  | Power Key Match Value 3 Register               |
| PWM PWRMATCH VALUE 4  | 0x012C | W    | 0x00000000  | Power Key Match Value 4 Register               |
| PWM PWRMATCH VALUE 5  | 0x0130 | W    | 0x00000000  | Power Key Match Value 5 Register               |
| PWM PWRMATCH VALUE 6  | 0x0134 | W    | 0x00000000  | Power Key Match Value 6 Register               |
| PWM PWRMATCH VALUE 7  | 0x0138 | W    | 0x00000000  | Power Key Match Value 7 Register               |
| PWM PWRMATCH VALUE 8  | 0x013C | W    | 0x00000000  | Power Key Match Value 8 Register               |
| PWM PWRMATCH VALUE 9  | 0x0140 | W    | 0x00000000  | Power Key Match Value 9 Register               |
| PWM PWRMATCH VALUE 10 | 0x0144 | W    | 0x00000000  | Power Key Match Value 10 Register              |

| Name                     | Offset | Size | Reset Value | Description                                |
|--------------------------|--------|------|-------------|--------------------------------------------|
| PWM_PWRMATCH_VALUE_11    | 0x0148 | W    | 0x00000000  | Power Key Match Value 11 Register          |
| PWM_PWRMATCH_VALUE_12    | 0x014C | W    | 0x00000000  | Power Key Match Value 12 Register          |
| PWM_PWRMATCH_VALUE_13    | 0x0150 | W    | 0x00000000  | Power Key Match Value 13 Register          |
| PWM_PWRMATCH_VALUE_14    | 0x0154 | W    | 0x00000000  | Power Key Match Value 14 Register          |
| PWM_PWRMATCH_VALUE_15    | 0x0158 | W    | 0x00000000  | Power Key Match Value 15 Register          |
| PWM_PWRCAPTURE_VALUE     | 0x015C | W    | 0x00000000  | Power Key Capture Value Register           |
| PWM_IR_TRANS_ARBITER     | 0x0180 | W    | 0x00000000  | Power Key Match Control Register           |
| PWM_IR_TRANS_CTRL0       | 0x0184 | W    | 0x00001F00  | IR Transmission control 0 register         |
| PWM_IR_TRANS_CTRL1       | 0x0188 | W    | 0x00000000  | IR Transmission control 1 register         |
| PWM_IR_TRANS_PRE         | 0x018C | W    | 0x11942328  | IR transmission preload period             |
| PWM_IR_TRANS_SPRE        | 0x0190 | W    | 0x0000008CA | IR transmission simple preload low period  |
| PWM_IR_TRANS_LD          | 0x0194 | W    | 0x000000230 | IR Trans Out Data Low Period               |
| PWM_IR_TRANS_HD          | 0x0198 | W    | 0x069A0230  | IR Trans Out High Period                   |
| PWM_IR_TRANS_BURST_FRAME | 0x019C | W    | 0x2261A5E0  | IR transmission frame and burst period     |
| PWM_IR_TRANS_DATA_VALUE  | 0x01A0 | W    | 0x00000000  | IR Trans Output Data Value                 |
| PWM_IR_TRANS_STATUS      | 0x01A4 | W    | 0x00000001  | IR Trans Status                            |
| PWM_FREQ_ARBITER         | 0x01C0 | W    | 0x00000000  | Frequency Meter Arbiter Control Register   |
| PWM_FREQ_CTRL            | 0x01C4 | W    | 0x00000000  | Frequency Meter control register           |
| PWM_FREQ_TIMER_VALUE     | 0x01C8 | W    | 0x00000000  | Frequency Meter timer value register       |
| PWM_FREQ_RESULT_VALUE    | 0x01CC | W    | 0x00000000  | Frequency Meter result value register      |
| PWM_COUNTER_ARBITER      | 0x0200 | W    | 0x00000000  | Counter Arbiter Control Register           |
| PWM_COUNTER_CTRL         | 0x0204 | W    | 0x00000000  | Counter control register                   |
| PWM_COUNTER_LOW          | 0x0208 | W    | 0x00000000  | Counter Low register                       |
| PWM_COUNTER_HIGH         | 0x020C | W    | 0x00000000  | Counter High register                      |
| PWM_WAVE_MEM             | 0x0400 | W    | 0x00000000  | Waveform Generator Memory Arbiter 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

### 31.4.3 Detail Registers Description

#### PWM VERSION ID

Address: **Operational Base** + offset (0x0000)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:24      | RO          | 0x04               | main_version<br>Main version                         |
| 23:16      | RO          | 0x00               | minor_version<br>Minor version                       |
| 15         | RO          | 0x0                | reserved                                             |
| 14         | RO          | 0x0                | biphasic_counter_support<br>Biphasic counter support |
| 13         | RO          | 0x0                | filter_support<br>Filter support                     |
| 12         | RO          | 0x0                | wave_support<br>Waveform generator support           |
| 11         | RO          | 0x0                | counter_support<br>Counter support                   |
| 10         | RO          | 0x0                | freq_meter_support<br>Frequency meter support        |
| 9          | RO          | 0x0                | power_key_support<br>Power key support               |
| 8          | RO          | 0x0                | ir_trans_support<br>IR transmission support          |
| 7:4        | RO          | 0x4                | channel_index<br>Channel index                       |
| 3:0        | RO          | 0x4                | channel_num_support<br>Channel number support        |

**PWM\_ENABLE**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:6       | RO          | 0x000              | reserved                                                                                                                                                                                                                                                                          |
| 5          | RW          | 0x0                | pwm_cnt_rd_en<br>PWM channel CNT read enable. The CNT can be read for debug.<br>1'b0: Disabled<br>1'b1: Enabled                                                                                                                                                                   |
| 4          | W1T         | 0x0                | pwm_global_join_en<br>PWM join global control enable. When this bit is set to 1, the PWM channel is enabled by pwm_global_en instead of pwm_en, and the following register can be updated at the posedge of pwm_global_ctrl_update_en: PWM_CTRL, PWM_PERIOD, PWM_DUTY, PWM_OFFSET |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                          |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | RW   | 0x0         | force_clk_en<br>1'b0: Disabled, when PWM channel is inactive state, the clk_pwm to PWM Clock pre-scale module is blocked to reduce power consumption.<br>1'b1: Enabled, the clk_pwm to PWM Clock pre-scale module is always enabled. |
| 2   | W1T  | 0x0         | pwm_ctrl_update_en<br>PWM control update enable. The bit will be auto cleaned. The following register can be updated at the posedge of pwm_ctrl_update_en: PWM_CTRL, PWM_PERIOD, PWM_DUTY, PWM_OFFSET                                |
| 1   | RW   | 0x0         | pwm_en<br>PWM enable<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.                                                                              |
| 0   | RW   | 0x0         | pwm_clk_en<br>PWM clock enable<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 CLK CTRL**Address: **Operational Base** + offset (0x0008)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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         | clk_global_sel<br>Clock global selection<br>1'b0: Select current channel scale clock<br>1'b1: Select global channel scale clock                                                                                                                                                                                                                                       |
| 14:13 | RW   | 0x0         | clk_src_sel<br>Clock source selection<br>2'b00: Select clk_pwm as root clock source, Clock is from PLL and the frequency can be configured.<br>2'b01: Select clk_pwm_osc as root clock source, Clock is from crystal oscillator and the frequency is fixed.<br>2'b10: Select clk_pwm_rc as root clock source, Clock is from RC oscillator and the frequency is fixed. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 12:4       | RW          | 0x000              | scale<br>This field defines the scale factor applied to pre-scaled clock. The value N means the clock is divided by $2^N$ . It is valid from 1~256. |
| 3          | RO          | 0x0                | reserved                                                                                                                                            |
| 2:0        | RW          | 0x0                | prescale<br>This field defines the pre-scale factor applied to input clock. The value N means that the input clock is divided by $2^N$ .            |

**PWM CTRL**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:9       | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                           |
| 8:6        | RW          | 0x0                | pwm_in_sel<br>PWM in channel selection, the default value is corresponding channel, User can configure to another channel.<br>3'b000: PWM channel 0<br>3'b001: PWM channel 1<br>3'b010: PWM channel 2<br>3'b011: PWM channel 3<br>3'b100: PWM channel 4<br>3'b101: PWM channel 5<br>3'b110: PWM channel 6<br>3'b111: PWM channel 7 |
| 5          | RW          | 0x0                | aligned_vld_n<br>0: Aligned Mode Valid<br>1: Aligned Mode Invalid                                                                                                                                                                                                                                                                  |
| 4          | RW          | 0x0                | output_mode<br>1'b0: Left aligned mode<br>1'b1: Center aligned mode                                                                                                                                                                                                                                                                |
| 3          | 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                                                                                 |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                   |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | 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                                                                                                                                                     |
| 1:0 | RW   | 0x0         | pwm_mode<br>2'b00: One shot mode, PWM produces the waveform within the repeated times defined by PWMx_CTRL_rpt.<br>2'b01: Continuous mode, PWM produces the waveform continuously.<br>2'b10: Capture mode, PWM measures the cycles of high/low polarity of input waveform.<br>2'b11: Reserved |

### PWM PERIOD

Address: Operational Base + offset (0x0010)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                              |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | PERIOD<br>This value defines the period of the output waveform for continuous mode or one-shot mode. 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 considered and bit [0] always considered as 0. |

### PWM DUTY

Address: Operational Base + offset (0x0014)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                             |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | DUTY<br>This value defines the duty cycle of the output waveform for continuous mode or one-shot mode. 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 considered. |

### PWM OFFSET

Address: Operational Base + offset (0x0018)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                      |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | channel_output_offset<br>If PWM is operated at the continuous mode or one-shot mode, this value defines the offset of the output waveform.<br>This value is based on the PWM clock. The value ranges from 0 to (period-duty).<br>This register takes effect when output aligned mode is invalid. |

### PWM RPT

Address: **Operational Base** + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | <p>rpt_second_dimensional<br/>This field defines the second dimensional repeated effective periods of output waveform. It can be used only in one-shot mode. The second dimensional waveform counter will increase 1 when first dimensional waveform counter reach rpt_first_dimensional. When reach rpt_second_dimensional, the PWM channel will be disabled and the one-shot interrupt will be asserted.</p> <p>The value N means N+1 repeated effective periods. The total waveform number will be (rpt_first_dimensional+1) multiply by (rpt_second_dimensional+1).</p> |
| 15:0       | RW          | 0x0000             | <p>rpt_first_dimensional<br/>This field defines the first dimensional repeated effective periods of output waveform. When reach rpt_first_dimensional, the waveform counter will wrap back to 0 and restart counting and the reload interrupt will be asserted.</p> <p>User can update the configuration in the interrupt.</p> <p>It can be used in one-shot mode and Continuous mode.</p> <p>The value N means N+1 repeated effective periods.</p>                                                                                                                         |

**PWM FILTER CTRL**Address: **Operational Base** + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_enable<br/>Write enable for lower 16 bits, each bit is individual.</p> <p>1'b0: Write access disable<br/>1'b1: Write access enable</p> |
| 15:10      | RO          | 0x00               | reserved                                                                                                                                        |
| 9:4        | RW          | 0x00               | <p>filter_number<br/>Filter window number</p>                                                                                                   |
| 3:1        | RO          | 0x0                | reserved                                                                                                                                        |
| 0          | RW          | 0x0                | <p>filter_enable<br/>1'b0: Disabled<br/>1'b1: Enabled</p>                                                                                       |

**PWM CNT**Address: **Operational Base** + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p>CNT<br/>The 32-bit indicates current value of PWM Channel 0 counter. The counter runs at the rate of PWM clock.</p> <p>The value ranges from 0 to (2^32-1).</p> |

**PWM ENABLE DELAY**

Address: **Operational Base** + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                             |
| 15:0       | RW          | 0x0000             | pwm_enable_delay<br>PWM enable delay |

**PWM\_HPC**Address: **Operational Base** + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | HPC<br>This value indicates the effective high polarity cycles of input waveform for capture mode. This value is based on the PWM clock.<br>The value ranges from 0 to ( $2^{32}-1$ ). |

**PWM\_LPC**Address: **Operational Base** + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | LPC<br>This value indicates the effective low polarity cycles of input waveform for capture mode. This value is based on the PWM clock. The value ranges from 0 to ( $2^{32}-1$ ). |

**PWM\_BIPHASIC COUNTER CTRL0**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 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                | biphasic_counter_mode0_edge_sel<br>biphasic counter phase edge selection for mode 0<br>1'b0: Posedge<br>1'b1: Negedge              |
| 8          | RW          | 0x0                | biphasic_counter_clk_force_en<br>Biphasic counter clock force enable                                                               |
| 7          | W1T         | 0x0                | biphasic_counter_sync_en<br>Biphasic counter synchronous enable                                                                    |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6   | W1T  | 0x0         | <p>timer_clk_switch_mode<br/>Timer clock switch mode, it can set to 1'b1 only when biphasic_counter_mode is mode0.</p> <p>1'b0: Normal mode<br/>1'b1: Switch timer clock and measured clock. It can be used to provide testing accuracy or reduce testing time when the frequency of measured clock is low. It can also be used in scenarios where the start time of the measured clock is uncertain</p> |
| 5:3 | RW   | 0x0         | <p>biphasic_counter_mode<br/>Biphasic counter mode</p> <p>3'h0: Mode0<br/>3'h1: Mode1<br/>3'h2: Mode2<br/>3'h3: Mode3<br/>3'h4: Mode4<br/>Other: Reserved</p>                                                                                                                                                                                                                                            |
| 2   | RW   | 0x0         | <p>biphasic_counter_clk_sel<br/>Biphasic counter clock selection</p> <p>1'b0: Select clk_pwm, clock is from PLL and the frequency can be configured.<br/>1'b1: Select clk_pwm_osc, clock is from crystal oscillator and the frequency is fixed.</p>                                                                                                                                                      |
| 1   | RW   | 0x0         | biphasic_counter_continuous_mode<br>Biphasic counter continuous mode                                                                                                                                                                                                                                                                                                                                     |
| 0   | W1T  | 0x0         | biphasic_counter_en<br>Biphasic counter enable.                                                                                                                                                                                                                                                                                                                                                          |

**PWM\_BIPHASIC\_COUNTER\_CTRL1**Address: **Operational Base** + offset (0x0044)

| Bit   | Attr | Reset Value | Description                                                                                                                                     |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | <p>write_enable<br/>Write enable for lower 16 bits, each bit is individual.</p> <p>1'b0: Write access disable<br/>1'b1: Write access enable</p> |
| 15:11 | RO   | 0x00        | reserved                                                                                                                                        |
| 10:4  | RW   | 0x00        | biphasic_counter_filter_number<br>Filter window number                                                                                          |
| 3:1   | RO   | 0x0         | reserved                                                                                                                                        |
| 0     | RW   | 0x0         | biphasic_counter_filter_enable<br>1'b0: Disabled<br>1'b1: Enabled                                                                               |

**PWM\_BIPHASIC\_COUNTER\_TIMER\_VALUE**Address: **Operational Base** + offset (0x0048)

| Bit  | Attr | Reset Value | Description                                                                                                          |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | biphasic_counter_timer_value<br>Biphasic counter timer value, the unit is one cycle of biphasic counter timer clock. |

**PWM BIPHASIC COUNTER RESULT VALUE**Address: **Operational Base** + offset (0x004C)

| Bit  | Attr | Reset Value | Description                                                                                                                          |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | biphasic_counte_result_value<br>Biphasic counter result value, it can read only after interrupt biphasic_counter_intsts is asserted. |

**PWM BIPHASIC COUNTER RESULT VALUE SYNC**Address: **Operational Base** + offset (0x0050)

| Bit  | Attr | Reset Value | Description                                                                                                                                                          |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | biphasic_counte_result_value_sync<br>Biphasic counter result value with synchronized processing, it can read in real time when biphasic_counter_sync_en is set to 1. |

**PWM INTSTS**Address: **Operational Base** + offset (0x0070)

| Bit   | Attr    | Reset Value | Description                                                                                                                                       |
|-------|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | RO      | 0x000000    | reserved                                                                                                                                          |
| 9     | W1<br>C | 0x0         | biphasic_counter_intsts<br>Biphasic counter interrupt status<br>1'b0: Interrupt not generated<br>1'b1: Interrupt generated                        |
| 8     | W1<br>C | 0x0         | wave_middle_intsts<br>Waveform address access middle address value interrupt status<br>1'b0: Interrupt not generated<br>1'b1: Interrupt generated |
| 7     | W1<br>C | 0x0         | wave_max_intsts<br>Waveform address access maximum address interrupt status<br>1'b0: Interrupt not generated<br>1'b1: Interrupt generated         |
| 6     | W1<br>C | 0x0         | it_trans_end_intsts<br>IR Transmission end interrupt status<br>1'b0: Interrupt not generated<br>1'b1: Interrupt generated                         |
| 5     | W1<br>C | 0x0         | pwr_intsts<br>Power key match interrupt status<br>1'b0: Interrupt not generated<br>1'b1: Interrupt generated                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 4          | W1<br>C     | 0x0                | freq_intsts<br>Frequency meter interrupt status<br>1'b0: Interrupt not generated<br>1'b1: Interrupt generated                        |
| 3          | W1<br>C     | 0x0                | reload_intsts<br>Reload interrupt status<br>1'b0: Interrupt not generated<br>1'b1: Interrupt generated                               |
| 2          | W1<br>C     | 0x0                | oneshot_end_intsts<br>Waveform end interrupt status for one-shot mode.<br>1'b0: Interrupt not generated<br>1'b1: Interrupt generated |
| 1          | W1<br>C     | 0x0                | cap_hpc_intsts<br>HPC interrupt status for capture mode.<br>1'b0: Interrupt not generated<br>1'b1: Interrupt generated               |
| 0          | W1<br>C     | 0x0                | cap_lpc_intsts<br>LPC interrupt status for capture mode.<br>1'b0: Interrupt not generated<br>1'b1: Interrupt generated               |

**PWM INT EN**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 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                | biphasic_couner_int_en<br>Biphasic counter interrupt enable<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled                 |
| 8          | RW          | 0x0                | wave_middle_int_en<br>Waveform address access middle address enable<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled         |
| 7          | RW          | 0x0                | wave_max_int_en<br>Waveform address access maximum address interrupt enable<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled |
| 6          | RW          | 0x0                | it_trans_end_int_en<br>IR Transmission end interrupt enable<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled                 |

| Bit | Attr | Reset Value | Description                                                                                                                   |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------|
| 5   | RW   | 0x0         | pwr_int_en<br>Power key match interrupt enable<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled                         |
| 4   | RW   | 0x0         | freq_int_en<br>Frequency meter interrupt enable<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled                        |
| 3   | RW   | 0x0         | reload_int_en<br>Reload interrupt enable<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled                               |
| 2   | RW   | 0x0         | oneshot_end_int_en<br>Waveform end interrupt enable for one-shot mode.<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled |
| 1   | RW   | 0x0         | cap_hpc_int_en<br>HPC interrupt enable for capture mode<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled                |
| 0   | RW   | 0x0         | cap_lpc_int_en<br>LPC interrupt enable for capture mode<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled                |

**PWM INT MASK**Address: **Operational Base** + offset (0x0078)

| Bit   | Attr | Reset Value | Description                                                                                                                        |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| 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:10 | RO   | 0x00        | reserved                                                                                                                           |
| 9     | RW   | 0x0         | biphasic_counter_int_mask<br>Biphasic counter interrupt mask<br>1'b0: Interrupt not mask<br>1'b1: Interrupt mask                   |
| 8     | RW   | 0x0         | wave_middle_int_mask<br>Waveform address access middle address mask<br>1'b0: Interrupt not mask<br>1'b1: Interrupt mask            |
| 7     | RW   | 0x0         | wave_max_int_mask<br>Waveform address access maximum address interrupt mask<br>1'b0: Interrupt not mask<br>1'b1: Interrupt mask    |

| Bit | Attr | Reset Value | Description                                                                                                            |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------|
| 6   | RW   | 0x0         | it_trans_end_int_mask<br>IR Transmission end interrupt mask<br>1'b0: Interrupt not mask<br>1'b1: Interrupt mask        |
| 5   | RW   | 0x0         | pwr_int_mask<br>Power key match interrupt mask<br>1'b0: Interrupt not mask<br>1'b1: Interrupt mask                     |
| 4   | RW   | 0x0         | freq_int_mask<br>Frequency meter interrupt mask<br>1'b0: Interrupt not mask<br>1'b1: Interrupt mask                    |
| 3   | RW   | 0x0         | reload_Int_mask<br>Reload interrupt mask<br>1'b0: Interrupt not mask<br>1'b1: Interrupt mask                           |
| 2   | RW   | 0x0         | oneshot_end_mask<br>Waveform end interrupt mask for one-shot mode.<br>1'b0: Interrupt not mask<br>1'b1: Interrupt mask |
| 1   | RW   | 0x0         | cap_hpc_int_mask<br>HPC interrupt mask for capture mode<br>1'b0: Interrupt not mask<br>1'b1: Interrupt mask            |
| 0   | RW   | 0x0         | cap_lpc_int_mask<br>LPC interrupt mask for capture mode<br>1'b0: Interrupt not mask<br>1'b1: Interrupt mask            |

**PWM WAVE MEM ARBITER**Address: Operational Base + offset (0x0080)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                          |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | RO   | 0x00        | reserved                                                                                                                                                                                                             |
| 23:16 | RW   | 0x00        | wave_mem_read_lock<br>Each bit controls the read lock of waveform generator memory.<br>Once one channel obtains arbitration, other channels cannot read waveform generator memory.<br>1'b0: Don't lock<br>1'b1: Lock |
| 15:8  | RO   | 0x00        | reserved                                                                                                                                                                                                             |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                  |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | RW   | 0x00        | wave_mem_grant<br>Each bit controls the grant of waveform generator memory for one channel. Once one channel obtains arbitration, other channels cannot write waveform generator memory.<br>1'b0: Don't Grant<br>1'b1: Grant |

**PWM WAVE MEM STATUS**Address: **Operational Base** + offset (0x0084)

| Bit  | Attr | Reset Value | Description                                                              |
|------|------|-------------|--------------------------------------------------------------------------|
| 31:1 | RO   | 0x00000000  | reserved                                                                 |
| 0    | RO   | 0x0         | access_done<br>Indicate the access to waveform generator memory is done. |

**PWM WAVE CTRL**Address: **Operational Base** + offset (0x0088)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                  |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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 | RW   | 0x00        | wave_period_amplify<br>Waveform generator table period value amplify, the value N means amplify by $2^N$ .                                                                                                                                                                                                                   |
| 10:6  | RW   | 0x00        | wave_duty_amplify<br>Waveform generator table duty value amplify, the value N means amplify by $2^N$ .                                                                                                                                                                                                                       |
| 5:4   | RW   | 0x1         | wave_mem_clk_sel<br>Waveform generator memory clock selection<br>2'b00: Select clk_pwm<br>2'b01: Select clk_pwm_osc<br>2'b10: Select clk_pwm_rc                                                                                                                                                                              |
| 3     | RW   | 0x0         | wave_update_mode<br>Waveform generator update mode<br>1'b0: The address will wrap back to minimum address when increase to maximum address, and then increase again.<br>1'b1: The address will change to decreasing when increasing to the maximum address. it will return to increasing when decrease to the minimum value. |
| 2     | RW   | 0x0         | wave_width_mode<br>Waveform generator width mode<br>1'b0: 8bits<br>1'b1: 16bits<br>Note: The table is 8bit, User can compose 16 bits with two adjacent addresses                                                                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | wave_period_en<br>Waveform generator period enable. The period cycle of the output waveform is controlled by waveform generator table instead of register PWM_PERIOD when this bit is set to 1. The period will be updated every waveform number of rpt_first_dimensional. |
| 0          | RW          | 0x0                | wave_duty_en<br>Waveform generator duty enable. The duty cycle of the output waveform is controlled by waveform generator table instead of register PWM_DUTY when this bit is set to 1. The duty will be updated every waveform number of rpt_first_dimensional.           |

### **PWM WAVE MAX**

Address: **Operational Base** + offset (0x008C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                              |
|------------|-------------|--------------------|-------------------------------------------------|
| 31:26      | RO          | 0x00               | reserved                                        |
| 25:16      | RW          | 0x000              | wave_period_max<br>The maximum index of period. |
| 15:10      | RO          | 0x00               | reserved                                        |
| 9:0        | RW          | 0x000              | wave_duty_max<br>The maximum index of duty.     |

### **PWM WAVE MIN**

Address: **Operational Base** + offset (0x0090)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                              |
|------------|-------------|--------------------|-------------------------------------------------|
| 31:26      | RO          | 0x00               | reserved                                        |
| 25:16      | RW          | 0x000              | wave_period_min<br>The minimum index of period. |
| 15:10      | RO          | 0x00               | reserved                                        |
| 9:0        | RW          | 0x000              | wave_duty_min<br>The minimum index of duty.     |

### **PWM WAVE OFFSET**

Address: **Operational Base** + offset (0x0094)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:10      | RO          | 0x000000           | reserved                                                   |
| 9:0        | RW          | 0x000              | wave_offset<br>The initial offset index of duty and period |

### **PWM WAVE MIDDLE**

Address: **Operational Base** + offset (0x0098)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:10      | RO          | 0x000000           | reserved                                            |
| 9:0        | RW          | 0x000              | wave_middle<br>The middle index of duty and period. |

**PWM WAVE HOLD**Address: **Operational Base** + offset (0x009C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x00               | reserved                                                                                              |
| 23:16      | RW          | 0x00               | middle_hold<br>The time to hold at middle index. the unit is waveform number of rpt_first_dimensional |
| 15:8       | RW          | 0x00               | min_hold<br>The time to hold at minimum index. the unit is waveform number of rpt_first_dimensional   |
| 7:0        | RW          | 0x00               | max_hold<br>The time to hold at maximum index. the unit is waveform number of rpt_first_dimensional   |

**PWM GLOBAL ARBITER**Address: **Operational Base** + offset (0x00C0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x00               | reserved                                                                                                                                                                                               |
| 23:16      | RW          | 0x00               | global_read_lock<br>Each bit controls the read lock of global control registers. Once one channel obtains arbitration, other channels cannot read global registers.<br>1'b0: Don't lock<br>1'b1: Lock  |
| 15:8       | RO          | 0x00               | reserved                                                                                                                                                                                               |
| 7:0        | RW          | 0x00               | global_grant<br>Each bit controls the grant of global control for one channel. Once one channel obtains arbitration, other channels cannot write global registers.<br>1'b0: Don't Grant<br>1'b1: Grant |

**PWM GLOBAL CTRL**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:2       | RO          | 0x0000             | reserved                                                                                                                                                                                                               |
| 1          | W1T         | 0x0                | global_pwm_ctrl_update_en<br>PWM global control update enable. The bit will be auto cleaned.<br>The following register can be updated at the posedge of pwm_ctrl_update_en: PWM_CTRL, PWM_PERIOD, PWM_DUTY, PWM_OFFSET |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | global_pwm_en<br>Global PWM enable<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\_PWRMATCH\_ARBITER**Address: **Operational Base** + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x00               | reserved                                                                                                                                                                                                      |
| 23:16      | RW          | 0x00               | pwrkey_read_lock<br>Each bit controls the read lock of power key function. Once one channel obtains arbitration, other channels cannot read power key registers.<br>1'b0: Don't lock<br>1'b1: Lock            |
| 15:8       | RO          | 0x00               | reserved                                                                                                                                                                                                      |
| 7:0        | RW          | 0x00               | pwrkey_grant<br>Each bit controls the grant of power key function for one channel. Once one channel obtains arbitration, other channels cannot write power key registers.<br>1'b0: Don't Grant<br>1'b1: Grant |

**PWM\_PWRMATCH\_CTRL**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 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                | 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 |
| 2          | RW          | 0x0                | pwrkey_capture_ctrl<br>1'b0: Capture the value after interrupt<br>1'b1: Capture the value directly                                                   |
| 1          | RW          | 0x0                | pwrkey_polarity<br>1'b0: PWM in polarity is positive<br>1'b1: PWM in polarity is negative                                                            |
| 0          | RW          | 0x0                | pwrkey_enable<br>1'b0: Disabled<br>1'b1: Enabled                                                                                                     |

**PWM\_PWRMATCH\_LPREG**Address: **Operational Base** + offset (0x0108)

| <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 (0x010C)

| <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 (0x0110)

| <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 (0x0114)

| <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 (0x0118)

| <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 (0x011C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:0       | RW          | 0x00000000         | pwrkey_match_value0<br>Power key match value 0 |

**PWM\_PWRMATCH\_VALUE1**Address: **Operational Base** + offset (0x0120)

| Bit  | Attr | Reset Value | Description                                    |
|------|------|-------------|------------------------------------------------|
| 31:0 | RW   | 0x00000000  | pwrkey_match_value1<br>Power key match value 1 |

**PWM\_PWRMATCH\_VALUE2**Address: **Operational Base** + offset (0x0124)

| Bit  | Attr | Reset Value | Description                                    |
|------|------|-------------|------------------------------------------------|
| 31:0 | RW   | 0x00000000  | pwrkey_match_value2<br>Power key match value 2 |

**PWM\_PWRMATCH\_VALUE3**Address: **Operational Base** + offset (0x0128)

| Bit  | Attr | Reset Value | Description                                    |
|------|------|-------------|------------------------------------------------|
| 31:0 | RW   | 0x00000000  | pwrkey_match_value3<br>Power key match value 3 |

**PWM\_PWRMATCH\_VALUE4**Address: **Operational Base** + offset (0x012C)

| Bit  | Attr | Reset Value | Description                                    |
|------|------|-------------|------------------------------------------------|
| 31:0 | RW   | 0x00000000  | pwrkey_match_value4<br>Power key match value 4 |

**PWM\_PWRMATCH\_VALUES**Address: **Operational Base** + offset (0x0130)

| Bit  | Attr | Reset Value | Description                                    |
|------|------|-------------|------------------------------------------------|
| 31:0 | RW   | 0x00000000  | pwrkey_match_value5<br>Power key match value 5 |

**PWM\_PWRMATCH\_VALUE6**Address: **Operational Base** + offset (0x0134)

| Bit  | Attr | Reset Value | Description                                    |
|------|------|-------------|------------------------------------------------|
| 31:0 | RW   | 0x00000000  | pwrkey_match_value6<br>Power key match value 6 |

**PWM\_PWRMATCH\_VALUE7**Address: **Operational Base** + offset (0x0138)

| Bit  | Attr | Reset Value | Description                                    |
|------|------|-------------|------------------------------------------------|
| 31:0 | RW   | 0x00000000  | pwrkey_match_value7<br>Power key match value 7 |

**PWM\_PWRMATCH\_VALUES**Address: **Operational Base** + offset (0x013C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:0       | RW          | 0x00000000         | pwrkey_match_value8<br>Power key match value 8 |

**PWM\_PWRMATCH\_VALUE9**Address: Operational Base + offset (0x0140)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:0       | RW          | 0x00000000         | pwrkey_match_value9<br>Power key match value 9 |

**PWM\_PWRMATCH\_VALUE10**Address: Operational Base + offset (0x0144)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 31:0       | RW          | 0x00000000         | pwrkey_match_value10<br>Power key match value 10 |

**PWM\_PWRMATCH\_VALUE11**Address: Operational Base + offset (0x0148)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 31:0       | RW          | 0x00000000         | pwrkey_match_value11<br>Power key match value 11 |

**PWM\_PWRMATCH\_VALUE12**Address: Operational Base + offset (0x014C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 31:0       | RW          | 0x00000000         | pwrkey_match_value12<br>Power key match value 12 |

**PWM\_PWRMATCH\_VALUE13**Address: Operational Base + offset (0x0150)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 31:0       | RW          | 0x00000000         | pwrkey_match_value13<br>Power key match value 13 |

**PWM\_PWRMATCH\_VALUE14**Address: Operational Base + offset (0x0154)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 31:0       | RW          | 0x00000000         | pwrkey_match_value14<br>Power key match value 14 |

**PWM\_PWRMATCH\_VALUE15**Address: Operational Base + offset (0x0158)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 31:0       | RW          | 0x00000000         | pwrkey_match_value15<br>Power key match value 15 |

**PWM PWRCAPTURE VALUE**Address: **Operational Base** + offset (0x015C)

| <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 IR TRANS ARBITER**Address: **Operational Base** + offset (0x0180)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x00               | reserved                                                                                                                                                                                                              |
| 23:16      | RW          | 0x00               | it_trans_read_lock<br>Each bit controls the read lock of IR transmission function. Once one channel obtains arbitration, other channels cannot read power key registers.<br>1'b0: Don't lock<br>1'b1: Lock            |
| 15:8       | RO          | 0x00               | reserved                                                                                                                                                                                                              |
| 7:0        | RW          | 0x00               | ir_trans_grant<br>Each bit controls the grant of IR transmission function for one channel. Once one channel obtains arbitration, other channels cannot write power key registers.<br>1'b0: Don't Grant<br>1'b1: Grant |

**PWM IR TRANS CTRL0**Address: **Operational Base** + offset (0x0184)

| <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:14      | RO          | 0x0                | reserved                                                                                                                                                         |
| 13         | RW          | 0x0                | ir_trans_clk_en_force<br>PWM IR Trans Out Function clock enable force.                                                                                           |
| 12:8       | RW          | 0x1f               | ir_trans_length_within_one_frame<br>0x00~0x1F is corresponding to data length 1~32                                                                               |
| 7:4        | RW          | 0x0                | ir_trans_format<br>PWM IR Trans format<br>4'h0: NEC with simple repeat code<br>4'h1: NEC with full repeat code<br>4'h2: TC9012<br>4'h3: SONY<br>Others: reserved |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | it_trans_mode<br>1'b0: One shot mode, PWM produces the waveform within the repeated times defined by ir_trans_rtp_cnt.<br>1'b1: Continuous mode, PWM produces the waveform continuously.                                                                    |
| 2          | RW          | 0x0                | it_trans_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 |
| 1          | RW          | 0x0                | ir_trans_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                                                                                                          |
| 0          | RW          | 0x0                | ir_trans_out_enable<br>1'b0: disable PWM IR Trans Out Function<br>1'b1: enable PWM IR Trans Out Function                                                                                                                                                    |

### **PWM IR TRANS CTRL1**

Address: **Operational Base** + offset (0x0188)

| <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:0       | RW          | 0x0000             | ir_trans_rpt<br>This field defines the repeated number for IR transmission. The value N means N+1 repeated effective periods.      |

### **PWM IR TRANS PRE**

Address: **Operational Base** + offset (0x018C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 31:16      | RW          | 0x1194             | ir_trans_out_high_preload<br>IR Trans Out High Preload Register |
| 15:0       | RW          | 0x2328             | ir_trans_out_low_preload<br>IR Trans Out Low Preload Register   |

### **PWM IR TRANS SPRE**

Address: **Operational Base** + offset (0x0190)

| <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       | RW          | 0x08ca             | ir_trans_out_high_simple_preload<br>PWM IR Trans Out High Simple Preload Register |

**PWM IR TRANS LD**Address: **Operational Base** + offset (0x0194)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                              |
| 15:0       | RW          | 0x0230             | ir_trans_out_data_low_period<br>IR Trans Out Data Low Period Register |

**PWM IR TRANS HD**Address: **Operational Base** + offset (0x0198)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 31:16      | RW          | 0x069a             | ir_trans_out_high_period_for_one<br>IR Trans Out High Period for One Register   |
| 15:0       | RW          | 0x0230             | ir_trans_out_high_period_for_zero<br>IR Trans Out High Period for Zero Register |

**PWM IR TRANS BURST FRAME**Address: **Operational Base** + offset (0x019C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                            |
| 29:20      | RW          | 0x226              | ir_trans_out_burst_period<br>PWM IR Trans Out Burst Period Register |
| 19:18      | RO          | 0x0                | reserved                                                            |
| 17:0       | RW          | 0x1a5e0            | ir_trans_out_frame_period<br>PWM IR Trans Out Frame Period          |

**PWM IR TRANS DATA VALUE**Address: **Operational Base** + offset (0x01A0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ir_trans_out_value<br>PWM IR Trans Out Value Register |

**PWM IR TRANS STATUS**Address: **Operational Base** + offset (0x01A4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                            |
| 0          | RO          | 0x1                | ir_state_idle<br>1'b0: PWM IR Trans Busy<br>1'b1: PWM IR Trans Idle |

**PWM FREQ ARBITER**Address: **Operational Base** + offset (0x01C0)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                          |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | RO   | 0x00        | reserved                                                                                                                                                                                                                             |
| 23:16 | RW   | 0x00        | <p>freq_read_lock<br/>Each bit controls the read lock of frequency meter function. Once one channel obtains arbitration, other channels cannot read frequency meter registers.</p> <p>1'b0: Don't lock<br/>1'b1: Lock</p>            |
| 15:8  | RO   | 0x00        | reserved                                                                                                                                                                                                                             |
| 7:0   | RW   | 0x00        | <p>freq_grant<br/>Each bit controls the grant of frequency meter function for one channel. Once one channel obtains arbitration, other channels cannot write frequency meter registers.</p> <p>1'b0: Don't Grant<br/>1'b1: Grant</p> |

**PWM FREQ CTRL**Address: **Operational Base** + offset (0x01C4)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                     |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | <p>write_enable<br/>Write enable for lower 16 bits, each bit is individual.</p> <p>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                 |
| 15:8  | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                        |
| 7     | RW   | 0x0         | <p>freq_timer_clk_sel<br/>Frequency meter timer clock selection</p> <p>1'b0: Select clk_pwm, clock is from PLL and the frequency can be configured.<br/>1'b1: Select clk_pwm_osc, clock is from crystal oscillator and the frequency is fixed.</p>                                                                                              |
| 6     | W1T  | 0x0         | <p>freq_timer_clk_switch_mode<br/>Timer clock switch mode</p> <p>1'b0: Normal mode<br/>1'b1: Switch timer clock and measured clock. It Can be used to provide testing accuracy or reduce testing time when the frequency of measured clock is low. It can also be used in scenarios where the start time of the measured clock is uncertain</p> |
| 5:3   | RW   | 0x0         | <p>freq_channel_sel<br/>Frequency Meter channel selection. It's valid only when freq_clk_sel set to 1'b0.</p> <p>3'b000: PWM channel 0<br/>3'b001: PWM channel 1<br/>3'b010: PWM channel 2<br/>3'b011: PWM channel 3<br/>3'b100: PWM channel 4<br/>3'b101: PWM channel 5</p>                                                                    |

| Bit | Attr | Reset Value | Description                                                                                                  |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------|
|     |      |             | 3'b110: PWM channel 6<br>3'b111: PWM channel 7                                                               |
| 2   | RO   | 0x0         | reserved                                                                                                     |
| 1   | RW   | 0x0         | freq_clk_sel<br>Frequency Meter clock selection<br>1'b0: Input from PWM IO<br>1'b1: Frequency clock from CRU |
| 0   | W1T  | 0x0         | freq_en<br>Frequency Meter enable.                                                                           |

### **PWM FREQ TIMER VALUE**

Address: **Operational Base** + offset (0x01C8)

| Bit  | Attr | Reset Value | Description                                                                                         |
|------|------|-------------|-----------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | freq_timer_value<br>Frequency Meter timer value, the unit is one cycle frequency meter timer clock. |

### **PWM FREQ RESULT VALUE**

Address: **Operational Base** + offset (0x01CC)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | freq_result_value<br>The frequency result value, the unit is one cycle of tested clock.<br>Once the freq_intsts interrupt is asserted, User can get the frequency by this value.<br><br>When timer_clk_switch_mode set to 1'b0, the frequency result is (freq_timer*freq_result_value)/freq_timer_value. When timer_clk_switch_mode set to 1'b1, the frequency result is (freq_timer*freq_result_value)/freq_result_value.<br>Notes: freq_osc is the frequency of SOC crystal oscillator. |

### **PWM COUNTER ARBITER**

Address: **Operational Base** + offset (0x0200)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                     |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | RO   | 0x00        | reserved                                                                                                                                                                                        |
| 23:16 | RW   | 0x00        | counter_read_lock<br>Each bit controls the read lock of counter function. Once one channel obtains arbitration, other channels cannot read counter registers.<br>1'b0: Don't lock<br>1'b1: Lock |
| 15:8  | RO   | 0x00        | reserved                                                                                                                                                                                        |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                       |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | RW   | 0x00        | <p>counter_grant</p> <p>Each bit controls the grant of counter for one channel. Once one channel obtains arbitration, other channels cannot write counter registers.</p> <p>1'b0: Don't Grant<br/>1'b1: Grant</p> |

**PWM COUNTER CTRL**Address: Operational Base + offset (0x0204)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | <p>write_enable</p> <p>Write enable for lower 16 bits, each bit is individual.</p> <p>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                 |
| 15:7  | RO   | 0x000       | reserved                                                                                                                                                                                                                                                                                                                           |
| 6     | W1T  | 0x0         | <p>counter_clr</p> <p>Counter value clear.</p>                                                                                                                                                                                                                                                                                     |
| 5:3   | RW   | 0x0         | <p>counter_channel_sel</p> <p>Counter channel selection. It's valid only when counter_clk_sel set to 1'b00.</p> <p>3'b000: PWM channel 0<br/>3'b001: PWM channel 1<br/>3'b010: PWM channel 2<br/>3'b011: PWM channel 3<br/>3'b100: PWM channel 4<br/>3'b101: PWM channel 5<br/>3'b110: PWM channel 6<br/>3'b111: PWM channel 7</p> |
| 2:1   | RW   | 0x0         | <p>counter_clk_sel</p> <p>Counter clock selection</p> <p>1'b0: Input from PWM IO<br/>1'b1: Counter clock from CRU</p>                                                                                                                                                                                                              |
| 0     | RW   | 0x0         | <p>counter_en</p> <p>Counter enable.</p>                                                                                                                                                                                                                                                                                           |

**PWM COUNTER LOW**Address: Operational Base + offset (0x0208)

| Bit  | Attr | Reset Value | Description                                                                                                                                                              |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | <p>counter_low_bits</p> <p>Indicates low 32bits of counter value. The value of counter ranges from 0 to <math>2^{64}-1</math>, The unit is one cycle of tested clock</p> |

**PWM COUNTER HIGH**Address: Operational Base + offset (0x020C)

| Bit  | Attr | Reset Value | Description                                                                                                                                               |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | counter_high_bits<br>Indicates high 32bits of the counter value. The value of counter ranges from 0 to $2^{64}-1$ , The unit is one cycle of tested clock |

**PWM WAVE MEM**Address: **Operational Base** + offset (0x0400)

| Bit   | Attr | Reset Value | Description                                                     |
|-------|------|-------------|-----------------------------------------------------------------|
| 31:16 | RO   | 0x0000      | reserved                                                        |
| 15:0  | RW   | 0x0000      | wave_mem_base_address<br>Waveform Generator memory base address |

**31.5 Interface Description**

Table 31-2 PWM Rockchip Matrix IO Interface Description

| Module Pin           | Direction | Rockchip Matrix IO | IOMUX Setting |
|----------------------|-----------|--------------------|---------------|
| PWM0_CH0~CH3         | I/O       | RM_IO              |               |
| PWM1_CH0~CH7         | I/O       | RM_IO              |               |
| PWM1_BIP_CNT_R_A0~A5 | I         | RM_IO              |               |
| PWM1_BIP_CNT_R_B0~B5 | I         | RM_IO              |               |

Notes: I=input, O=output, I/O=input/output. For the configuration of RM\_IO, please refer to chapter "Rockchip Matrix IO".

**31.6 Application Notes****31.6.1 PWM Capture Mode Standard Usage Flow**

1. Set PWM\_ENABLE.pwm\_en to 1'b0 to disable the PWM channel.
2. Set PWM\_CLK\_CTRL.prescale/scale/clk\_src\_sel to configure the clock selection and division.
3. Set PWM\_CTRL.pwm\_mode to 2'b10 to select capture mode.
4. Set PWM\_INT\_EN.cap\_lpc\_int\_en/cap\_hpc\_int\_en to 1'b1 to enable the interrupt.
5. Set PWM\_ENABLE.pwm\_en/pwm\_clk\_en to 1'b1 to enable the channel.
6. When an interrupt is asserted, refer to PWM\_INTSTS register to know the raw interrupt status. User should read the PWM\_HPC register to know the effective high cycles of input waveforms when cap\_hpc\_intsts is asserted and read the PWM\_LPC register to know the effective low cycles when cap\_lpc\_intsts is asserted. User should set 1'b1 to correspond bit of PWM\_INTSTS to clear the interrupt.
7. If user want to disable PWM channel, set PWM\_ENABLE.pwm\_en/pwm\_clk\_en to 1'b0.

**31.6.2 PWM Power Key Capture Mode Standard Usage Flow**

1. Set PWM\_ENABLE.pwm\_en to 1'b0 to disable the PWM channel.
2. Set PWM\_CLK\_CTRL.prescale/scale/clk\_src\_sel to configure the clock selection and division. The clock frequency should be 1 MHz after division.
3. Set PWM\_CTRL.pwm\_mode to 2'b10 to select capture mode.
4. Set PWM\_PWRMATCH\_ARBITER.pwrkey\_grant to 8'b01 to set channel 0 for capture.
5. Set PWM\_INT\_EN.pwr\_int\_en to 1'b1 to enable the interrupt.
6. Set PWM\_PWRMATCH\_VALUE0~15 registers for the 16 power key match value.
7. 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 if the default value can meet the requirement.

8. Set PWM\_PWRMATCH\_CTRL.pwrkey\_polarity for the polarity of power key signal.
9. Set PWM\_PWRMATCH\_CTRL.pwrkey\_enable to 1'b1 to enable power key mode.
10. Set PWM\_FILTER\_CTRL.filter\_number/filter\_enable to enable filter. (Optional).
11. Set PWM\_ENABLE.pwm\_en/pwm\_clk\_en to 1'b1 to enable the channel.
12. When an interrupt is asserted, refer to PWM\_INTSTS register to know the raw interrupt status, and refer to PWM\_PWR\_CAPTURE\_VALUE to know the power key capture value. User should set 1'b1 to correspond bit of PWM\_INTSTS to clear the interrupt.
13. If user want to disable PWM channel, set PWM\_ENABLE.pwm\_en/pwm\_clk\_en to 1'b0.

### **31.6.3 PWM Continuous Standard Usage Flow**

1. Set PWM\_ENABLE.pwm\_en to 1'b0 to disable the PWM channel.
2. Set PWM\_CLK\_CTRL.prescale/scale/clk\_src\_sel to configure the clock selection and division.
3. Set PWM\_CTRL.output\_mode/duty\_pol/inactive\_pol to select output mode, duty polarity and inactive polarity.
4. Set PWM\_PERIOD and PWM\_DUTY register.
5. Set PWM\_RPT.rpt\_first\_dimensional for reload operation (Optional).
6. Set PWM\_CTRL.pwm\_mode to 2'b01 to select continuous mode.
7. Set PWM\_ENABLE.pwm\_en/pwm\_clk\_en to 1'b1 to enable the channel.
8. Set PWM\_PERIOD and DUTY, then set PWM\_ENABLE.pwm\_ctrl\_update\_en to 1'b1 to update configuration (Optional).
9. If user want to disable PWM channel, set PWM\_ENABLE.pwm\_en/pwm\_clk\_en to 1'b0.

### **31.6.4 PWM One-shot Mode Standard Usage Flow**

1. Set PWM\_ENABLE.pwm\_en to 1'b0 to disable the PWM channel.
2. Set PWM\_CLK\_CTRL.prescale/scale/clk\_src\_sel to configure the clock selection and division.
3. Set PWM\_CTRL.output\_mode/duty\_pol/inactive\_pol to select output mode, duty polarity and inactive polarity.
4. Set PWM\_PERIOD and PWM\_DUTY register.
5. Set PWM\_RPT.rpt\_first\_dimensional for reload operation (Option).
6. Set PWM\_RPT.rpt\_second\_dimensional.
7. Set PWM\_CTRL.pwm\_mode to 2'b00 to select one shot mode.
8. Set INT\_EN.oneshot\_end\_int\_en to 1'b1 to enable interrupt.
9. Set PWM\_ENABLE.pwm\_en/pwm\_clk\_en to 1'b1 to enable the channel.
10. When an interrupt is asserted, refer to PWM\_INTSTS register to know the raw interrupt. User should set 1'b1 to correspond bit of PWM\_INTSTS to clear the interrupt.

PWM\_CTRL.pwm\_en/pwm\_clk\_en is automatically cleared.

### **31.6.5 Multi-channel Synchronous Start Usage Flow**

1. Set PWM\_ENABLE.pwm\_en of all synchronous channels to 1'b0 to disable the PWM channel.
2. Set PWM\_CTRL.pwm\_mode/output\_mode/duty\_pol/inactive\_pol, PWM\_PERIOD and PWM\_DUTY register of all synchronous channels.
3. Set PWM\_CLK\_CTRL.prescale/scale/clk\_src\_sel of channel 0 to configure the clock selection and division.
4. Set PWM\_Enable.pwm\_global\_join\_en of all synchronous channels to 1'b1.
5. Enable the INT\_EN.oneshot\_end\_int\_en of channel 0 to enable interrupt generation if the channel is desired to work in the one-shot mode.
6. Set PWM\_ENABLE.pwm\_clk\_en of channel 0 to 1'b1 to enable clock.
7. Set PWM\_GLOBAL\_ARBITER.global\_grant to 8'h01 to set channel 0 as main channel.
8. Set PWM\_GLOBAL\_CTRL.global\_pwm\_en to enable all synchronous channels.
9. Set PWM\_PERIOD and DUTY to all synchronous channel, then set PWM\_GLOBAL\_CTRL.global\_pwm\_ctrl\_update\_en to 1'b1 to update configuration of all synchronous channels (Optional).
10. If user want to disable PWM channel, set PWM\_GLOBAL\_CTRL.global\_pwm\_en to 1'b0, then set PWM\_CTRL.pwm\_clk\_en of channel 0 to 1'b0 to disable clock.

### **31.6.6 IR transmission Usage Flow**

1. Set PWM\_CTRL.pwm\_en to 1'b0 to disable the PWM channel.
2. Set PWM\_CLK\_CTRL.prescale/scale/clk\_src\_sel to configure the clock selection and

- division. The clock frequency should be 1 MHz after division.
3. Set PWM\_CTRL.pwm\_clk\_en to 1'b1 to enable clock.
  4. Set PWM\_IR\_TRANS\_ARBITER.ir\_trans\_grant to 8'b01 to set channel 0 for transmission.
  5. Set PWM\_IR\_TRANS\_CTRL0.format/it\_trans\_mode/ir\_trans\_duty\_pol/ir\_trans\_length\_within\_one\_frame/it\_trans\_inactive\_pol
  6. Set PWM\_IR\_TRANS\_DATA\_VALUE.ir\_trans\_out\_value to the data which need to transmit.
  7. Set the PWM\_IR\_TRANS\_CTRL0.ir\_trans\_rpt if the channel is desired to work in the one-shot mode.
  8. Set PWM\_IR\_TRANS\_CTRL0.transout\_en to 1'b1 to enable PWM IR transmission.
  9. If user want to disable the output waveform, set PWM\_IR\_TRANS\_CTRL0.transout\_en to 1'b0, the channel will be disable at the end of one frame.

### **31.6.7 Clock Counter Usage Flow**

1. Set PWM\_COUNTER\_ARBITER.counter\_grant to 8'h01 to use channel 0.
2. Set PWM\_COUNTER\_CTRL.counter\_clk\_sel/counter\_channel\_sel to select clock.
3. Set PWM\_COUNTER\_CTRL.counter\_en to 1'b1 to enable clock counter.
4. Refer to PWM\_COUNTER\_LOW/ PWM\_COUNTER\_HIGH to gets the counter value.
5. If user want to disable clock counter, set PWM\_COUNTER\_CTRL.counter\_en to 1'b0, then set PWM\_COUNTER\_ARBITER.counter\_grant to 8'h0.

### **31.6.8 Clock Frequency Meter Usage Flow**

1. Set PWM\_FREQ\_ARBITER.freq\_grant to 8'h01 to use channel 0.
2. Set PWM\_FREQ\_CTRL.freq\_clk\_sel/freq\_channel\_sel to select clock.
3. Set PWM\_FREQ\_CTRL.freq\_timer\_clk\_sel to select timer clock.
4. Set PWM\_FREQ\_TIMER\_VALUE.freq\_timer\_value to set timer.
5. Set PWM\_INT\_EN.freq\_int\_en to enable interrupt.
6. Set PWM\_FREQ\_CTRL.freq\_en to 1'b1 to enable clock frequency meter.
7. When an interrupt is asserted, refer to PWM\_INTSTS register to know the raw interrupt. Then refer PWM\_FREQ\_RESULT\_VALUE.freq\_result\_value to get result. The frequency can be calculated as formula: frequency\_timer\* freq\_result\_value/ freq\_timer\_value. User should set 1'b1 to correspond bit of PWM\_INTSTS to clear the interrupt.
8. If user want to disable clock frequency meter, set PWM\_FREQ\_ARBITER.freq\_grant to 8'h0.

### **31.6.9 Biphasic Counter Usage Flow**

1. Set PWM\_BIPHASIC\_COUNTER\_CTRL0.biphasic\_counter\_clk\_sel to select clock.
2. Set PWM\_BIPHASIC\_COUNTER\_CTRL0.biphasic\_counter\_mode to select mode.
3. Set PWM\_BIPHASIC\_COUNTER\_CTRL1.biphasic\_counter\_filter\_number/biphasic\_counter\_filter\_enable to set the filter.
4. Set PWM\_BIPHASIC\_COUNTER\_TIMER\_VALUE. biphasic\_counter\_timer\_value to set timer.
5. Set PWM\_INT\_EN.biphasic\_couner\_int\_en to enable interrupt.
6. Set PWM\_BIPHASIC\_COUNTER\_CTRL0.biphasic\_counter\_en to 1'b1 to enable biphasic counter.
7. When an interrupt is asserted, refer to PWM\_INTSTS register to know the raw interrupt. Then refer PWM\_BIPHASIC\_COUNTER\_RESULT\_VALUE to get the result. User should set 1'b1 to correspond bit of PWM\_INTSTS to clear the interrupt.

### **31.6.10 Generates Waveform Through Lookup Table Usage Flow**

1. Set PWM\_ENABLE.pwm\_en to 1'b0 to disable the PWM channel.
2. Set PWM\_CLK\_CTRL.prescale/scale/clk\_src\_sel to configure the clock selection and division.
3. Set PWM\_CTRL.output\_mode/duty\_pol/inactive\_pol to select output mode, duty polarity and inactive polarity.
4. Set PWM\_PERIOD register, the value should be 1~256.
5. Set PWM\_WAVE\_CTRL.wave\_duty\_en to 1'b1 to enable duty to reload through lookup table.
6. Set PWM\_WAVE\_CTRL.wave\_update\_mode to 1'b1.
7. Set PWM\_WAVE\_MAX.wave\_duty\_max.
8. Set PWM\_WAVE\_MIN.wave\_duty\_min.

9. Set the duty value in lookup table from offset address wave\_duty\_min to wave\_duty\_max. The base address of lookup table is PWM\_WAVE\_MEM.
10. Set PWM\_RPT.rpt\_first\_dimensional for reloading interval.
11. Set PWM\_CTRL.pwm\_mode to 2'b01 to select continuous mode.
12. Set PWM\_ENABLE.pwm\_en/pwm\_clk\_en to 1'b1 to enable the channel.

Rockchip Confidential

## Chapter 32 Inter-Integrated Circuit (I2C)

### 32.1 Overview

The Inter-Integrated Circuit (I2C) is a two wired (SCL and SDA), bi-directional serial bus that provides an efficient and simple method of information exchange between devices. This I2C bus controller supports master mode acting as a bridge between AMBA protocol and generic I2C bus system.

I2C Controller supports the following features:

- Support 3 independent I2C: I2C0~2
- Item Compatible with I2C-bus
- AMBA APB slave interface
- Support master mode of I2C bus
- Software programmable clock frequency and transfer rate up to 400Kbit/sec
- Support 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

### 32.2 Block Diagram



Fig.32-1 I2C Architecture

#### 32.2.1 I2C\_RF

I2C\_RF module is used to control the I2C controller operation by the host with APB interface. It implements the register set and the interrupt functionality. The I2C\_RF component operates synchronously with the APB clock.

#### 32.2.2 I2C\_PE

I2C\_PE module implements the I2C master operation for transmit data to and receive data from other I2C devices. The I2C master controller operates synchronously with the clk\_i2c.

#### 32.2.3 I2C\_TOP

I2C\_TOP module is the top module of the I2C controller.

## 32.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 supports 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.

### 32.3.1 Initialization

The I2C controller is based on AMBA APB bus architecture and usually is part of a SOC. So before I2C operates, some system setting and configuration must be conformed, which includes:

- I2C interrupt connection type: CPU interrupt scheme should be considered. If the I2C interrupt is connected to extra Interrupt Controller module, we need decide the INTC vector.
- I2C Clock Rate: The I2C controller uses the APB clock to configure controller and uses clk\_i2c as the working clock. The correct register setting is subject to the system requirement.

### 32.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 will 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 enters 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 enters 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.32-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.32-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.32-4 I2C Acknowledge

- Byte transfer

The master owns I2C bus might initiate multi byte to transfer to a slave. The transfer starts from a "START" command and ends in a "STOP" command. After every byte transfer, the receiver must reply an ACK to transmitter.



Fig.32-5 I2C Byte Transfer

## 32.4 Register Description

### 32.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

#### Operational Base

| Name | Base Address |
|------|--------------|
| I2C0 | 0xff040000   |
| I2C1 | 0xff050000   |
| I2C2 | 0xff060000   |

### 32.4.2 Registers Summary

| Name            | Offset | Size | Reset Value | Description                                                                                |
|-----------------|--------|------|-------------|--------------------------------------------------------------------------------------------|
| RKI2C CON       | 0x0000 | W    | 0x000060000 | Control register                                                                           |
| RKI2C CLKDIV    | 0x0004 | W    | 0x000000001 | Clock divider register I2C CLK = PCLK / (16*CLKDIV)                                        |
| RKI2C MRXADDR   | 0x0008 | W    | 0x000000000 | The slave address accessed for master rx mode                                              |
| RKI2C MRXRADDR  | 0x000C | W    | 0x000000000 | The slave register address accessed for master rx mode                                     |
| RKI2C MTXCNT    | 0x0010 | W    | 0x000000000 | Master transmit count, specify the total bytes to be transmit (0~32)                       |
| RKI2C MRXCNT    | 0x0014 | W    | 0x000000000 | Master rx count, specify the total bytes to be received(0~32)                              |
| RKI2C IEN       | 0x0018 | W    | 0x000000000 | Interrupt enable register                                                                  |
| RKI2C IPD       | 0x001C | W    | 0x000000000 | Interrupt pending register                                                                 |
| RKI2C FCNT      | 0x0020 | W    | 0x000000000 | Finished count: the count of data which has been transmitted or received for debug purpose |
| RKI2C SCL_OE_DB | 0x0024 | W    | 0x000000020 | Slave hold debounce configure register                                                     |
| RKI2C TXDATA0   | 0x0100 | W    | 0x000000000 | I2C tx data register 0                                                                     |
| RKI2C TXDATA1   | 0x0104 | W    | 0x000000000 | I2C tx data register 1                                                                     |
| RKI2C TXDATA2   | 0x0108 | W    | 0x000000000 | I2C tx data register 2                                                                     |
| RKI2C TXDATA3   | 0x010C | W    | 0x000000000 | I2C tx data register 3                                                                     |
| RKI2C TXDATA4   | 0x0110 | W    | 0x000000000 | I2C tx data register 4                                                                     |
| RKI2C TXDATA5   | 0x0114 | W    | 0x000000000 | I2C tx data register 5                                                                     |
| RKI2C TXDATA6   | 0x0118 | W    | 0x000000000 | I2C tx data register 6                                                                     |
| RKI2C TXDATA7   | 0x011C | W    | 0x000000000 | I2C tx data register 7                                                                     |
| RKI2C RXDATA0   | 0x0200 | W    | 0x000000000 | I2C rx data register 0                                                                     |
| RKI2C RXDATA1   | 0x0204 | W    | 0x000000000 | I2C rx data register 1                                                                     |
| RKI2C RXDATA2   | 0x0208 | W    | 0x000000000 | I2C rx data register 2                                                                     |
| RKI2C RXDATA3   | 0x020C | W    | 0x000000000 | I2C rx data register 3                                                                     |
| RKI2C RXDATA4   | 0x0210 | W    | 0x000000000 | I2C rx data register 4                                                                     |
| RKI2C RXDATA5   | 0x0214 | W    | 0x000000000 | I2C rx data register 5                                                                     |
| RKI2C RXDATA6   | 0x0218 | W    | 0x000000000 | I2C rx data register 6                                                                     |
| RKI2C RXDATA7   | 0x021C | W    | 0x000000000 | I2C rx data register 7                                                                     |
| RKI2C ST        | 0x0220 | W    | 0x000000000 | Status debug register                                                                      |
| RKI2C DBGCTRL   | 0x0224 | W    | 0x000000000 | Debug configuration register                                                               |
| RKI2C CON1      | 0x0228 | W    | 0x000000000 | 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

### 32.4.3 Detail Registers Description

#### RKI2C CON

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                     |
|-------|------|-------------|-------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0006      | version<br>Rki2c version information.                                                           |
| 15:14 | RW   | 0x0         | stop_setup<br>Stop setup configuration.<br>TSU;sto = (stop_setup + 1) * T(SCL_HIGH) + Tclk_i2c. |

## RK3506 TRM (Part 1)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                            |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:12 | RW   | 0x0         | start_setup<br>Start setup config.<br>$TSU;sta = (\text{start\_setup} + 1) * T(\text{SCL\_HIGH}) + \text{Tclk\_i2c}.$<br>$\text{THD};sta = (\text{start\_setup} + 2) * T(\text{SCL\_HIGH}) - \text{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, used to adjust setup/hold time.<br>4'b1n: Thold = (n + 1) * Tclk_i2c.<br>Note: 0 <= n <= 5                                                                                                                                                 |
| 7     | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                               |
| 6     | RW   | 0x0         | act2nak<br>Operation when NAK handshake is received.<br>1'b0: Ignored.<br>1'b1: Stop transaction.                                                                                                                                                                                                                                      |
| 5     | RW   | 0x0         | ack<br>Last byte acknowledge control in master receive mode.<br>1'b0: ACK<br>1'b1: NAK                                                                                                                                                                                                                                                 |
| 4     | RW   | 0x0         | stop<br>Stop enable, when this bit is written to 1, I2C will generate stop signal.                                                                                                                                                                                                                                                     |
| 3     | RW   | 0x0         | start<br>Start enable, when this bit is written to 1, I2C will generate start signal.                                                                                                                                                                                                                                                  |
| 2:1   | RW   | 0x0         | i2c_mode<br>I2c mode select.<br>2'b00: Transmit only.<br>2'b01: Transmit address (device + register address) --> Restart --> Transmit address -> Receive only.<br>2'b10: Receive only.<br>2'b11: Transmit address (device + register address, write/read bit is 1) --> Restart --> Transmit address (device address) --> Receive data. |
| 0     | RW   | 0x0         | i2c_en<br>I2c module enable.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                                                                                          |

### RKI2C\_CLKDIV

Address: **Operational Base** + offset (0x0004)

| Bit   | Attr | Reset Value | Description                                                                                                    |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | CLKDIVH<br>SCL high level clock count.<br>$T(\text{SCL\_HIGH}) = \text{Tclk\_i2c} * (\text{CLKDIVH} + 1) * 8.$ |
| 15:0  | RW   | 0x0001      | CLKDIVL<br>SCL low level clock count.<br>$T(\text{SCL\_LOW}) = \text{Tclk\_i2c} * (\text{CLKDIVL} + 1) * 8.$   |

### RKI2C\_MRXADDR

Address: **Operational Base** + offset (0x0008)

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:27 | RO   | 0x00        | reserved    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------|
| 26         | RW          | 0x0                | addhvlid<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                | addlvlid<br>Address low byte valid.<br>1'b0: Invalid<br>1'b1: Valid                                      |
| 23:0       | RW          | 0x000000           | saddr<br>Master address register.<br>The lowest bit indicate write or read.<br>24 bits address register. |

**RKI2C\_MRXRADDR**Address: **Operational Base** + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:27      | RO          | 0x00               | reserved                                                                |
| 26         | RW          | 0x0                | sraddhvlid<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                | sraddlvlid<br>Address low byte valid.<br>1'b0: Invalid<br>1'b1: Valid   |
| 23:0       | RW          | 0x000000           | sraddr<br>Slave register address accessed.<br>24 bits register address  |

**RKI2C\_MTXCNT**Address: **Operational Base** + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                           |
| 5:0        | RW          | 0x00               | mtxcnt<br>Master transmit count.<br>6 bits counter |

**RKI2C\_MRXCNT**Address: **Operational Base** + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                           |
|------------|-------------|--------------------|----------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                     |
| 5:0        | RW          | 0x00               | mrxcnt<br>Master rx count.<br>6 bits counter |

**RKI2C\_IEN**Address: **Operational Base** + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------|
| 31:9       | RO          | 0x000000           | reserved                                                                                    |
| 8          | RW          | 0x0                | slavehdsdaen<br>Slave hold sda interrupt enable.<br>1'b0: Disable<br>1'b1: Enable           |
| 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:9       | RO          | 0x000000           | reserved                                                                                                                                                        |
| 8          | RW          | 0x0                | slavehdsdaipd<br>Slave hold sda interrupt pending bit.<br>1'b0: No interrupt available.<br>1'b1: Slave hold sda interrupt appear, write 1 to clear.             |
| 7          | RW          | 0x0                | slavehdsclipd<br>Slave hold scl interrupt pending bit.<br>1'b0: No interrupt available.<br>1'b1: Slave hold scl interrupt appear, write 1 to clear.             |
| 6          | W1 C        | 0x0                | nakrcvipd<br>NAK handshake received interrupt pending bit.<br>1'b0: No interrupt available.<br>1'b1: NAK handshake received interrupt appear, write 1 to clear. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | W1<br>C     | 0x0                | stopipd<br>Stop operation finished interrupt pending bit.<br>1'b0: No interrupt available.<br>1'b1: Stop operation finished interrupt appear, write 1 to clear.             |
| 4          | W1<br>C     | 0x0                | startipd<br>Start operation finished interrupt pending bit.<br>1'b0: No interrupt available.<br>1'b1: Start operation finished interrupt appear, write 1 to clear.          |
| 3          | W1<br>C     | 0x0                | mbrfipd<br>MRXCNT data received finished interrupt pending bit.<br>1'b0: No interrupt available.<br>1'b1: MRXCNT data received finished interrupt appear, write 1 to clear. |
| 2          | W1<br>C     | 0x0                | mbtfipd<br>MTXCNT data transfer finished interrupt pending bit.<br>1'b0: No interrupt available.<br>1'b1: MTXCNT data transfer finished interrupt appear, write 1 to clear. |
| 1          | W1<br>C     | 0x0                | brfipd<br>Byte rx finished interrupt pending bit.<br>1'b0: No interrupt available.<br>1'b1: Byte rx finished interrupt appear, write 1 to clear.                            |
| 0          | W1<br>C     | 0x0                | btfipd<br>Byte tx finished interrupt pending bit.<br>1'b0: No interrupt available.<br>1'b1: Byte tx finished interrupt appear, write 1 to clear.                            |

### **RKI2C\_FCNT**

Address: **Operational Base** + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                                            |
| 5:0        | RO          | 0x00               | fcnt<br>The count of data which has been transmitted or received for debug purpose. |

### **RKI2C\_SCL\_OE\_DB**

Address: **Operational Base** + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------|
| 31:8       | RO          | 0x00000000         | reserved                                                                       |
| 7:0        | RW          | 0x20               | scl_oe_db<br>Slave hold scl debounce.<br>Cycles for debounce (unit: Tclk_i2c). |

### **RKI2C\_TXDATA0**

Address: **Operational Base** + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:0       | RW          | 0x00000000         | txdata0<br>Data0 to be transmitted.<br>32 bits data |

### **RKI2C\_TXDATA1**

Address: **Operational Base** + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:0       | RW          | 0x00000000         | txdata1<br>Data1 to be transmitted.<br>32 bits data |

**RKI2C TXDATA2**Address: **Operational Base** + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:0       | RW          | 0x00000000         | txdata2<br>Data2 to be transmitted.<br>32 bits data |

**RKI2C TXDATA3**Address: **Operational Base** + offset (0x010C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:0       | RW          | 0x00000000         | txdata3<br>Data3 to be transmitted.<br>32 bits data |

**RKI2C TXDATA4**Address: **Operational Base** + offset (0x0110)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:0       | RW          | 0x00000000         | txdata4<br>Data4 to be transmitted.<br>32 bits data |

**RKI2C TXDATA5**Address: **Operational Base** + offset (0x0114)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:0       | RW          | 0x00000000         | txdata5<br>Data5 to be transmitted.<br>32 bits data |

**RKI2C TXDATA6**Address: **Operational Base** + offset (0x0118)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:0       | RW          | 0x00000000         | txdata6<br>Data6 to be transmitted.<br>32 bits data |

**RKI2C TXDATA7**Address: **Operational Base** + offset (0x011C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:0       | RW          | 0x00000000         | txdata7<br>Data7 to be transmitted.<br>32 bits data |

**RKI2C RXDATA0**Address: **Operational Base** + offset (0x0200)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:0       | RO          | 0x00000000         | rxdata0<br>Data0 received.<br>32 bits data |

**RKI2C RXDATA1**Address: **Operational Base** + offset (0x0204)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:0       | RO          | 0x00000000         | rxdata1<br>Data1 received.<br>32 bits data |

**RKI2C\_RXDATA2**Address: **Operational Base** + offset (0x0208)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:0       | RO          | 0x00000000         | rxdata2<br>Data2 received.<br>32 bits data |

**RKI2C\_RXDATA3**Address: **Operational Base** + offset (0x020C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:0       | RO          | 0x00000000         | rxdata3<br>Data3 received.<br>32 bits data |

**RKI2C\_RXDATA4**Address: **Operational Base** + offset (0x0210)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:0       | RO          | 0x00000000         | rxdata4<br>Data4 received.<br>32 bits data |

**RKI2C\_RXDATA5**Address: **Operational Base** + offset (0x0214)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:0       | RO          | 0x00000000         | rxdata5<br>Data5 received.<br>32 bits data |

**RKI2C\_RXDATA6**Address: **Operational Base** + offset (0x0218)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:0       | RO          | 0x00000000         | rxdata6<br>Data6 received.<br>32 bits data |

**RKI2C\_RXDATA7**Address: **Operational Base** + offset (0x021C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:0       | RO          | 0x00000000         | rxdata7<br>Data7 received.<br>32 bits data |

**RKI2C\_ST**Address: **Operational Base** + offset (0x0220)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                 |
| 1          | RO          | 0x0                | scl_st<br>SCL status.<br>1'b0: SCL status low.<br>1'b0: SCL status high. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------|
| 0          | RO          | 0x0                | sda_st<br>SDA status.<br>1'b0: SDA status low.<br>1'b0: SDA status high. |

**RKI2C DBGCTRL**

Address: **Operational Base** + offset (0x0224)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15      | RO          | 0x00000            | reserved                                                                                                                                                                              |
| 14         | RW          | 0x0                | h0_check_scl<br>1'b0: Check if scl been pull down by slave at the whole SCL_HIGH.<br>1'b1: Check if scl been pull down by slave only at the h0 of SCL_HIGH(SCL_HIGH including h0~h7). |
| 13         | RW          | 0x0                | nak_release_scl<br>1'b0: Hold scl as low when received nack.<br>1'b1: Release scl as high when received nack.                                                                         |
| 12         | RW          | 0x0                | flt_en<br>SCL 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.                                                                                                        |

**RKI2C CON1**

Address: **Operational Base** + offset (0x0228)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                                                                                                                                          |
| 2          | RW          | 0x0                | auto_stop_nak<br>Auto stop when i2c master received nak from slave.<br>Work when CON1[0]=1'b1.<br>1'b0: Do not auto stop when received nak.<br>1'b1: Auto stop when received nak. |
| 1          | RW          | 0x0                | auto_stop_tx_end<br>Auto stop when i2c master tx end.<br>Work when CON1[0]=1'b1.<br>1'b0: Do not auto stop when tx end.<br>1'b1: Auto stop when tx end.                           |
| 0          | RW          | 0x0                | auto_stop<br>Auto stop when i2c master received nak from slave or tx end.<br>1'b0: Do not auto stop when received nak or tx end.<br>1'b1: Auto stop when received nak or tx end.  |

## 32.5 Interface Description

Table 32-1 I2C Rockchip Matrix IO Interface Description

| Module pin    | Rockchip Matrix IO | IOMUX Setting |
|---------------|--------------------|---------------|
| <b>IOMUX0</b> |                    |               |
| I2C0_SCL      | RM_IO              |               |
| I2C0_SDA      | RM_IO              |               |
| I2C1_SCL      | RM_IO              |               |
| I2C1_SDA      | RM_IO              |               |
| I2C2_SCL      | RM_IO              |               |
| I2C2_SDA      | RM_IO              |               |

Notes: *I*=input, *O*=output, *I/O*=input/output. For the configuration of RM\_IO, please refer to chapter "Rockchip Matrix IO".

## 32.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.32-6 I2C Flow Chat for Transmit Only Mode

- Receive only mode ( $I2C\_CON[1:0]=2'b10$ )



Fig.32-7 I2C Flow Chat for Receive Only Mode

- Mix mode ( $\text{I2C\_CON}[1:0]=2'b01$  or  $\text{I2C\_CON}[1:0]=2'b11$ )



Fig.32-8 I2C Flow Chat for Mix Mode

# Chapter 33 Universal Asynchronous Receiver/Transmitter

## 33.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 controllers: UART0-UART5
- Support APB Slave configuration interface of 8, 16, 32bits
- All contain two 64 Bytes FIFOs for data receive and transmit
- UART3-UART5 support auto flow-control
- UART3-UART5 support RS485 function
- Support bit rates 115.2Kbps, 460.8Kbps, 921.6Kbps, 1.5Mbps, 3Mbps, 4Mbps, 8Mbps
- 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

## 33.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. 33-1 UART Architecture

### APB INTERFACE

The host processor accesses data, control, and status information on the UART through the APB interface. The UART supports APB data bus widths of 8, 16, and 32 bits.

### Register block

Be responsible for the main UART functionality including control, status and interrupt generation.

**Modem Synchronization block**

Synchronizes the modem input signal.

**FIFO block**

Be responsible for FIFO control and storage (when using internal RAM) or signaling to control external RAM (when used).

**Baud Clock Generator**

Generates the transmitter and receiver baud clock along with the output reference clock signal (baudout\_n).

**Serial Transmitter**

Converts the parallel data, written to the UART, into serial form and adds all additional bits, as specified by the control register, for transmission.

**Serial Receiver**

Converts the serial data character (as specified by the control register) received to parallel form. Parity error detection, framing error detection and line break detection is carried out in this block.

### 33.3 Function Description

**UART 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. 33-2 UART Serial protocol

**Baud Clock**

The baud rate is controlled by the serial clock (sclk or pclk in a single clock implementation) and the Divisor Latch Register (DLH and DLL). As the exact number of baud clocks that each bit was transmitted for is known, calculating the mid-point for sampling is not difficult, that is every 16 baud clocks after the mid-point sample of the start bit.



Fig. 33-3 UART Baud Rate

**FIFO Support****1. NONE FIFO MODE**

If FIFO support is not selected, then no FIFOs are implemented and only a single receive data byte and transmit data byte can be stored at a time in the RBR and THR.

**2. FIFO MODE**

The FIFO depth of is 64bytes. The FIFO mode of all the UART is enabled by register FCR[0].

**Interrupts**

The following interrupt types can be enabled with the IER register.

- Receiver Error
- Receiver Data Available
- Character Timeout (in FIFO mode only)

- Transmitter Holding Register Empty at/below threshold (in Programmable THRE Interrupt mode)
- Modem Status

### DMA Support

The UART supports DMA signaling with the use of two output signals (`dma_tx_req_n` and `dma_rx_req_n`) to indicate when data is ready to be read or when the transmit FIFO is empty.

The `dma_tx_req_n` signal is asserted under the following conditions:

- When the Transmitter Holding Register is empty in non-FIFO mode.
- When the transmitter FIFO is empty in FIFO mode with Programmable THRE interrupt mode disabled.
- When the transmitter FIFO is at, or below the programmed threshold with Programmable THRE interrupt mode enabled.

The `dma_rx_req_n` signal is asserted under the following conditions:

- When there is a single character available in the Receive Buffer Register in non-FIFO mode.
- When the Receiver FIFO is at or above the programmed trigger level in FIFO mode.

### Auto Flow Control

The UART can be configured to have a 16750-compatible Auto RTS and Auto CTS serial data flow control mode available. If FIFOs are not implemented, then this mode cannot be selected. When Auto Flow Control mode has been selected, it can be enabled with the Modem Control Register (MCR[5]). Following figure shows a block diagram of the Auto Flow Control functionality.



Fig. 33-4 UART Auto Flow Control Block Diagram

Auto RTS – Becomes active when the following occurs:

- Auto Flow Control is selected during configuration
- FIFOs are implemented
- RTS (MCR[1] bit and MCR[5]bit are both set)
- FIFOs are enabled (FCR[0]) bit is set)
- SIR mode is disabled (MCR[6] bit is not set)



Fig. 33-5 UART AUTO RTS TIMING

Auto CTS – becomes active when the following occurs:

- Auto Flow Control is selected during configuration
- FIFOs are implemented
- AFCE (MCR[5] bit is set)
- FIFOs are enabled through FIFO Control Register FCR[0] bit
- SIR mode is disabled (MCR[6] bit is not set)



Fig. 33-6 UART AUTO CTS TIMING

### RS485 Mode

The RS485 standard supports serial communication over a twisted pair configuration. The difference between the RS232 and RS485 standards is its use of a balanced line for transmission. This usage is also known as the differential format that sends the same signal on two separate lines with phase delay and then compares the signals at the end, subtracts any noise, and adds them to regain signal strength. This process allows the RS485 standard to be viable over significantly longer distances than its short range RS232 counterpart.

UART supports hardware mode and software mode.

- Hardware mode, DE and RE are mutually exclusive. By default 'de' and 're' will be disabled. When at user mode, user should programs the DE to active the 'de', while at auto mode, DE will assert when transfer starts. Once the TX FIFO becomes empty and the stop bit be sampled, 're' signal gets enabled and 'de' signal will be disabled, automatically. In this mode, hardware will consider the de-inactive timing and turn around timing, which are programmed in the DET and TAT register, respectively. When 'de' is valid, it is useless to configure RE, and vice versa.
- Software mode, transmit and receive can happen simultaneously. The user can enable DE, RE at any point of time. Turn around timing as programmed in the TAT register and de-inactive timing as programmed in the DET are not applicable in this mode.

## 33.4 Register Description

### 33.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

#### Operational Base

| Name  | Base Address |
|-------|--------------|
| UART0 | 0xff0a0000   |
| UART1 | 0xff0b0000   |
| UART2 | 0xff0c0000   |
| UART3 | 0xff0d0000   |
| UART4 | 0xff0e0000   |

| Name  | Base Address |
|-------|--------------|
| UART5 | 0xff4e0000   |

### 33.4.2 Registers Summary

| Name       | Offset | Size | Reset Value | Description                          |
|------------|--------|------|-------------|--------------------------------------|
| UART_RBR   | 0x0000 | W    | 0x00000000  | Receive Buffer Register              |
| UART_DLL   | 0x0000 | W    | 0x00000000  | Divisor Latch Low                    |
| UART_THR   | 0x0000 | W    | 0x00000000  | Transmit Buffer Register             |
| UART_DLH   | 0x0004 | W    | 0x00000000  | Divisor Latch High                   |
| UART_IER   | 0x0004 | W    | 0x00000000  | Interrupt Enable Register            |
| UART_FCR   | 0x0008 | W    | 0x00000000  | FIFO Enable                          |
| UART_IIR   | 0x0008 | W    | 0x00000001  | Interrupt Identity Register          |
| UART_LCR   | 0x000C | W    | 0x00000000  | Line Control Register                |
| UART_MCR   | 0x0010 | W    | 0x00000000  | Modem Control Register               |
| UART_LSR   | 0x0014 | W    | 0x00000060  | Line Status Register                 |
| UART_MSR   | 0x0018 | W    | 0x00000000  | Modem Status Register                |
| UART_SCR   | 0x001C | W    | 0x00000000  | Scratchpad Register                  |
| UART_SRBR  | 0x0030 | W    | 0x00000000  | Shadow Receive Buffer Register       |
| UART_STHR  | 0x0030 | W    | 0x00000000  | Shadow Transmit Holding Register     |
| UART_FAR   | 0x0070 | W    | 0x00000000  | FIFO Access Register                 |
| UART_TFR   | 0x0074 | W    | 0x00000000  | Transmit FIFO Read                   |
| UART_RFW   | 0x0078 | W    | 0x00000000  | Receive FIFO write                   |
| UART_USR   | 0x007C | W    | 0x00000006  | UART Status Register                 |
| UART_TFL   | 0x0080 | W    | 0x00000000  | Transmit FIFO level                  |
| UART_RFL   | 0x0084 | W    | 0x00000000  | Receive FIFO level                   |
| UART_SRR   | 0x0088 | W    | 0x00000000  | Software Reset Register              |
| UART_SRTS  | 0x008C | W    | 0x00000000  | Shadow Request to Send               |
| UART_SBCR  | 0x0090 | W    | 0x00000000  | Shadow Break Control Register        |
| UART_SDMAM | 0x0094 | W    | 0x00000000  | Shadow DMA Mode                      |
| UART_SFE   | 0x0098 | W    | 0x00000000  | Shadow FIFO enable                   |
| UART_SRT   | 0x009C | W    | 0x00000000  | Shadow RCVR Trigger                  |
| UART_STET  | 0x00A0 | W    | 0x00000000  | Shadow TX Empty Trigger              |
| UART_HTX   | 0x00A4 | W    | 0x00000000  | Halt TX                              |
| UART_DMASA | 0x00A8 | W    | 0x00000000  | DMA Software Acknowledge             |
| UART_TCR   | 0x00AC | W    | 0x00000000  | Transceiver Control Register         |
| UART_DE    | 0x00B0 | W    | 0x00000000  | Driver Output Enable Register        |
| UART_RE    | 0x00B4 | W    | 0x00000000  | Receiver Output Enable Register      |
| UART_DET   | 0x00B8 | W    | 0x00000000  | Driver Output Enable Timing Register |
| UART_TAT   | 0x00BC | W    | 0x00000000  | Turn Around Timing Register          |
| UART_CPR   | 0x00F4 | W    | 0x00043FF2  | Component Parameter Register         |
| UART_UCV   | 0x00F8 | W    | 0x3430322A  | UART Component Version               |
| UART_CTR   | 0x00FC | W    | 0x44570110  | Component Type Register              |

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

### 33.4.3 Detail Registers Description

#### UART\_RBR

Address: **Operational Base** + offset (0x0000)

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:8 | RO   | 0x00000000  | reserved    |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | RO   | 0x00        | <p>data_input</p> <p>Data byte received on the serial input port (sin) in UART mode, or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line Status Register (LCR) is set. If in non-FIFO mode (FIFO_MODE == NONE) or FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it is overwritten, resulting in an over-run error.</p> <p>If in FIFO mode (FIFO_MODE != NONE) and FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO is preserved, but any incoming data are lost and an over-run error occurs.</p> |

**UART DLL**Address: **Operational Base** + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0000000   | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 7:0  | RW   | 0x00        | <p>baud_rate_divisor_l</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 UART clock should be allowed to pass before transmitting or receiving data.</p> |

**UART THR**Address: **Operational Base** + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0000000   | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 7:0  | WO   | 0x00        | <p>data_output</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)

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:8 | RO   | 0x0000000   | reserved    |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | RW   | 0x00        | <p>baud_rate_divisor_h<br/>Upper 8-bits of a 16-bit, read/write, Divisor Latch register that contains the baud rate divisor for the UART. This register may only be accessed when the DLAB bit (LCR[7]) is set and the UART is not busy (USR[0] is zero). The output baud rate is equal to the serial clock (pclk if one clock design, sclk if two clock design CLOCK_MODE == Enabled)) frequency divided by sixteen times the value of the baud rate divisor, as follows: baud rate = (serial clock freq) / (16 * divisor).</p> <p>Note that with the Divisor Latch Registers (DLL and DLH) set to zero, the baud clock is disabled and no serial communications occur. Also, once the DLH is set, at least 8 clock cycles of the slowest UART clock should be allowed to pass before transmitting or receiving data.</p> |

**UART\_IER**Address: **Operational Base** + offset (0x0004)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                           |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0000000   | reserved                                                                                                                                                                                                                                                                                                                              |
| 7    | RW   | 0x0         | <p>prog_thre_int_en<br/>Programmable THRE Interrupt Mode Enable that can be written to only when THRE_MODE_USER == Enabled, always readable. This is used to enable/disable the generation of THRE Interrupt.<br/>1'b0: Disabled<br/>1'b1: Enabled</p>                                                                                |
| 6:4  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                              |
| 3    | RW   | 0x0         | <p>modem_status_int_en<br/>Enable Modem Status Interrupt. This is used to enable/disable the generation of Modem Status Interrupt. This is the fourth highest priority interrupt.<br/>1'b0: Disabled<br/>1'b1: Enabled</p>                                                                                                            |
| 2    | RW   | 0x0         | <p>receive_line_status_int_en<br/>Enable Receiver Line Status Interrupt. This is used to enable/disable the generation of Receiver Line Status Interrupt. This is the highest priority interrupt.<br/>1'b0: Disabled<br/>1'b1: Enabled</p>                                                                                            |
| 1    | RW   | 0x0         | <p>trans_hold_empty_int_en<br/>Enable Transmit Holding Register Empty Interrupt. This is used to enable/disable the generation of Transmitter Holding Register Empty Interrupt. This is the third highest priority interrupt.<br/>1'b0: Disabled<br/>1'b1: Enabled</p>                                                                |
| 0    | RW   | 0x0         | <p>receive_data_available_int_en<br/>Enable Received Data Available Interrupt. This is used to enable/disable the generation of Received Data Available Interrupt and the Character Timeout Interrupt (if in FIFO mode and FIFOs enabled). These are the second highest priority interrupts.<br/>1'b0: Disabled<br/>1'b1: Enabled</p> |

**UART\_FCR**

Address: **Operational Base** + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 7:6        | WO          | 0x0                | <p>rcvr_trigger<br/>           At which the Received Data Available Interrupt is generated. In auto flow control mode it is used to determine when the rts_n signal is de-asserted. It also determines when the dma_rx_req_n signal is asserted in certain modes of operation. For details on DMA support, refer to "DMA Support". The following trigger levels are supported:<br/>           2'b00: 1 character in the FIFO<br/>           2'b01: FIFO 1/4 full<br/>           2'b10: FIFO 1/2 full<br/>           2'b11: FIFO 2 less than full</p>                                         |
| 5:4        | WO          | 0x0                | <p>tx_empty_trigger<br/>           TX Empty Trigger. Writes have no effect when THRE_MODE_USER == Disabled. This is used to select the empty threshold level at which the THRE Interrupts are generated when the mode is active. It also determines when the dma_tx_req_n signal is asserted when in certain modes of operation. For details on DMA support, refer to "DMA Support". The following trigger levels are supported:<br/>           2'b00: FIFO empty<br/>           2'b01: 2 characters in the FIFO<br/>           2'b10: FIFO 1/4 full<br/>           2'b11: FIFO 1/2 full</p> |
| 3          | WO          | 0x0                | <p>dma_mode<br/>           DMA Mode. This determines the DMA signaling mode used for the dma_tx_req_n and dma_rx_req_n output signals when additional DMA handshaking signals are not selected (DMA_EXTRA == No). For details on DMA support, refer to DMA Support.<br/>           1'b0: Mode 0<br/>           1'b1: Mode 1</p>                                                                                                                                                                                                                                                              |
| 2          | WO          | 0x0                | <p>xmit_fifo_reset<br/>           XMIT FIFO Reset. This resets the control portion of the transmit FIFO and treats the FIFO as empty. This also de-asserts the DMA TX request and single signals when additional DMA handshaking signals are selected (DMA_EXTRA == YES). Note that this bit is 'self-clearing'. It is not necessary to clear this bit.</p>                                                                                                                                                                                                                                  |
| 1          | WO          | 0x0                | <p>rcvr_fifo_reset<br/>           RCVR FIFO Reset. This resets the control portion of the receive FIFO and treats the FIFO as empty. This also de-asserts the DMA RX request and single signals when additional DMA handshaking signals are selected (DMA_EXTRA == YES). Note that this bit is 'self-clearing'. It is not necessary to clear this bit.</p>                                                                                                                                                                                                                                   |
| 0          | WO          | 0x0                | <p>fifo_en<br/>           FIFO Enable. This enables/disables the transmit (XMIT) and receive (RCVR) FIFOs. Whenever the value of this bit is changed both the XMIT and RCVR controller portion of FIFOs is reset.</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           |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:6 | RO   | 0x0         | fifos_en<br>FIFOs Enabled. This is used to indicate whether the FIFOs are enabled or disabled.<br>2'b00: Disabled<br>2'b11: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 5:4 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 3:0 | RO   | 0x1         | int_id<br>Interrupt ID. This indicates the highest priority pending interrupt which can be one of the following types:<br>4'b0000: Modem status<br>4'b0001: No interrupt pending<br>4'b0010: THR empty<br>4'b0100: Received data available<br>4'b0110: Receiver line status<br>4'b0111: Busy detect<br>4'b1100: Character timeout<br>The interrupt priorities are split into four levels that are detailed in Table X.<br>Bit 3 indicates an interrupt can only occur when the FIFOs are enabled and used to distinguish a Character Timeout condition interrupt. |

**UART\_LCR**Address: **Operational Base** + offset (0x000C)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0000000   | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7    | RW   | 0x0         | div_lat_access<br>Divisor Latch Access Bit. Writeable only when UART is not busy (USR[0] is zero), always readable. This bit is used to enable reading and writing of the Divisor Latch register (DLL and DLH) to set the baud rate of the UART. This bit must be cleared after initial baud rate setup in order to access other registers.                                                                                                                                                                                               |
| 6    | RW   | 0x0         | break_ctrl<br>Break Control Bit. This is used to cause a break condition to be transmitted to the receiving device. If set to one the serial output is forced to the spacing (logic 0) state. When not in Loopback Mode, as determined by MCR[4], the sout line is forced low until the Break bit is cleared. If SIR_MODE == Enabled and active (MCR[6] set to one) the sir_out_n line is continuously pulsed. When in Loopback Mode, the break condition is internally looped back to the receiver and the sir_out_n line is forced low. |
| 5    | RW   | 0x0         | stick_parity<br>If UART_16550_COMPATIBLE = NO, then writeable only when UART is not busy (USR[0] is 0); otherwise always writable and always readable. This bit is used to force parity value. When PEN, EPS and Stick Parity are set to 1, the parity bit is transmitted and checked as logic 0. If PEN and Stick Parity are set to 1 and EPS is a logic 0, then parity bit is transmitted and checked as a logic 1. If this bit is set to 0, Stick Parity is disabled.                                                                  |
| 4    | RW   | 0x0         | even_parity_sel<br>Even Parity Select. 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.                                                                                                                                                                                     |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | RW   | 0x0         | <p>parity_en<br/>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_bits_num<br/>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>data_length_sel<br/>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)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                    |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7 | RO   | 0x00000000  | reserved                                                                                                                                                                                                                                                                                                                                                       |
| 6    | RW   | 0x0         | <p>sir_mode_en<br/>SIR Mode Enable. Writeable only when SIR_MODE == Enabled, always readable. This is used to enable/disable the IrDA SIR Mode features as described in "IrDA 1.0 SIR Protocol".</p> <p>1'b0: IrDA SIR Mode disabled<br/>1'b1: IrDA SIR Mode enabled</p>                                                                                       |
| 5    | RW   | 0x0         | <p>auto_flow_ctrl_en<br/>Auto Flow Control Enable. Writeable only when AFCE_MODE == Enabled, always readable. When FIFOs are enabled and the Auto Flow Control Enable (AFCE) bit is set, Auto Flow Control features are enabled as described in "Auto Flow Control".</p> <p>1'b0: Auto Flow Control Mode disabled<br/>1'b1: Auto Flow Control Mode enabled</p> |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4   | RW   | 0x0         | <p>loopback</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>                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 1   | RW   | 0x0         | <p>req_to_send</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>data_terminal_ready</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          | 0x000000           | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7          | RO          | 0x0                | <p>receiver_fifo_error<br/>Receiver FIFO Error bit. This bit is only relevant when FIFO_MODE != NONE AND FIFOs are enabled (FCR[0] set to one). This is used to indicate if there is at least one parity error, framing error, or break indication in the FIFO.</p> <p>1'b0: No error in RX FIFO<br/>1'b1: Error in RX FIFO</p> <p>This bit is cleared when the LSR is read and the character with the error is at the top of the receiver FIFO and there are no subsequent errors in the FIFO.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 6          | RO          | 0x1                | <p>trans_empty<br/>Transmitter Empty bit. If in FIFO mode (FIFO_MODE != NONE) and FIFOs enabled (FCR[0] set to one), this bit is set whenever the Transmitter Shift Register and the FIFO are both empty. If in non-FIFO mode or FIFOs are disabled, this bit is set whenever the Transmitter Holding Register and the Transmitter Shift Register are both empty.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 5          | RO          | 0x1                | <p>trans_hold_reg_empty<br/>Transmit Holding Register Empty bit. If THRE_MODE_USER == Disabled or THRE mode is disabled (IER[7] set to zero) and regardless of FIFO's being implemented/enabled or not, this bit indicates that the THR or TX FIFO is empty.</p> <p>This bit is set whenever data is transferred from the THR or TX FIFO to the transmitter shift register and no new data has been written to the THR or TX FIFO. This also causes a THRE Interrupt to occur, if the THRE Interrupt is enabled. If THRE_MODE_USER == Enabled AND FIFO_MODE != NONE and both modes are active (IER[7] set to one and FCR[0] set to one respectively), the functionality is switched to indicate the transmitter FIFO is full, and no longer controls THRE interrupts, which are then controlled by the FCR[5:4] threshold setting.</p>                                                                                                                     |
| 4          | RO          | 0x0                | <p>break_int<br/>Break Interrupt bit. This is used to indicate the detection of a break sequence on the serial input data. If in UART mode (SIR_MODE == Disabled), it is set whenever the serial input, sin, is held in a logic '0' state for longer than the sum of start time + data bits + parity + stop bits. If in infrared mode (SIR_MODE == Enabled), it is set whenever the serial input, sir_in, is continuously pulsed to logic '0' for longer than the sum of start time + data bits + parity + stop bits. A break condition on serial input causes one and only one character, consisting of all zeros, to be received by the UART. In the FIFO mode, the character associated with the break condition is carried through the FIFO and is revealed when the character is at the top of the FIFO.</p> <p>Reading the LSR clears the BI bit. In the non-FIFO mode, the BI indication occurs immediately and persists until the LSR is read.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3          | RO          | 0x0                | <p>framing_error<br/>Framing Error bit. This is used to indicate the occurrence of a framing error in the receiver. A framing error occurs when the receiver does not detect a valid STOP bit in the received data. In the FIFO mode, since the framing error is associated with a character received, it is revealed when the character with the framing error is at the top of the FIFO. When a framing error occurs, the UART tries to resynchronize. It does this by assuming that the error was due to the start bit of the next character and then continues receiving the other bit i.e. data, and/or parity and stop. It should be noted that the Framing Error (FE) bit (LSR[3]) is set if a break interrupt has occurred, as indicated by Break Interrupt (BI) bit (LSR[4]).</p> <p>1'b0: No framing error<br/>1'b1: Framing error<br/>Reading the LSR clears the FE bit.</p> |
| 2          | RO          | 0x0                | <p>parity_error<br/>Parity Error bit. This is used to indicate the occurrence of a parity error in the receiver if the Parity Enable (PEN) bit (LCR[3]) is set. In the FIFO mode, since the parity error is associated with a character received, it is revealed when the character with the parity error arrives at the top of the FIFO. It should be noted that the Parity Error (PE) bit (LSR[2]) is set if a break interrupt has occurred, as indicated by Break Interrupt (BI) bit (LSR[4]).</p> <p>1'b0: No parity error<br/>1'b1: Parity error<br/>Reading the LSR clears the PE bit.</p>                                                                                                                                                                                                                                                                                        |
| 1          | RO          | 0x0                | <p>overrun_error<br/>Overrun error bit. This is used to indicate the occurrence of an overrun error. This occurs if a new data character was received before the previous data was read. In the non-FIFO mode, the OE bit is set when a new character arrives in the receiver before the previous character was read from the RBR. When this happens, the data in the RBR is overwritten. In the FIFO mode, an overrun error occurs when the FIFO is full and a new character arrives at the receiver. The data in the FIFO is retained and the data in the receive shift register is lost.</p> <p>1'b0: No overrun error<br/>1'b1: Overrun error<br/>Reading the LSR clears the OE bit.</p>                                                                                                                                                                                            |
| 0          | RO          | 0x0                | <p>data_ready<br/>Data Ready bit. This is used to indicate that the receiver contains at least one character in the RBR or the receiver FIFO.</p> <p>1'b0: No data ready<br/>1'b1: Data ready<br/>This bit is cleared when the RBR is read in non-FIFO mode, or when the receiver FIFO is empty, in FIFO mode.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

**UART MSR**Address: **Operational Base** + offset (0x0018)

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

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | RO   | 0x0         | <p>data_carriorn_detect</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>ring_indicator</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>data_set_ready</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 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>                                                                                                                                 |
| 4   | RO   | 0x0         | <p>clear_to_send</p> <p>Clear to Send. This is used to indicate the current state of the modem control line cts_n. This bit is the complement of cts_n. When the Clear to Send input (cts_n) is asserted it is an indication that the modem or data set is ready to exchange data with the UART.</p> <p>1'b0: cts_n input is de-asserted (logic 1)<br/>1'b1: cts_n input is asserted (logic 0)</p> <p>In Loopback Mode (MCR[4] = 1), CTS is the same as MCR[1] (RTS).</p>                                                                                                                                                      |
| 3   | RO   | 0x0         | <p>delta_data_carrier_detect</p> <p>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).</p> <p>Note, if the DDCD bit is not set and the dcd_n signal is asserted (low) and a reset occurs (software or otherwise), then the DDCD bit is set when the reset is removed if the dcd_n signal remains asserted.</p> |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | RO   | 0x0         | <p>trailing_edge_ring_indicator<br/>Trailing Edge of Ring Indicator. This is used to indicate that a change on the input ri_n (from an active-low to an inactive-high state) has occurred since the last time the MSR was read.</p> <p>1'b0: No change on ri_n since last read of MSR<br/>1'b1: Change on ri_n since last read of MSR</p> <p>Reading the MSR clears the TERI bit. In Loopback Mode (MCR[4] = 1), TERI reflects when MCR[2] (Out1) has changed state from a high to a low.</p>                                                                                                                    |
| 1   | RO   | 0x0         | <p>delta_data_set_ready<br/>Delta Data Set Ready. This is used to indicate that the modem control line dsr_n has changed since the last time the MSR was read.</p> <p>1'b0: No change on dsr_n since last read of MSR<br/>1'b1: Change on dsr_n since last read of MSR</p> <p>Reading the MSR clears the DDSR bit. In Loopback Mode (MCR[4] = 1), DDSR reflects changes on MCR[0] (DTR).</p> <p>Note, if the DDSR bit is not set and the dsr_n signal is asserted (low) and a reset occurs (software or otherwise), then the DDSR bit is set when the reset is removed if the dsr_n signal remains asserted.</p> |
| 0   | RO   | 0x0         | <p>delta_clear_to_send<br/>Delta Clear to Send. This is used to indicate that the modem control line cts_n has changed since the last time the MSR was read.</p> <p>1'b0: No change on ctssdr_n since last read of MSR<br/>1'b1: Change on ctssdr_n since last read of MSR</p> <p>Reading the MSR clears the DCTS bit. In Loopback Mode (MCR[4] = 1), DCTS reflects changes on MCR[1] (RTS). Note, if the DCTS bit is not set and the cts_n signal is asserted (low) and a reset occurs (software or otherwise), then the DCTS bit is set when the reset is removed if the cts_n signal remains asserted.</p>    |

**UART SCR**Address: **Operational Base** + offset (0x001C)

| Bit  | Attr | Reset Value | Description                                                                                                                                           |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x000000    | reserved                                                                                                                                              |
| 7:0  | RW   | 0x00        | temp_store_space<br>Scratchpad register. This register is for programmers to use as a temporary storage space. It has no defined purpose in the UART. |

**UART SRBR**Address: **Operational Base** + offset (0x0030)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x000000    | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 7:0  | RO   | 0x00        | shadow_rbr<br>This is a shadow register for the RBR and has been allocated sixteen 32-bit locations (0x30-0x6c) so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If in non-FIFO mode (FIFO_MODE == NONE) or FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it is overwritten, resulting in an overrun error. If in FIFO mode (FIFO_MODE != |

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

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0000000   | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 7:0  | WO   | 0x00        | shadow_thr<br>This is a shadow register for the THR and has been allocated sixteen 32-bit locations(0x30-0x6c) so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If in non-FIFO mode or FIFOs are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If in FIFO mode and FIFOs are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. |

**UART FAR**Address: **Operational Base** + offset (0x0070)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x000000000 | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0    | RW   | 0x0         | fifo_access_test_en<br>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.<br>1'b0: FIFO access mode disabled<br>1'b1: FIFO access mode enabled<br>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. |

**UART TFR**Address: **Operational Base** + offset (0x0074)

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:8 | RO   | 0x0000000   | reserved    |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | RO   | 0x00        | <p>trans_fifo_read<br/>Transmit FIFO Read. These bits are only valid when FIFO access mode is enabled (FAR[0] is set to one). When FIFOs are implemented and enabled, reading this register gives the data at the top of the transmit FIFO. Each consecutive read pops the transmit FIFO and gives the next data value that is currently at the top of the FIFO.</p> <p>When FIFOs are not implemented or not enabled, reading this register gives the data in the THR.</p> |

**UART\_RFW**Address: **Operational Base** + offset (0x0078)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | RO   | 0x000000    | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 9     | WO   | 0x0         | <p>receive_fifo_framing_error<br/>Receive FIFO Framing Error. These bits are only valid when FIFO access mode is enabled (FAR[0] is set to one). When FIFOs are implemented and enabled, this bit is used to write framing error detection information to the receive FIFO. When FIFOs are not implemented or not enabled, this bit is used to write framing error detection information to the RBR.</p>                                                       |
| 8     | WO   | 0x0         | <p>receive_fifo_parity_error<br/>Receive FIFO Parity Error. These bits are only valid when FIFO access mode is enabled (FAR[0] is set to one). When FIFOs are implemented and enabled, this bit is used to write parity error detection information to the receive FIFO. When FIFOs are not implemented or not enabled, this bit is used to write parity error detection information to the RBR.</p>                                                           |
| 7:0   | WO   | 0x00        | <p>receive_fifo_write<br/>Receive FIFO Write Data. These bits are only valid when FIFO access mode is enabled (FAR[0] is set to one). When FIFOs are implemented and enabled, the data that is written to the RFWD is pushed into the receive FIFO. Each consecutive write pushes the new data to the next write location in the receive FIFO. When FIFOs are not implemented or not enabled, the data that is written to the RFWD is pushed into the RBR.</p> |

**UART\_USR**Address: **Operational Base** + offset (0x007C)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                 |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | RO   | 0x00000000  | reserved                                                                                                                                                                                                                                                                                                    |
| 4    | RO   | 0x0         | <p>receive_fifo_full<br/>Receive FIFO Full. This bit is only valid when FIFO_STAT == YES. This is used to indicate that the receive FIFO is completely full.<br/>1'b0: Receive FIFO not full<br/>1'b1: Receive FIFO Full<br/>This bit is cleared when the RX FIFO is no longer full.</p>                    |
| 3    | RO   | 0x0         | <p>receive_fifo_not_empty<br/>Receive FIFO Not Empty. This bit is only valid when FIFO_STAT == YES. This is used to indicate that the receive FIFO contains one or more entries.<br/>1'b0: Receive FIFO is empty<br/>1'b1: Receive FIFO is not empty<br/>This bit is cleared when the RX FIFO is empty.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2          | RO          | 0x1                | <p>trasn_fifo_empty<br/>Transmit FIFO Empty. This bit is only valid when FIFO_STAT == YES. This is used to indicate that the transmit FIFO is completely empty.</p> <p>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.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 1          | RO          | 0x1                | <p>trans_fifo_not_full<br/>Transmit FIFO Not Full. This bit is only valid when FIFO_STAT == YES. This is used to indicate that the transmit FIFO is not full.</p> <p>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.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0          | RO          | 0x0                | <p>uart_busy<br/>UART Busy. This indicates that a serial transfer is in progress, when cleared indicates that the UART is idle or inactive.</p> <p>1'b0: UART is idle or inactive<br/>1'b1: UART is busy (actively transferring data)<br/>Note that it is possible for the UART Busy bit to be cleared even though a new character may have been sent from another device. That is, if the UART has no data in THR and RBR and there is no transmission in progress and a start bit of a new character has just reached the UART. This is due to the fact that a valid start is not seen until the middle of the bit period and this duration is dependent on the baud divisor that has been programmed. If a second system clock has been implemented (CLOCK_MODE == Enabled), the assertion of this bit is also delayed by several cycles of the slower clock.</p> |

**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               | <p>trans_fifo_level<br/>Transmit FIFO Level. This indicates the number of data entries in the transmit FIFO.</p> |

**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               | <p>receive_fifo_level<br/>Receive FIFO Level. This indicates the number of data entries in the receive FIFO.</p> |

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

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | WO   | 0x0         | xmit_fifo_reset<br>XMIT FIFO Reset. This is a shadow register for the XMIT FIFO Reset bit (FCR[2]). This can be used to remove the burden on software having to store previously written FCR values (which are pretty static) just to reset the transmit FIFO. This resets the control portion of the transmit FIFO and treats the FIFO as empty. This also de-asserts the DMA TX request and single signals when additional DMA handshaking signals are selected (DMA_EXTRA == YES). Note that this bit is 'self-clearing'. It is not necessary to clear this bit.  |
| 1   | WO   | 0x0         | rcvr_fifo_reset<br>RCVR FIFO Reset. This is a shadow register for the RCVR FIFO Reset bit (FCR[1]). This can be used to remove the burden on software having to store previously written FCR values (which are pretty static) just to reset the receive FIFO. This resets the control portion of the receive FIFO and treats the FIFO as empty. This also de-asserts the DMA RX request and single signals when additional DMA handshaking signals are selected (DMA_EXTRA == YES).<br>Note that this bit is 'self-clearing'. It is not necessary to clear this bit. |
| 0   | WO   | 0x0         | uart_reset<br>UART Reset. This asynchronously resets the UART and synchronously removes the reset assertion. For a two clock implementation both pclk and sclk domains are reset.                                                                                                                                                                                                                                                                                                                                                                                    |

**UART\_SRTS**Address: **Operational Base** + offset (0x008C)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x00000000  | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0    | RW   | 0x0         | shadow_req_to_send<br>Shadow Request to Send. This is a shadow register for the RTS bit (MCR[1]), this can be used to remove the burden of having to performing a read-modify-write on the MCR. This is used to directly control the Request to Send (rts_n) output. The Request To Send (rts_n) output is used to inform the modem or data set that the UART is ready to exchange data. When Auto RTS Flow Control is not enabled (MCR[5] = 0), the rts_n signal is set low by programming MCR[1] (RTS) to a high. In Auto Flow Control, AFCE_MODE == Enabled and active (MCR[5] = 1) and FIFOs enable (FCR[0] = 1), the rts_n output is controlled in the same way, but is also gated with the receiver FIFO threshold trigger (rts_n is inactive high when above the threshold).<br>Note that in Loopback mode (MCR[4] = 1), the rts_n output is held inactive-high while the value of this location is internally looped back to an input. |

**UART\_SBCR**Address: **Operational Base** + offset (0x0090)

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:1 | RO   | 0x00000000  | reserved    |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | RW   | 0x0         | shadow_break_ctrl<br>Shadow Break Control Bit. This is a shadow register for the Break bit (LCR[6]), this can be used to remove the burden of having to performing a read modify write on the LCR. This is used to cause a break condition to be transmitted to the receiving device. If set to one the serial output is forced to the spacing (logic 0) state. When not in Loopback Mode, as determined by MCR[4], the sout line is forced low until the Break bit is cleared. If SIR_MODE == Enabled and active (MCR[6] = 1) the sir_out_n line is continuously pulsed. When in Loopback Mode, the break condition is internally looped back to the receiver. |

**UART SDMAM**Address: **Operational Base** + offset (0x0094)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x00000000  | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0    | RW   | 0x0         | shadow_dma_mode<br>Shadow DMA Mode. This is a shadow register for the DMA mode bit (FCR[3]). This can be used to remove the burden of having to store the previously written value to the FCR in memory and having to mask this value so that only the DMA Mode bit gets updated. This determines the DMA signalling mode used for the dma_tx_req_n and dma_rx_req_n output signals when additional DMA handshaking signals are not selected (DMA_EXTRA == NO).<br>1'b0: Mode 0<br>1'b1: Mode 1 |

**UART SFE**Address: **Operational Base** + offset (0x0098)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x00000000  | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0    | RW   | 0x0         | shadow_fifo_en<br>Shadow FIFO Enable. This is a shadow register for the FIFO enable bit (FCR[0]). This can be used to remove the burden of having to store the previously written value to the FCR in memory and having to mask this value so that only the FIFO enable bit gets updated. This enables/disables the transmit (XMIT) and receive (RCVR) FIFOs. If this bit is set to zero (disabled) after being enabled then both the XMIT and RCVR controller portion of FIFOs are reset. |

**UART SRT**Address: **Operational Base** + offset (0x009C)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | RO   | 0x00000000  | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 1:0  | RW   | 0x0         | shadow_rcvr_trigger<br>Shadow RCVR Trigger. This is a shadow register for the RCVR trigger bits (FCR[7:6]). This can be used to remove the burden of having to store the previously written value to the FCR in memory and having to mask this value so that only the RCVR trigger bit gets updated. This is used to select the trigger level in the receiver FIFO at which the Received Data Available Interrupt is generated. It also determines when the dma_rx_req_n signal is asserted when DMA Mode (FCR[3]) = 1. The following trigger levels are supported: |

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

### **UART STET**

Address: **Operational Base** + offset (0x00A0)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | RO   | 0x00000000  | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1:0  | RW   | 0x0         | shadow_tx_empty_trigger<br>Shadow TX Empty Trigger. This is a shadow register for the TX empty trigger bits (FCR[5:4]). This can be used to remove the burden of having to store the previously written value to the FCR in memory and having to mask this value so that only the TX empty trigger bit gets updated. This is used to select the empty threshold level at which the THRE Interrupts are generated when the mode is active. The following trigger levels are supported:<br>2'b00: FIFO empty<br>2'b01: 2 characters in the FIFO<br>2'b10: FIFO 1/4 full<br>2'b11: FIFO 1/2 full |

### **UART HTX**

Address: **Operational Base** + offset (0x00A4)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                               |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x00000000  | reserved                                                                                                                                                                                                                                                                                                                                  |
| 0    | RW   | 0x0         | halt_tx_en<br>This register is use to halt transmissions for testing, so that the transmit FIFO can be filled by the master when FIFOs are implemented and enabled.<br>1'b0: Halt TX disabled<br>1'b1: Halt TX enabled<br>Note, if FIFOs are implemented and not enabled, the setting of the halt TX register has no effect on operation. |

### **UART DMASA**

Address: **Operational Base** + offset (0x00A8)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x00000000  | reserved                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0    | WO   | 0x0         | dma_software_ack<br>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 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. |

### **UART TCR**

Address: **Operational Base** + offset (0x00AC)

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:6 | RO   | 0x00000000  | reserved    |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5   | RW   | 0x0         | auto_de<br>Assert DE Automatically Enable. When data is written to the TXFIFO, the DE will automatically asserted, meanwhile, the RE will automatically de-asserted.<br>1'b0: Disable.<br>1'b1: Enable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4   | RW   | 0x0         | re_pol<br>Receiver Enable Polarity.<br>1'b0: re signal is active low.<br>1'b1: re signal is active high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 3   | RW   | 0x0         | de_pol<br>Driver Enable Polarity.<br>1'b0: de signal is active high.<br>1'b1: de signal is active low.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 2   | RW   | 0x0         | xfer_mode<br>Transfer Mode.<br>1'b0: Hardware mode, DE and RE are mutually exclusive. By default 'de' and 're' will be disabled. User should programs the DE to active the 'de'. Once the TX FIFO becomes empty and the stop bit be sampled, 're' signal gets enabled and 'de' signal will be disabled, automatically. In this mode, hardware will consider the de-inactive timing and turn around timing (applied for 4 wire mode only), which are programmed in the DET and TAT register, respectively. When 'de' is valid, it is useless to configure RE, and vice versa.<br>1'b1: Software mode, transmit and receive can happen simultaneously. The user can enable DE, RE at any point of time. Turn around timing as programmed in the TAT register and de-inactive timing as programmed in the DET are not applicable in this mode. |
| 1   | RW   | 0x0         | re_en<br>Receiver Enable.<br>1'b0: RE signal disable, DE control both transmit and receive process. Correspondingly, assert DE for transmit state, while de-assert DE for receive state. In this scenario, RE-associated logics and TAT register will hold constant for lower power consumption.<br>1'b1: RE signal enable, DE control the transmit process, and RE control the receive process.                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0   | RW   | 0x0         | rs485_en<br>RS485 Enable.<br>1'b0: In this mode, the transfers are still in the RS232 mode. The registers of DE, RE, DET and TAT are reserved.<br>1'b1: In this mode, the transfers will happen in RS485 mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

**UART DE**Address: **Operational Base** + offset (0x00B0)

| Bit  | Attr | Reset Value | Description                                                                                                                                            |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x00000000  | reserved                                                                                                                                               |
| 0    | RW   | 0x0         | de<br>The 'de' register bit is used to control assertion and de-assertion of 'de' signal.<br>1'b0: De-assert 'de' signal.<br>1'b1: Assert 'de' signal. |

**UART RE**Address: **Operational Base** + offset (0x00B4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                                                  |
| 0          | RW          | 0x0                | <p>re</p> <p>The 're' register bit is used to control assertion and de-assertion of 're' signal.</p> <p>1'b0: De-assert 're' signal.</p> <p>1'b1: Assert 're' signal.</p> |

**UART DET**Address: **Operational Base** + offset (0x00B8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 15:0       | RW          | 0x0000             | <p>de_inact_time</p> <p>This field controls the amount of time (in terms of number of pclk periods) between the finish flag after the sampling point of the stop bit on the sout to the falling edge of Driver output enable signal. Note that, the mentioned finish flag, i.e. the actual starting effective point of the count, is located at the position of (DLL+1) sclk periods before the full stop bit ends, followed by 3~4 synchronization pclk periods. The actual time is the programmed value + 1.</p> |

**UART TAT**Address: **Operational Base** + offset (0x00BC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                       |
| 15:0       | RW          | 0x0000             | <p>de2re_time</p> <p>Turn around time (in terms of pclk) for DE De-assertion to RE assertion. The actual time is the programmed value + 1.</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          | 0x04               | <p>fifo_mode</p> <p>8'h4 means FIFO mode is 64.</p>                               |
| 15:14      | RO          | 0x0                | reserved                                                                          |
| 13         | RO          | 0x1                | <p>dma_extra</p> <p>1'b1 means DMA_EXTRA enabled.</p>                             |
| 12         | RO          | 0x1                | <p>uart_add_encoded_params</p> <p>1'b1 means UART_ADD_ENCODED_PARAMS enabled.</p> |
| 11         | RO          | 0x1                | <p>shadow</p> <p>1'b1 means SHADOW mode enabled.</p>                              |
| 10         | RO          | 0x1                | <p>fifo_stat</p> <p>1'b1 means FIFO_STAT enabled.</p>                             |
| 9          | RO          | 0x1                | <p>fifo_access</p> <p>1'b1 means FIFO ACCESS enabled.</p>                         |
| 8          | RO          | 0x1                | <p>new_feat</p> <p>1'b1 means Additional features enabled.</p>                    |
| 7          | RO          | 0x1                | <p>sir_lp_mode</p> <p>1'b1 means SIR_LP mode enabled.</p>                         |
| 6          | RO          | 0x1                | <p>sir_mode</p> <p>1'b1 means SIR mode enabled.</p>                               |
| 5          | RO          | 0x1                | <p>thre_mode</p> <p>1'b1 means THRE mode enabled.</p>                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 4          | RO          | 0x1                | afce_mode<br>1'b1 means AFCE mode enabled.             |
| 3:2        | RO          | 0x0                | reserved                                               |
| 1:0        | RO          | 0x2                | apb_data_width<br>2'b10 means APB data width is 32bit. |

### **UART UCV**

Address: **Operational Base** + offset (0x00F8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:0       | RO          | 0x3430322a         | ver<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         | peripheral_id<br>This register contains the peripherals identification code. |

## **33.5 Interface Description**

Table 33-1 UART0 Interface Description

| <b>Module Pin</b> | <b>Dir</b> | <b>Pad Name</b> | <b>IOMUX Setting</b>                         |
|-------------------|------------|-----------------|----------------------------------------------|
| <b>IOMUX0</b>     |            |                 |                                              |
| uart0_rx          | I          | GPIO0_C7        | GPIO0_IOC_GPIO0C_IOM<br>UX_SEL_1[15:12]=4'h2 |
| uart0_tx          | O          | GPIO0_C6        | GPIO0_IOC_GPIO0C_IOM<br>UX_SEL_1[11:8]=4'h2  |

Notes: I=input, O=output, I/O=input/output.

Table 33-2 UART1 Rockchip Matrix IO Interface Description

| <b>Module Pin</b> | <b>Dir</b> | <b>Rockchip Matrix IO</b> | <b>IOMUX Setting</b> |
|-------------------|------------|---------------------------|----------------------|
| <b>IOMUX0</b>     |            |                           |                      |
| uart_rx           | I          | RM_IO                     |                      |
| uart_tx           | O          | RM_IO                     |                      |

Notes: I=input, O=output, I/O=input/output. For the configuration of RM\_IO, please refer to chapter "Rockchip Matrix IO".

Table 33-3 UART2 Rockchip Matrix IO Interface Description

| <b>Module Pin</b> | <b>Dir</b> | <b>Rockchip Matrix IO</b> | <b>IOMUX Setting</b> |
|-------------------|------------|---------------------------|----------------------|
| <b>IOMUX0</b>     |            |                           |                      |
| uart_rx           | I          | RM_IO                     |                      |
| uart_tx           | O          | RM_IO                     |                      |

Notes: I=input, O=output, I/O=input/output. For the configuration of RM\_IO, please refer to chapter "Rockchip Matrix IO".

Table 33-4 UART3 Rockchip Matrix IO Interface Description

| <b>Module Pin</b> | <b>Dir</b> | <b>Rockchip Matrix IO</b> | <b>IOMUX Setting</b> |
|-------------------|------------|---------------------------|----------------------|
| <b>IOMUX0</b>     |            |                           |                      |
| uart_rx           | I          | RM_IO                     |                      |
| uart_tx           | O          | RM_IO                     |                      |
| uart_cts_n        | I          | RM_IO                     |                      |
| uart_re           | O          |                           |                      |
| uart_rts_n        | O          | RM_IO                     |                      |
| uart_de           |            |                           |                      |

Notes: I=input, O=output, I/O=input/output. For the configuration of RM\_IO, please refer to chapter "Rockchip Matrix IO".

Table 33-5 UART4 Rockchip Matrix IO Interface Description

| <b>Module Pin</b> | <b>Dir</b> | <b>Rockchip Matrix IO</b> | <b>IOMUX Setting</b> |
|-------------------|------------|---------------------------|----------------------|
| <b>IOMUX0</b>     |            |                           |                      |
| uart_rx           | I          |                           |                      |

| <b>IOMUX0</b> |   |       |  |
|---------------|---|-------|--|
| uart_rx       | I | RM_IO |  |
| uart_tx       | O | RM_IO |  |
| uart_cts_n    | I | RM_IO |  |
| uart_re       | O |       |  |
| uart_rts_n    | O | RM_IO |  |
| uart_de       | O |       |  |

Notes: I=input, O=output, I/O=input/output. For the configuration of RM\_IO, please refer to chapter "Rockchip Matrix IO".

Table 33-6 UART5 Rockchip Matrix IO Interface Description

| <b>Module Pin</b> | <b>Dir</b> | <b>Pad Name</b> | <b>IOMUX Setting</b>                           |
|-------------------|------------|-----------------|------------------------------------------------|
| <b>IOMUX0</b>     |            |                 |                                                |
| uart_rx           | I          | GPIO3_B4        | GPIO3_IOC_GPIO3B_IOM<br>UX_SEL_0[15:12] = 4'h1 |
| uart_tx           | O          | GPIO3_B3        | GPIO3_IOC_GPIO3B_IOM<br>UX_SEL_1[3:0] = 4'h1   |
| uart_cts_n        | I          | GPIO3_B2        | GPIO3_IOC_GPIO3B_IOM<br>UX_SEL_0[11:8] = 4'h1  |
| uart_re           | O          |                 | GPIO3_IOC_GPIO3B_IOM<br>UX_SEL_1[7:4] = 4'h1   |
| uart_rts_n        | O          | GPIO3_B5        | GPIO3_IOC_GPIO3B_IOM<br>UX_SEL_1[7:4] = 4'h1   |
| uart_de           | O          |                 |                                                |
| <b>IOMUX1</b>     |            |                 |                                                |
| uart_rx           | I          | GPIO1_D3        | GPIO1_IOC_GPIO1D_IOM<br>UX_SEL_0[15:12] = 4'h6 |
| uart_tx           | O          | GPIO1_D2        | GPIO1_IOC_GPIO1D_IOM<br>UX_SEL_0[11:8] = 4'h6  |
| uart_cts_n        | I          | GPIO1_B1        | GPIO1_IOC_GPIO1B_IOM<br>UX_SEL_0[7:4] = 4'h6   |
| uart_re           | O          |                 | GPIO1_IOC_GPIO1D_IOM<br>UX_SEL_0[7:4] = 4'h6   |
| uart_rts_n        | O          | GPIO1_D1        | GPIO1_IOC_GPIO1D_IOM<br>UX_SEL_0[7:4] = 4'h6   |
| uart_de           | O          |                 |                                                |

Notes: I=input, O=output, I/O=input/output.

## **33.6 Application Notes**

### **33.6.1 No FIFO Mode Transfer Flow**



Fig. 33-7 UART None FIFO Mode

### **33.6.2 FIFO Mode Transfer Flow**



Fig. 33-8 UART FIFO Mode

The UART is an APB slave performing:

Serial-to-parallel conversion on data received from a peripheral device. Parallel-to-serial conversion on data transmitted to the peripheral device. The CPU reads and writes data and control/status information through the APB interface. The transmitting and receiving paths are buffered with internal FIFO memories enabling up to 64-bytes to be stored independently in both transmit and receive modes. A baud rate generator can generate a common transmit and receive internal clock input. The baud rates will depend on the internal clock frequency. The UART will also provide transmit, receive and exception interrupts to system. A DMA interface is implemented for improving the system performance.

### 33.6.3 Baud Rate Calculation

#### UART clock generation

UARTs source clocks (SCLK) can be selected from different PLL outputs, or from XIN24M. SCLK can be divided to different frequency, please refer to CRU chapter.

#### UART baud rate configuration

The following table provides some reference configuration for different UART baud rates.

Table 33-7 UART Baud Rate Configuration

| Baud Rate  | Reference Configuration                                                                                                                                                                                                                         |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 115.2 Kbps | Configure PLL to get 1188MHz clock output; Divide 1188MHz clock by 1536/24750 to get 73.728MHz clock by shared fractional divider; Divide 73.728MHz clock by 20 to get 3.6864MHz clock by independent integer divider; Configure UART_DLL to 2. |
| 460.8 Kbps | Configure PLL to get 1188MHz clock output; Divide 1188MHz clock by 1536/24750 to get 73.728MHz clock by shared fractional divider; Divide 73.728MHz clock by 10 to get 460.8KHz clock by independent integer divider; Configure UART_DLL to 1.  |

|            |                                                                                                                                                                                                                                               |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 921.6 Kbps | Configure PLL to get 1188MHz clock output; Divide 1188MHz clock by 1536/24750 to get 73.728MHz clock by shared fractional divider; Divide 73.728MHz clock by 5 to get 921.6KHz clock by independent integer divider; Configure UART_DLL to 1. |
| 1.5 Mbps   | Configure PLL to get 800MHz clock output; Divide 1000MHz clock by 24/100 to get 192MHz clock by shared fractional divider; Divide 192MHz clock by 8 to get 24MHz clock by independent integer divider; Configure UART_DLL to 1.               |
| 3 Mbps     | Configure PLL to get 800MHz clock output; Divide 1000MHz clock by 24/100 to get 192MHz clock by shared fractional divider; Divide 192MHz clock by 4 to get 48MHz clock by independent integer divider; Configure UART_DLL to 1.               |
| 4 Mbps     | Configure PLL to get 800MHz clock output; Divide 1000MHz clock by 24/100 to get 192MHz clock by shared fractional divider; Divide 192MHz clock by 3 to get 64MHz clock by independent integer divider; Configure UART_DLL to 1.               |
| 8 Mbps     | Configure PLL to get 800MHz clock output; Divide 800MHz clock by 16/100 to get 128MHz clock by shared fractional divider; Divide 128MHz clock by 1 to get 128MHz clock by independent integer divider; Configure UART_DLL to 1.               |

## Chapter 34 Controller Area Network (CAN)

### 34.1 Overview

CAN (Rockchip Controller Area Network) bus is a robust vehicle bus standard designed to allow microcontrollers 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.

RKCAN controller supports the following features:

- Support CAN and CANFD protocol
- Support AHB slave interface
- Not support AHB master interface
- Support classical and can-fd transmit or receive standard frame
- Support classical and can-fd 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 acceptance filter
- Support bit error, bit stuffing error, form error, ack error and crc error
- Support interrupt and all interrupt can be masked
- Support controller status query
- Support error code check
- Support self test mode
- Support single sample and three sample configurable
- Support SJW(reSynchronization 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 auto retransmission mode
- Support auto bus on after bus-off state
- Support 2 transmit buffers
- Support Internal Storage Mode
- Support protocol exception event
- Support DMA

### 34.2 Function Description

The features listed below which may or may not be present in actual product, may be subject to the third party licensing requirements. Please contact Rockchip for actual product feature configurations and licensing requirements.

#### 34.2.1 Block Diagram



Fig. 34-1 RKCAN Controller Block Diagram

This version of RKCAN controller includes the previous version of CAN logic in compliance with old software application and also includes new CANFD logic which support transmitting and receiving both CAN and CANFD frame.

### **34.2.2 ACCEPTANCE FILTER**

The Acceptance Filter (ATF) is a receive filter module. RKCAN can filter the received CAN frames based on four identifiers: ID, RTR, and DLC. There are five sets of ID\_RTR registers and one set of DLC registers for configuring the filter mode of RKCAN. The filtering mode based on ID and RTR has two types: List Mode and Mask Mode. The current ATF Mask register can be configured as either a mask mode or a list mode through the ATFMn.mask bit.

(1) Mask Mode: ATFM is used as the mask register of ATF, and RKCAN provides five sets of configurable 'filter-mask' registers.

(2) List Mode: ATFM is used as the filter register, and RKCAN provides ten configurable 'filter' registers."



Fig. 34-2 ATF Mode

When filtering based on DLC, there are also two modes: Over Mode and Less Mode. The ATF\_DLC.en bit is used to enable the DLC filter, the ARF\_DLC.mode bit is used to select between the two modes, and the ATF\_DLC.dlc[3:0] is used to configure the filter threshold.

(1) Over Mode: When ARF\_DLC.mode is 0, if the dlc value of the received CAN frame is greater than or equal to ATF\_DLC.dlc[3:0], the CAN frame can be received by RKCAN and stored in memory.

(2) Less Mode: When ARF\_DLC.mode is 1, if the dlc value of the received CAN frame is less than or equal to ATF\_DLC.dlc[3:0], the CAN frame can be received by RKCAN and stored in memory.

ATF\_CTL[9:0] is used to control the switch status of ATF0~4 and ATFM0~4.

### **34.2.3 BIT TIMING**

#### **34.2.3.1 Bit Timing Logic**

The CAN FD protocol defines two bit rates, the first for the ARBITRATION-PHASE with a longer bit time and the second for the data phase with the same or with a shorter bit time. The definition for the first bit rate is the same as for the NOMINAL BIT RATE and the NOMINAL BIT TIME in the CAN protocol specification. The definition for the second bit rate, the DATA BIT RATE WITH THE DATA BIT TIME, requires a separate configuration register set.

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.

### 34.2.3.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( $t_{sclk}$ ), 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  $t_{sclk}$  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 t_{sclk}$$

$$t_{prop\_seg} + t_{phase\_seg1} = t_{sclk} \times (8 \times TSEG1.3 + 4 \times TSEG1.2 + 2 \times TSEG1.1 + TSEG1.0 + 1)$$

$$t_{phase\_seg2} = t_{sclk} \times (4 \times TSEG2.2 + 2 \times TSEG2.1 + TSEG1.0 + 1)$$

Define a counter to count  $t_{sclk}$ . 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. 34-3 Bit timing FSM



Fig. 34-4 Bit timing waveform diagram

### 34.2.3.3 Bit time transition

The first part of a CAN FD frame, until the BRS bit, is transmitted with the NOMINAL BIT RATE. The bit rate is switched if the BRS bit is recessive, until the CRC DELIMITER is reached or until the CAN FD controller sees an error condition that results in the starting

of an ERROR FRAME, CAN FD ERROR FRAMES, as well as ACK FIELD, END OF FRAME, OVERLOAD FRAMES, and all frames in CAN format are transmitted with the NOMINAL BIT RATE.



Fig. 34-5 Bit Timing

#### 34.2.3.4 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  $t_{sclk}$ .



Possible values are BRP = 000001, TSEG1 = 0101 and TSEG2 = 010.

Fig. 34-6 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.

### 34.2.3.5 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. 34-7 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. 34-8 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.

### 34.2.3.6 Transmitter Delay Compensation

During the data phase of a CAN FD transmission, only one node is transmitting; all others are receiving. Therefore, the propagation delay does not limit the maximum data rate. When transmitting via pin, TXCAN, the CAN FD Controller module receives the transmitted data from its local CAN transceiver via pin, RXCAN. The received data are delayed by the CAN transceiver's loop delay. In case this delay is greater than  $1 + DTSEG1$ , a bit error will be detected.

In order to enable a data phase bit time that is shorter than the transceiver loop delay, the Transmitter Delay Compensation (TDC) is implemented. Instead of sampling after DTSEG1, a Secondary Sample Point (SSP) is calculated and used for sampling during the data phase of a CAN FD message.



Fig. 34-9 Measurement of Transceiver Delay

### 34.2.4 RXSTORE

#### 34.2.4.1 Internal Storage Mode

To store the frame data received by RKCAN only in the internal SRAM, the STR\_CTL.stm needs to be configured as 0. The frame data received by RKCAN will only be stored in the internal SRAM. The size of the internal SRAM is 256x32bit. The CPU can query the remaining amount of data in the internal SRAM through the STR\_STAT.intm\_left\_cnt register. After the CPU reads the data, the STR\_STAT.intm\_left\_cnt will decrease accordingly. At the same time, the way the internal SRAM stores data can be divided into four data storage formats: Flexible, CAN Fixed, CANFD Fixed, and Mixed. Use STR\_CTL\_ism\_sel[1:0] to select among the four formats, the specific explanations are as follows:

- (1) Flexible: The data of each frame is seamlessly stored in the SRAM according to its volume.
- (2) CAN Fixed: A fixed 4 words are used to store a frame of data.
- (3) CANFD Fixed: A fixed 18 words are used to store a frame of data.
- (4) Mixed: CAN frames use 4 words to store a frame of data, and CANFD frames use 18 words to store a frame of data. It should be noted that when the external storage mode is turned on, the internal SRAM will still be used for data caching, and the STR\_CTL\_ism\_sel[1:0] can still be used to select the format of the data cached in the internal SRAM, but the external memory uses a fixed 18

words to store a frame of data.

### 34.2.4.2 External Storage Mode

To store the frame data received by RKCAN in external memory (DDR or System Memory), the STORE\_CTL.stm needs to be configured as 1, and registers such as TXTHR, START\_ADDR, and EXTM\_SIZE need to be configured. RKCAN will first store the received frame data in the internal SRAM. When the amount of data received by RKCAN exceeds the threshold set by TXTHR, it will automatically write the data stored in the internal SRAM to the external memory through AHB Master, and update the WADDR register to the tail address of the part of the external memory that has been written with data. At the same time, it updates the status of the two empty/full flags STR\_STAT.extm\_empty and STR\_STAT.extm\_full. RKCAN sends an interrupt to the CPU. The CPU can determine the amount of data that can be read by querying the value of the WADDR register. After the CPU completes the frame data reading, it needs to write the latest CPU\_RD\_ADDR value into the RADDR register of RKCAN. RKCAN will calculate the empty/full status of the memory based on the values of the RADDR and WADDR registers. The CPU can query the amount of data in the external memory through STR\_STAT.extm\_left\_cnt, and query the remaining amount of data in the internal SRAM through STR\_STAT.intm\_left\_cnt.

This feature is currently only used for debugging. For specific application details, please consult Rockchip.



Fig. 34-10 Data storage format under external storage mode

### 34.2.4.3 ESM Timeout Mechanism

RKCAN also has a timeout mechanism to prevent the RKCAN receive buffer from overflowing when the CPU does not read data for a long time. The timeout threshold is configured through the BUF\_TIMEOUT register. In internal storage mode, if the CPU does not read the data in the internal SRAM for a long time, a timeout interrupt will occur; in external storage mode, if the CPU does not update the value of the CPU\_RD\_ADDR register for a long time, a timeout interrupt will occur. The same interrupt flag is used in both modes.

### 34.2.5 ERROR PROCESS

There are five types of errors. Multiple errors can occur at the same time.

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

- **BIT STUFF ERROR:**

A STUFF ERROR has to be detected at the bit time of the 6<sup>th</sup> consecutive equal bit level in a message field that should be coded by the method of bit stuffing.

- **FORM ERROR:**

A FORM ERROR has to be detected when a fixed-form bit field contains one or more illegal bits. (Exception is the detection of a dominant bit during the last bit of END OF FRAME by a RECEIVER, or the detection of a dominant bit during the last bit of ERROR DELIMITER or OVERLOAD DELIMITER by any node). When the value of a fixed STUFF-BIT in the CAN FD format CRC SEQUENCE is equal to its preceding bit, this shall also be detected as a FORM-ERROR.

- **ACK ERROR:**

An ACK ERROR has to be detected by a transmitter whenever it does not monitor a ‘dominant’ bit during the ACK SLOT.

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

## 34.3 Register Description

### 34.3.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows. address can be divided into different length for different usage, which is shown as follows.

**Operational Base**

| Name              | Base Address |
|-------------------|--------------|
| CAN0 base address | 0xFF320000   |
| CAN1 base address | 0xFF330000   |

### 34.3.2 Registers Summary

| Name                        | Offset | Size | Reset Value | Description                                       |
|-----------------------------|--------|------|-------------|---------------------------------------------------|
| RKCAN_MODE                  | 0x0000 | W    | 0x00000000  | Mode Configure Register                           |
| RKCAN_CMD                   | 0x0004 | W    | 0x00000000  | Request Command Register                          |
| RKCAN_STATE                 | 0x0008 | W    | 0x00000000  | Controller State Register                         |
| RKCAN_INT                   | 0x000C | W    | 0x00000000  | Interrupt State Register                          |
| RKCAN_INT_MASK              | 0x0010 | W    | 0x00000000  | Interrupt Mask Registers                          |
| RKCAN_FD_NOMINAL_BIT_TIMING | 0x0100 | W    | 0x00000000  | CANFD Nominal Bit Timing Configure Register       |
| RKCAN_FD_DATA_BITTIMING     | 0x0104 | W    | 0x00000000  | CANFD Data Bit Timing Configure Register          |
| RKCAN_FD_TDC                | 0x0108 | W    | 0x00000000  | Transmitter Delay Compensation Configure Register |
| RKCAN_FD_BRS_CFG            | 0x010C | W    | 0x0000000B  | Transmitter Delay Compensation Configure Register |
| RKCAN_FD_LOOP_CNT           | 0x0110 | W    | 0x00000000  | Transmitter Delay Compensation Configure Register |

| Name                  | Offset | Size | Reset Value | Description                                       |
|-----------------------|--------|------|-------------|---------------------------------------------------|
| RKCAN DMA CTRL        | 0x011C | W    | 0x00000000  | DMA Mode Control Register                         |
| RKCAN FD TXFRAMEINFO  | 0x0200 | W    | 0x00000000  | CANFD TX Frame Information Configuration Register |
| RKCAN FD TXID         | 0x0204 | W    | 0x00000000  | CANFD Transmit ID Register                        |
| RKCAN FD TXDATA0      | 0x0208 | W    | 0x00000000  | CANFD Transmit DATA0                              |
| RKCAN FD TXDATA1      | 0x020C | W    | 0x00000000  | CANFD Transmit DATA1                              |
| RKCAN FD TXDATA2      | 0x0210 | W    | 0x00000000  | CANFD Transmit DATA2                              |
| RKCAN FD TXDATA3      | 0x0214 | W    | 0x00000000  | CANFD Transmit DATA3                              |
| RKCAN FD TXDATA4      | 0x0218 | W    | 0x00000000  | CANFD Transmit DATA4                              |
| RKCAN FD TXDATA5      | 0x021C | W    | 0x00000000  | CANFD Transmit DATA5                              |
| RKCAN FD TXDATA6      | 0x0220 | W    | 0x00000000  | CANFD Transmit DATA6                              |
| RKCAN FD TXDATA7      | 0x0224 | W    | 0x00000000  | CANFD Transmit DATA7                              |
| RKCAN FD TXDATA8      | 0x0228 | W    | 0x00000000  | CANFD Transmit DATA8                              |
| RKCAN FD TXDATA9      | 0x022C | W    | 0x00000000  | CANFD Transmit DATA9                              |
| RKCAN FD TXDATA10     | 0x0230 | W    | 0x00000000  | CANFD Transmit DATA10                             |
| RKCAN FD TXDATA11     | 0x0234 | W    | 0x00000000  | CANFD Transmit DATA11                             |
| RKCAN FD TXDATA12     | 0x0238 | W    | 0x00000000  | CANFD Transmit DATA12                             |
| RKCAN FD TXDATA13     | 0x023C | W    | 0x00000000  | CANFD Transmit DATA13                             |
| RKCAN FD TXDATA14     | 0x0240 | W    | 0x00000000  | CANFD Transmit DATA14                             |
| RKCAN FD TXDATA15     | 0x0244 | W    | 0x00000000  | CANFD Transmit DATA15                             |
| RKCAN FD RXFRAMEINFO  | 0x0300 | W    | 0x00000000  | CANFD RX Frame Information Configuration Register |
| RKCAN FD RXID         | 0x0304 | W    | 0x00000000  | CANFD Receive ID                                  |
| RKCAN FD RXTIMESTAMP  | 0x0308 | W    | 0x00000000  | CANFD Receive Timestamp Reserved                  |
| RKCAN FD RXDATA0      | 0x030C | W    | 0x00000000  | CANFD Receive Data Reg0                           |
| RKCAN FD RXDATA1      | 0x0310 | W    | 0x00000000  | CANFD Receive Data Reg1                           |
| RKCAN FD RXDATA2      | 0x0314 | W    | 0x00000000  | CANFD Receive Data Reg2                           |
| RKCAN FD RXDATA3      | 0x0318 | W    | 0x00000000  | CANFD Receive Data Reg3                           |
| RKCAN FD RXDATA4      | 0x031C | W    | 0x00000000  | CANFD Receive Data Reg4                           |
| RKCAN FD RXDATA5      | 0x0320 | W    | 0x00000000  | CANFD Receive Data Reg5                           |
| RKCAN FD RXDATA6      | 0x0324 | W    | 0x00000000  | CANFD Receive Data Reg6                           |
| RKCAN FD RXDATA7      | 0x0328 | W    | 0x00000000  | CANFD Receive Data Reg7                           |
| RKCAN FD RXDATA8      | 0x032C | W    | 0x00000000  | CANFD Receive Data Reg8                           |
| RKCAN FD RXDATA9      | 0x0330 | W    | 0x00000000  | CANFD Receive Data Reg9                           |
| RKCAN FD RXDATA10     | 0x0334 | W    | 0x00000000  | CANFD Receive Data Reg10                          |
| RKCAN FD RXDATA11     | 0x0338 | W    | 0x00000000  | CANFD Receive Data Reg11                          |
| RKCAN FD RXDATA12     | 0x033C | W    | 0x00000000  | CANFD Receive Data Reg12                          |
| RKCAN FD RXDATA13     | 0x0340 | W    | 0x00000000  | CANFD Receive Data Reg13                          |
| RKCAN FD RXDATA14     | 0x0344 | W    | 0x00000000  | CANFD Receive Data Reg14                          |
| RKCAN FD RXDATA15     | 0x0348 | W    | 0x00000000  | CANFD Receive Data Reg15                          |
| RKCAN RX STR RDATA    | 0x0400 | W    | 0x00000000  | RX Storage Read Data                              |
| RKCAN STR CTL         | 0x0600 | W    | 0x00000080  | Storage Ctrl Register                             |
| RKCAN STR STATE       | 0x0604 | W    | 0x00000000  | Storage Ctrl Register                             |
| RKCAN STR TIMEOUT     | 0x0608 | W    | 0x00002710  | Storage Timeout Threshold Register                |
| RKCAN STR WTM         | 0x060C | W    | 0x000168ED  | Storage Water Mark Register                       |
| RKCAN EXTM START ADDR | 0x0610 | W    | 0x00000000  | External Memory Start Address                     |
| RKCAN EXTM SIZE       | 0x0614 | W    | 0x000001F8  | External Memory Size Register                     |
| RKCAN EXTM WADDR      | 0x0618 | W    | 0x00000000  | External Memory AHB Write Address                 |

| Name                    | Offset | Size | Reset Value | Description                                         |
|-------------------------|--------|------|-------------|-----------------------------------------------------|
| RKCAN_EXTM_RADDR        | 0x061C | W    | 0x000000000 | External Memory Soft Read Address                   |
| RKCAN_EXTM_AHB_TXTH_R   | 0x0620 | W    | 0x000000000 | AHB Master Transmit Threshold Level                 |
| RKCAN_EXTM_LEFT_CNT     | 0x0624 | W    | 0x000000000 | External Memory Left Counter                        |
| RKCAN_ATF0              | 0x0700 | W    | 0x000000000 | Acceptance Filter 0 Code Register                   |
| RKCAN_ATF1              | 0x0704 | W    | 0x000000000 | Acceptance Filter 1 Code Register                   |
| RKCAN_ATF2              | 0x0708 | W    | 0x000000000 | Acceptance Filter 2 Code Register                   |
| RKCAN_ATF3              | 0x070C | W    | 0x000000000 | Acceptance Filter 3 Code Register                   |
| RKCAN_ATF4              | 0x0710 | W    | 0x000000000 | Acceptance Filter 4 Code Register                   |
| RKCAN_ATFM0             | 0x0714 | W    | 0x1FFFFFFF  | Acceptance Filter 0 Mask Register                   |
| RKCAN_ATFM1             | 0x0718 | W    | 0x1FFFFFFF  | Acceptance Filter 1 Mask Register                   |
| RKCAN_ATFM2             | 0x071C | W    | 0x1FFFFFFF  | Acceptance Filter 2 Mask Register                   |
| RKCAN_ATFM3             | 0x0720 | W    | 0x1FFFFFFF  | Acceptance Filter 3 Mask Register                   |
| RKCAN_ATFM4             | 0x0724 | W    | 0x1FFFFFFF  | Acceptance Filter 4 Mask Register                   |
| RKCAN_ATF_DLC           | 0x0728 | W    | 0x000000000 | Acceptance DLC Filter Function                      |
| RKCAN_ATF_CTL           | 0x072C | W    | 0x000000000 | Acceptance Filter Configure Register                |
| RKCAN_AUTO RETX CFG     | 0x0808 | W    | 0x00000320  | Configure Register for Auto Retransmission Function |
| RKCAN_AUTO RETX STAT_E0 | 0x080C | W    | 0x000000000 | Auto Retransmission Status Register 0               |
| RKCAN_AUTO RETX STAT_E1 | 0x0810 | W    | 0x000000000 | Auto Retransmission Status Register 0               |
| RKCAN_OLF_CFG           | 0x0814 | W    | 0x000000000 | Overload Frame Configuration Register               |
| RKCAN_RXINT_CTRL        | 0x0818 | W    | 0x00000100  | Multi Frame Interrupt(MFI) Configure Register       |
| RKCAN_RXINT_TIMEOUT     | 0x081C | W    | 0x0000FFFF  | MFI Timeout Threshold Register                      |
| RKCAN_ERROR_CODE        | 0x0900 | W    | 0x000000000 | RX Error Code Register                              |
| RKCAN_ERROR_MASK        | 0x0904 | W    | 0x000000000 | Error Mask Register                                 |
| RKCAN_RXERRORCNT        | 0x0910 | W    | 0x000000000 | Receive Error Counter Register                      |
| RKCAN_TXERRORCNT        | 0x0914 | W    | 0x000000000 | Transmit Error Counter Register                     |
| RKCAN_ARBIT FAIL_STAT_E | 0x0918 | W    | 0x000000000 | Arbiter Fail Code Register                          |
| RKCAN RTL VERSION       | 0x0F0C | W    | 0xCFDBA0EB  | CAN RTL version                                     |

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

### 34.3.3 Detail Registers Description

#### RKCAN MODE

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                       |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0000      | reserved                                                                                                                                                                                          |
| 15    | RW   | 0x0         | noack_mode<br>When noack_mode is enabled, if the internal receive buffer of RKCAN is full and a new frame is received, RKCAN will no longer respond with an ACK.<br>1'b0: Disable<br>1'b1: Enable |
| 14    | RW   | 0x0         | force_passive_err<br>Force RKCAN into error passive station<br>1'b0: Disable<br>1'b1: Enable                                                                                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13         | RW          | 0x0                | force_active_err<br>Force RKCAN into error active station<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 12         | RW          | 0x0                | crcerr_pass_mode<br>1'b0: Send Passive Error when CRC Error detected<br>1'b1: Not send Passive Error when CRC Error detected                                                                                                                                                                                                                                                                                                                                                                                     |
| 11         | RW          | 0x0                | crcerr_ack_mode<br>1'b0: Not send ACK when CRC Error detected<br>1'b1: Send ACK when CRC Error detected                                                                                                                                                                                                                                                                                                                                                                                                          |
| 10         | RW          | 0x0                | pass_err_mode<br>1'b0: PASSIVE Error Flag use recessive bits<br>1'b1: PASSIVE Error Flag use dominant bits                                                                                                                                                                                                                                                                                                                                                                                                       |
| 9          | RW          | 0x0                | dis_pee<br>Disable Protocol Exception Event Detection/Generation<br>1'b0: PEE detection/generation is enabled. If the CANFD receiver detects the res bit as 1, it goes to Bus Integration state (PEE_config) and waits for Bus Idle condition (11 consecutive nominal recessive bits). The error counter remains unchanged.<br>1'b1: Disable Protocol Exception Event detection/generation by CANFD receiver if "res" bit in CANFD frame is detected as 1.<br>In this case, CANFD receiver generates Form error. |
| 8          | RW          | 0x0                | rett_mode<br>Restricted Operation Mode<br>In Restricted Operation Mode, RKCAN is able to transmit and to receive DATA FRAMES and REMOTE FRAMES and it gives ACKNOWLEDGE to valid frames, but it does not send ACTIVE ERROR FRAMES or OVERLOAD FRAMES. The error counters are not incremented or decremented.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                    |
| 7          | 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.                                                                                                                                                                                                       |
| 6          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 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                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | self_test<br>Reserved<br>Self check ACK slot when TX frame<br>Using ERROR_MASK[4] can achieve the same function<br>When in self_test mode, the receiver does not need to return an ACK signal when receiving data. Therefore, no error ack will occur in self_test mode. When in 'lback_mode' or 'silent_mode', it needs to enable 'self_test' mode when sending frame. |
| 1          | RW          | 0x0                | sleep_mode<br>Sleep Mode<br>This is the Sleep mode request bit<br>1'b0: No such request<br>1'b1: Request core to be in Sleep mode<br>This bit is cleared when the core wakes up from Sleep mode.                                                                                                                                                                        |
| 0          | RW          | 0x0                | work_mode<br>Work Mode<br>1'b0: Idle mode, CAN stop transmit and registers can be configured<br>1'b1: Work mode, CAN enter the working mode, Receive/transmit data                                                                                                                                                                                                      |

### **RKCAN CMD**

Address: **Operational Base** + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                         |
| 1          | R/W SC      | 0x0                | tx1_req<br>Transmit request enable<br>1'b0: Disable<br>1'b1: Enable<br>When 'tx1_req' is enable, the RKCAN buffer1 is in the transmit mode and cannot receive frames from other CANs. When the RKCAN buffer1 transmission frame complete, 'tx1_req' is automatically cleared to 0. Also, when RKCAN is set 'work_mode' to 'reset_mode', tx_req' is cleared to 0. |
| 0          | R/W SC      | 0x0                | tx0_req<br>Transmit request enable<br>1'b0: Disable<br>1'b1: Enable<br>When 'tx0_req' is enable, the RKCAN buffer0 is in the transmit mode and cannot receive frames from other CANs. When the RKCAN buffer0 transmission frame complete, 'tx0_req' is automatically cleared to 0. Also, when RKCAN is set 'work_mode' to 'reset_mode', tx_req' is cleared to 0. |

### **RKCAN 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                | sleep_state<br>Sleep state<br>1'b0: None<br>1'b1: CAN controller is in the sleep state |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | RO          | 0x0                | bus_off_state<br>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 \geq 32'd255$ ) |
| 3          | RO          | 0x0                | error_warning_state<br>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 \geq 32'd96$ )                                                                                                              |
| 2          | RO          | 0x0                | tx_period<br>Transmit state<br>1'b0: Not in transmit state<br>1'b1: CAN controller is in the transmit state                                                                                                                                                                                      |
| 1          | RO          | 0x0                | rx_period<br>Receive state<br>1'b0: Not in receive state<br>1'b1: CAN controller is in the receive state                                                                                                                                                                                         |
| 0          | RO          | 0x0                | 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.                                                                                                                                          |

**RKCAN\_INT**Address: **Operational Base** + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                                                                            |
| 19         | W1 C        | 0x0                | busoff_rcy_int<br>BusOff Timer Recovery Interrupt<br>1'b0: None<br>1'b1: BusOff timer recovery<br>Write 1 then clear                                |
| 18         | W1 C        | 0x0                | esm_wtm_int<br>External Stotage watermark Interrupt<br>1'b0: None<br>1'b1: The data in external storage reaches the watermark<br>Write 1 then clear |
| 17         | W1 C        | 0x0                | ism_wtm_int<br>Internal Stotage watermark Interrupt<br>1'b0: None<br>1'b1: The data in internal storage reaches the watermark<br>Write 1 then clear |
| 16         | W1 C        | 0x0                | busint_int<br>Enter Bus Integration Interrupt<br>1'b0: None<br>1'b1: Indicates RKCAN enter the bus integration state.<br>Write 1 then clear         |
| 15         | W1 C        | 0x0                | rxstr_timeout_int<br>RX Storage Timeout Interrupt<br>1'b0: None<br>1'b1: Indicates that data remain in rx storage timeout.<br>Write 1 then clear    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14         | W1<br>C     | 0x0                | mfi_timeout_int<br>Multi Frame Interrupt(MFI) Mode Timeout Interrupt                                                                                                                                                                                                                                         |
| 13         | W1<br>C     | 0x0                | mfi_int<br>Multi Frame Interrupt(MFI)                                                                                                                                                                                                                                                                        |
| 12         | W1<br>C     | 0x0                | auto_retx_fail_int<br>Automatic Transmit Failure Interrupt                                                                                                                                                                                                                                                   |
| 11         | W1<br>C     | 0x0                | wakeup_int<br>Wakeup Interrupt<br>1'b0: None<br>1'b1: Indicates that the core entered Normal mode from Sleep mode. Write 1 then clear                                                                                                                                                                        |
| 10         | W1<br>C     | 0x0                | bus_off_recovery_int<br>Bus off Recover Interrupt<br>1'b0: None<br>1'b1: Indicates that the core is recovered from Bus-off mode<br>Write 1 then clear                                                                                                                                                        |
| 9          | W1<br>C     | 0x0                | bus_off_int<br>Bus Off Interrupt<br>1'b0: None<br>1'b1: Indicates that the CAN core entered Bus-off mode<br>Write 1 then clear                                                                                                                                                                               |
| 8          | W1<br>C     | 0x0                | rxstr_overflow_int<br>RX Storage Overflow Interrupt.<br>1'b0: None<br>1'b1: Indicates that a message has been lost. This condition occurs when a new message with ID matching to Receive Storage is received and the Receive Storage is full.<br>Write 1 then clear                                          |
| 7          | W1<br>C     | 0x0                | rxstr_full_int<br>RX Storage full Interrupt.<br>1'b0: None<br>1'b1: Indicates that RX Storage is full based on watermark setting<br>Write 1 then clear                                                                                                                                                       |
| 6          | W1<br>C     | 0x0                | error_int<br>Bus Error Interrupt<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.<br>Write 1 then clear                                                                                         |
| 5          | W1<br>C     | 0x0                | tx_arbit_fail_int<br>Transmit Arbitration loss Interrupt<br>1'b0: None<br>1'b1: Arbitration loss interrupt. This interrupt is generated when the loss of arbitration is turned into a receiver<br>Write 1 then clear                                                                                         |
| 4          | W1<br>C     | 0x0                | passive_error_int<br>Passive Error Interrupt<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.<br>Write 1 then clear |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3          | W1<br>C     | 0x0                | overload_int<br>Overload Frame Interrupt<br>1'b0: None<br>1'b1: CAN bus overload interrupt. This interrupt is generated when a overload frame is generated.<br>Write 1 then clear  |
| 2          | W1<br>C     | 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.<br>Write 1 then clear |
| 1          | W1<br>C     | 0x0                | tx_finish_int<br>Transmit finish interrupt<br>1'b0: None<br>1'b1: Transmit finish interrupt. CAN controller sends the message.<br>Write 1 then clear                               |
| 0          | W1<br>C     | 0x0                | rx_finish_int<br>Receive Finish Interrupt<br>1'b0: None<br>1'b1: Receive finish int. CAN controller has received the message and the rx_buffer is full.<br>Write 1 then clear      |

**RKCAN INT MASK**Address: **Operational Base** + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                  |
| 19         | RW          | 0x0                | busoff_rcy_int_mask<br>1'b0: Unmasked<br>1'b1: Masked     |
| 18         | RW          | 0x0                | esm_wtm_int_mask<br>1'b0: Unmasked<br>1'b1: Masked        |
| 17         | RW          | 0x0                | ism_wtm_int_mask<br>1'b0: Unmasked<br>1'b1: Masked        |
| 16         | RW          | 0x0                | busint_int_mask<br>1'b0: Unmasked<br>1'b1: Masked         |
| 15         | RW          | 0x0                | rxstr_timeout_int_mask<br>1'b0: Unmasked<br>1'b1: Masked  |
| 14         | RW          | 0x0                | mfi_timeout_int_mask<br>1'b0: Unmasked<br>1'b1: Masked    |
| 13         | RW          | 0x0                | mfi_int_mask<br>1'b0: Unmasked<br>1'b1: Masked            |
| 12         | RW          | 0x0                | auto_retx_fail_int_mask<br>1'b0: Unmasked<br>1'b1: Masked |

| Bit | Attr | Reset Value | Description                                                 |
|-----|------|-------------|-------------------------------------------------------------|
| 11  | RW   | 0x0         | wakeup_int_mask<br>1'b0: Unmasked<br>1'b1: Masked           |
| 10  | RW   | 0x0         | bus_off_recovery_int_mask<br>1'b0: Unmasked<br>1'b1: Masked |
| 9   | RW   | 0x0         | bus_off_int_mask<br>1'b0: Unmasked<br>1'b1: Masked          |
| 8   | RW   | 0x0         | rxstr_overflow_int_mask<br>1'b0: Unmasked<br>1'b1: Masked   |
| 7   | RW   | 0x0         | rxstr_full_int_mask<br>1'b0: Unmasked<br>1'b1: Masked       |
| 6   | RW   | 0x0         | error_int_mask<br>1'b0: Unmasked<br>1'b1: Masked            |
| 5   | RW   | 0x0         | tx_arbit_fail_int_mask<br>1'b0: Unmasked<br>1'b1: Masked    |
| 4   | RW   | 0x0         | passive_error_int_mask<br>1'b0: Unmasked<br>1'b1: Masked    |
| 3   | RW   | 0x0         | overload_int_mask<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        |
| 0   | RW   | 0x0         | rx_finish_int_mask<br>1'b0: Unmasked<br>1'b1: Masked        |

**RKCAN FD NOMINAL BITTIMING**Address: **Operational Base** + offset (0x0100)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                      |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | RW   | 0x0         | sample_mode<br>RKCAN controller sampling mode configuration register.<br>When enabling triple sampling, it is necessary to configure the positions of two additional sampling points using the FD_BRS_CFG[30:5] register.<br>1'b0: Single sample mode<br>1'b1: Three sample mode |
| 30:24 | RW   | 0x00        | 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.                                                                          |
| 23:16 | RW   | 0x00        | brq<br>brp: system prescale coefficient<br>$T_{Sclk} = 2 \times T_{Clk} \times (brp + 1)$                                                                                                                                                                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 15         | RO          | 0x0                | reserved                                                                           |
| 14:8       | RW          | 0x00               | tseg2<br>Phase buffer segment 2<br>$T_{phase\_seg2} = T_{sclk} \times (tseg2 + 1)$ |
| 7:0        | RW          | 0x00               | tseg1<br>Phase buffer segment 1<br>$T_{phase\_seg1} = T_{sclk} \times (tseg1 + 1)$ |

**RKCAN FD DATA BITTIMING**Address: **Operational Base** + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RW          | 0x00               | brs_tseg1<br>tseg1 for BRS Bit                                                                                                                                                                          |
| 23         | RW          | 0x0                | brs_mode<br>BRS bit sampling point setting<br>1'b0: Sampling BRS bit according to the position specified in the protocol<br>1'b1: The sampling point of BRS bit will be advanced                        |
| 22         | RW          | 0x0                | ackslot_sync_dis<br>1'b0: Enable Hardsync when ACK_SLOT<br>1'b1: Disable Hardsync when ACK_SLOT                                                                                                         |
| 21         | RO          | 0x0                | reserved                                                                                                                                                                                                |
| 20:17      | 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. |
| 16:9       | RW          | 0x00               | brq<br>brp: system prescale coefficient<br>$T_{sclk} = 2 \times T_{clk} \times (brp + 1)$                                                                                                               |
| 8:5        | RW          | 0x0                | tseg2<br>Phase buffer segment 2<br>$T_{phase\_seg2} = T_{sclk} \times (tseg2 + 1)$                                                                                                                      |
| 4:0        | RW          | 0x00               | tseg1<br>Phase buffer segment 1<br>$T_{phase\_seg1} = T_{sclk} \times (tseg1 + 1)$                                                                                                                      |

**RKCAN FD TDC**Address: **Operational Base** + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9       | RO          | 0x000000           | reserved                                                                                                                                                                                                                                                                                                                                    |
| 8          | RW          | 0x0                | lcnt_clr<br>Loop Delay Counter Clear                                                                                                                                                                                                                                                                                                        |
| 7          | RW          | 0x0                | lcnt_meas_en<br>Loop Delay Counter Enable                                                                                                                                                                                                                                                                                                   |
| 6:1        | RW          | 0x00               | tdc_offset<br>Transmitter Delay Compensation Offset<br>This offset is specified in CAN clock cycles and is added to the measured transmitter delay to place the Secondary Sample Point (SSP) at appropriate position (for example, set this to half data bit time in terms of CAN clock cycles to place SSP in the middle of the data bit). |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | tdc_enable<br>Transmitter Delay Compensation (TDC) Enable<br>1'b0: TDC is disabled<br>1'b1: Enables TDC function as specified in the CAN FD standard |

**RKCAN FD BRS CFG**

Address: **Operational Base** + offset (0x010C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | triple_sync_mode<br>ReSync Enable for triple_sample mode.                                                                                   |
| 30:26      | RW          | 0x00               | sp2_dtseg2<br>Sample Point 2 data phase tseg2                                                                                               |
| 25:18      | RW          | 0x00               | sp2_ntseg1<br>Sample Point 2 tseg1                                                                                                          |
| 17:13      | RW          | 0x00               | sp1_dtseg2<br>Sample Point 1 data phase tseg2                                                                                               |
| 12:5       | RW          | 0x00               | sp1_ntseg1<br>Sample Point 1 tseg1                                                                                                          |
| 4          | RO          | 0x0                | reserved                                                                                                                                    |
| 3          | RW          | 0x1                | resync_mode<br>Resync Mode.<br>1'b0: Resynchronization only on the falling edge<br>1'b1: Resynchronization on both rising and falling edges |
| 2          | RO          | 0x0                | reserved                                                                                                                                    |
| 1          | RW          | 0x1                | brs_possync_en<br>BRS Bit Posedge Sync Enable                                                                                               |
| 0          | RW          | 0x1                | brs_negsync_en<br>BRS Bit negedge Sync Enable                                                                                               |

**RKCAN FD LOOP CNT**

Address: **Operational Base** + offset (0x0110)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:0       | RO          | 0x00000000         | loop_delay_cnt<br>Loop Delay Counter |

**RKCAN DMA CTRL**

Address: **Operational Base** + offset (0x011C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x000000           | reserved                                                                                                                                                                                                        |
| 9          | RW          | 0x0                | dma_rx_en<br>DMA receive request enable<br>1'b0: Disable<br>1'b1: Enable<br>When dma_rx_mode is enable, the RKCAN is in the DMA receive mode. Also, when RKCAN is set work_mode to reset_mode, rx_req is clear. |
| 8:0        | RW          | 0x000              | dma_thr<br>DMA transfer start threshold                                                                                                                                                                         |

**RKCAN FD TXFRAMEINFO**

Address: **Operational Base** + offset (0x0200)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | RW          | 0x0                | 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          | RW          | 0x0                | tx_fdf<br>Extended Data Length/FD Frame Format<br>This bit distinguishes between CAN format and CANFD format frames.<br>1'b0: CAN format frame<br>1'b1: CAN FD format frame                                                                                                                                                                                                                                                                                                |
| 4          | RW          | 0x0                | tx_brs<br>Bit Rate Switch<br>The BRS bit decides whether the bit rate is switched inside a CAN FD format frame or not (provided BRSD bit is not set in MSR register).<br>1'b0: Bit rate is not switched inside a CAN FD frame.<br>1'b1: Bit rate is switched from the standard bit rate of the Arbitration phase to the preconfigured alternate bit rate of the Data phase inside a CAN FD frame.<br>Note: BRS does not exist in CAN format frames and should be set to 0. |
| 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>4'b1001:12byte<br>4'b1010:16byte<br>4'b1011:20byte<br>4'b1100:24byte<br>4'b1101:32byte<br>4'b1110:48byte<br>4'b1111:64byte                                                                                                        |

### **RKCAN FD TXID**

Address: **Operational Base** + offset (0x0204)

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

### **RKCAN FD TXDATA0**

Address: **Operational Base** + offset (0x0208)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>         |
|------------|-------------|--------------------|----------------------------|
| 31:0       | RW          | 0x00000000         | tx_data0<br>tx_data0[31:0] |

### **RKCAN FD TXDATA1**

Address: **Operational Base** + offset (0x020C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>         |
|------------|-------------|--------------------|----------------------------|
| 31:0       | RW          | 0x00000000         | tx_data1<br>tx_data1[31:0] |

**RKCAN FD TXDATA2**Address: **Operational Base** + offset (0x0210)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>         |
|------------|-------------|--------------------|----------------------------|
| 31:0       | RW          | 0x00000000         | tx_data2<br>tx_data2[31:0] |

**RKCAN FD TXDATA3**Address: **Operational Base** + offset (0x0214)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>         |
|------------|-------------|--------------------|----------------------------|
| 31:0       | RW          | 0x00000000         | tx_data3<br>tx_data3[31:0] |

**RKCAN FD TXDATA4**Address: **Operational Base** + offset (0x0218)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>         |
|------------|-------------|--------------------|----------------------------|
| 31:0       | RW          | 0x00000000         | tx_data4<br>tx_data4[31:0] |

**RKCAN FD TXDATA5**Address: **Operational Base** + offset (0x021C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>         |
|------------|-------------|--------------------|----------------------------|
| 31:0       | RW          | 0x00000000         | tx_data5<br>tx_data5[31:0] |

**RKCAN FD TXDATA6**Address: **Operational Base** + offset (0x0220)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>         |
|------------|-------------|--------------------|----------------------------|
| 31:0       | RW          | 0x00000000         | tx_data6<br>tx_data6[31:0] |

**RKCAN FD TXDATA7**Address: **Operational Base** + offset (0x0224)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>         |
|------------|-------------|--------------------|----------------------------|
| 31:0       | RW          | 0x00000000         | tx_data7<br>tx_data7[31:0] |

**RKCAN FD TXDATA8**Address: **Operational Base** + offset (0x0228)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>         |
|------------|-------------|--------------------|----------------------------|
| 31:0       | RW          | 0x00000000         | tx_data8<br>tx_data8[31:0] |

**RKCAN FD TXDATA9**Address: **Operational Base** + offset (0x022C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>         |
|------------|-------------|--------------------|----------------------------|
| 31:0       | RW          | 0x00000000         | tx_data9<br>tx_data9[31:0] |

**RKCAN FD TXDATA10**Address: **Operational Base** + offset (0x0230)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 31:0       | RW          | 0x00000000         | tx_data10<br>tx_data10[31:0] |

**RKCAN FD TXDATA11**Address: **Operational Base** + offset (0x0234)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 31:0       | RW          | 0x00000000         | tx_data11<br>tx_data11[31:0] |

**RKCAN FD TXDATA12**Address: **Operational Base** + offset (0x0238)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 31:0       | RW          | 0x00000000         | tx_data12<br>tx_data12[31:0] |

**RKCAN FD TXDATA13**Address: **Operational Base** + offset (0x023C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 31:0       | RW          | 0x00000000         | tx_data13<br>tx_data13[31:0] |

**RKCAN FD TXDATA14**Address: **Operational Base** + offset (0x0240)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 31:0       | RW          | 0x00000000         | tx_data14<br>tx_data14[31:0] |

**RKCAN FD TXDATA15**Address: **Operational Base** + offset (0x0244)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 31:0       | RW          | 0x00000000         | tx_data15<br>tx_data15[31:0] |

**RKCAN FD RXFRAMEINFO**Address: **Operational Base** + offset (0x0300)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                                                     |
| 7          | RO          | 0x0                | rxframe_format<br>1'b0: Standard frame<br>1'b1: Extended frame                                                                                                               |
| 6          | RO          | 0x0                | rx_rtr<br>1'b0: Data frame<br>1'b1: Remote frame                                                                                                                             |
| 5          | RO          | 0x0                | rx_fdf<br>Extended Data Length/FD Frame Format<br>This bit distinguishes between CAN format and CAN FD format frames.<br>1'b1: CAN FD format frame<br>1'b0: CAN format frame |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | RO          | 0x0                | <p>rx_brs<br/>Bit Rate Switch<br/>The BRS bit decides whether the bit rate is switched inside a CAN FD format frame or not (provided BRSD bit is not set in MSR register).</p> <p>1'b0: Bit rate is not switched inside a CAN FD frame.<br/>1'b1: Bit rate is switched from the standard bit rate of the Arbitration phase to the preconfigured alternate bit rate of the Data phase inside a CAN FD frame.</p> <p>Note: BRS does not exist in CAN format frames and should be set</p> |
| 3:0        | RO          | 0x0                | <p>rxdata_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/>4'b1001:12byte<br/>4'b1010:16byte<br/>4'b1011:20byte<br/>4'b1100:24byte<br/>4'b1101:32byte<br/>4'b1110:48byte<br/>4'b1111:64byte</p>                                                                                           |

### **RKCAN FD RXID**

Address: **Operational Base** + offset (0x0304)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>       |
|------------|-------------|--------------------|--------------------------|
| 31:29      | RO          | 0x0                | reserved                 |
| 28:0       | RO          | 0x00000000         | rx_id<br>can_rx_id[28:0] |

### **RKCAN FD RXTIMESTAMP**

Address: **Operational Base** + offset (0x0308)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:0       | RO          | 0x00000000         | timestamp<br>Reserved |

### **RKCAN FD RXDATA0**

Address: **Operational Base** + offset (0x030C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | rx_data0<br>rx_data0[31:0]<br>This register refresh after receiving the next frame |

### **RKCAN FD RXDATA1**

Address: **Operational Base** + offset (0x0310)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | rx_data1<br>rx_data1[31:0]<br>This register refresh after receiving the next frame |

**RKCAN FD RXDATA2**Address: **Operational Base** + offset (0x0314)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | rx_data2<br>rx_data2[31:0]<br>This register refresh after receiving the next frame |

**RKCAN FD RXDATA3**Address: **Operational Base** + offset (0x0318)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | rx_data3<br>rx_data3[31:0]<br>This register refresh after receiving the next frame |

**RKCAN FD RXDATA4**Address: **Operational Base** + offset (0x031C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | rx_data4<br>rx_data4[31:0]<br>This register refresh after receiving the next frame |

**RKCAN FD RXDATA5**Address: **Operational Base** + offset (0x0320)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | rx_data5<br>rx_data5[31:0]<br>This register refresh after receiving the next frame |

**RKCAN FD RXDATA6**Address: **Operational Base** + offset (0x0324)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | rx_data6<br>rx_data6[31:0]<br>This register refresh after receiving the next frame |

**RKCAN FD RXDATA7**Address: **Operational Base** + offset (0x0328)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | rx_data7<br>rx_data7[31:0]<br>This register refresh after receiving the next frame |

**RKCAN FD RXDATA8**Address: **Operational Base** + offset (0x032C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | rx_data8<br>rx_data8[31:0]<br>This register refresh after receiving the next frame |

**RKCAN FD RXDATA9**Address: **Operational Base** + offset (0x0330)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | rx_data9<br>rx_data9[31:0]<br>This register refresh after receiving the next frame |

**RKCAN FD RXDATA10**Address: **Operational Base** + offset (0x0334)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | rx_data10<br>rx_data10[31:0]<br>This register refresh after receiving the next frame |

**RKCAN FD RXDATA11**Address: **Operational Base** + offset (0x0338)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | rx_data11<br>rx_data11[31:0]<br>This register refresh after receiving the next frame |

**RKCAN FD RXDATA12**Address: **Operational Base** + offset (0x033C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | rx_data12<br>rx_data12[31:0]<br>This register refresh after receiving the next frame |

**RKCAN FD RXDATA13**Address: **Operational Base** + offset (0x0340)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | rx_data13<br>rx_data13[31:0]<br>This register refresh after receiving the next frame |

**RKCAN FD RXDATA14**Address: **Operational Base** + offset (0x0344)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | rx_data14<br>rx_data14[31:0]<br>This register refresh after receiving the next frame |

**RKCAN FD RXDATA15**Address: **Operational Base** + offset (0x0348)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | rx_data15<br>rx_data15[31:0]<br>This register refresh after receiving the next frame |

**RKCAN RX STR RDATA**Address: **Operational Base** + offset (0x0400)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                          |
|------------|-------------|--------------------|---------------------------------------------|
| 31:0       | RO          | 0x00000000         | rx_str_rdata<br>RX strorage read data value |

**RKCAN STR CTL**Address: **Operational Base** + offset (0x0600)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8          | RW          | 0x0                | str_timeout_mode<br>RX storage not read timeout threshold Mode.<br>1'b0: Disable<br>1'b1: Enable                                                                                                      |
| 7:6        | RW          | 0x2                | esm_sel<br>External Storage Mode(ESM) Data Format Select<br>2'b00: Flexible<br>2'b01: CAN Fixed<br>2'b10: CANFD Fixed<br>2'b11: Mixed                                                                 |
| 5          | RO          | 0x0                | reserved                                                                                                                                                                                              |
| 4          | RW          | 0x0                | srst<br>RX Storage Soft Reset Bit<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                    |
| 3:2        | RW          | 0x0                | ism_sel<br>Internal Storage Mode(ISM) Data Format Select<br>2'b00: Flexible; cover_mode must disable<br>2'b01: CAN Fixed<br>2'b10: CANFD Fixed<br>2'b11: Mixed. cover_mode must disable               |
| 1          | RW          | 0x0                | stm<br>Storage Mode<br>1'b0: Internal Storage Mode<br>1'b1: External Storage Mode. RKCAN can use AHB Master interface to write the received frame data to External Memory(DDR or System Memory)       |
| 0          | RW          | 0x0                | buff_mode_en<br>RX Buffer Mode Enable<br>1'b0: Disable<br>1'b1: Enable. RKCAN only a set of RXDATA0~15 registers used as buffers to store received data, instead of internal SRAM or external memory. |

### **RKCAN STR STATE**

Address: **Operational Base** + offset (0x0604)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------|
| 31:26      | RO          | 0x00               | reserved                                                                                               |
| 25:17      | RO          | 0x000              | intm_frame_cnt<br>Remaining frame count in RXFIFO. Unit: Frame<br>Only Support when cover_mode disable |
| 16:8       | RO          | 0x000              | intm_left_cnt<br>The amount of data remaining in the Internal SRAM. Unit:Word                          |
| 7:4        | RO          | 0x0                | reserved                                                                                               |
| 3          | RO          | 0x0                | extm_full<br>External Memory Full Flag<br>1'b0: Not Full<br>1'b1: Full                                 |
| 2          | RO          | 0x0                | extm_empty<br>External Memory Empty Flag<br>1'b0: Not Empty<br>1'b1: Empty                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------|
| 1          | RO          | 0x0                | intm_full<br>Internal Memory Full Flag<br>1'b0: Not Full<br>1'b1: Full     |
| 0          | RO          | 0x0                | intm_empty<br>Internal Memory Empty Flag<br>1'b0: Not Empty<br>1'b1: Empty |

**RKCAN\_STR\_TIMEOUT**Address: **Operational Base** + offset (0x0608)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                             |
|------------|-------------|--------------------|----------------------------------------------------------------|
| 31:0       | RW          | 0x00002710         | str_timeout_thr<br>RX storage not read timeout threshold value |

**RKCAN\_STR\_WTM**Address: **Operational Base** + offset (0x060C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                               |
| 30:9       | RW          | 0x0000b4           | esm_watermark<br>External Storage Watermark Register. Unit:Word                                                                                                                                                                                                        |
| 8:0        | RW          | 0x0ed              | ism_watermark<br>Internal Storage Watermark Register. The configurable range is from 0 to 256. Unit:Word<br>In ISM mode, when the amount of valid data in the RXFIFO is greater than the threshold set by ism_watermark, RKCAN will generate an ism_wtm_int interrupt. |

**RKCAN\_EXTM\_START\_ADDR**Address: **Operational Base** + offset (0x0610)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | start_addr<br>External Memory Start Address<br>Used as the Start Address of AHB master output rxdata |

**RKCAN\_EXTM\_SIZE**Address: **Operational Base** + offset (0x0614)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x000001f8         | ext_mem_size<br>Configuration size of external storage space. Unit:Word<br>Must be power of 18 |

**RKCAN\_EXTM\_WADDR**Address: **Operational Base** + offset (0x0618)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:0       | RO          | 0x00000000         | can_waddr<br>RKCAN AHB Write Address |

**RKCAN\_EXTM\_RADDR**Address: **Operational Base** + offset (0x061C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>            |
|------------|-------------|--------------------|-------------------------------|
| 31:0       | RW          | 0x00000000         | cpu_raddr<br>CPU Read Address |

**RKCAN\_EXTM\_AHB\_TXTHR**

## RK3506 TRM (Part 1)

Address: **Operational Base** + offset (0x0620)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                 |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9 | RO   | 0x0000000   | reserved                                                                                                                                                                                                                                    |
| 8:0  | RW   | 0x000       | ahb_txthr(V2)<br>When the number of RXFIFO entries is greater than or equal to this value, the RKCAN will automatically transfer the data in the RXFIFO to the external via the AHB Master interface. The value ranges is 0~511.(Unit:byte) |

### RKCAN\_EXTM\_LEFT\_CNT

Address: **Operational Base** + offset (0x0624)

| Bit   | Attr | Reset Value | Description                                                                   |
|-------|------|-------------|-------------------------------------------------------------------------------|
| 31:22 | RO   | 0x000       | reserved                                                                      |
| 21:0  | RO   | 0x0000000   | extm_left_cnt<br>The amount of remaining data in external storage.(Unit:Word) |

### RKCAN\_ATFO

Address: **Operational Base** + offset (0x0700)

| Bit  | Attr | Reset Value | Description                                                                                         |
|------|------|-------------|-----------------------------------------------------------------------------------------------------|
| 31   | RO   | 0x0         | reserved                                                                                            |
| 30   | RW   | 0x0         | RTR_EN<br>RTR Bit Filter Enable<br>1'b0: Disable<br>1'b1: Enable                                    |
| 29   | RW   | 0x0         | RTR<br>RTR part of the Acceptance Filter 0<br>1'b0: Data Frame<br>1'b1: Remote Frame(Only CAN Mode) |
| 28:0 | RW   | 0x000000000 | ID<br>ID part of the Acceptance Filter 0                                                            |

### RKCAN\_ATF1

Address: **Operational Base** + offset (0x0704)

| Bit  | Attr | Reset Value | Description                                                                                         |
|------|------|-------------|-----------------------------------------------------------------------------------------------------|
| 31   | RO   | 0x0         | reserved                                                                                            |
| 30   | RW   | 0x0         | RTR_EN<br>RTR Bit Filter Enable<br>1'b0: Disable<br>1'b1: Enable                                    |
| 29   | RW   | 0x0         | RTR<br>RTR part of the Acceptance Filter 1<br>1'b0: Data Frame<br>1'b1: Remote Frame(Only CAN Mode) |
| 28:0 | RW   | 0x000000000 | ID<br>ID part of the Acceptance Filter 0                                                            |

### RKCAN\_ATF2

Address: **Operational Base** + offset (0x0708)

| Bit | Attr | Reset Value | Description                                                      |
|-----|------|-------------|------------------------------------------------------------------|
| 31  | RO   | 0x0         | reserved                                                         |
| 30  | RW   | 0x0         | RTR_EN<br>RTR Bit Filter Enable<br>1'b0: Disable<br>1'b1: Enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 29         | RW          | 0x0                | RTR<br>RTR part of the Acceptance Filter 2<br>1'b0: Data Frame<br>1'b1: Remote Frame(Only CAN Mode) |
| 28:0       | RW          | 0x00000000         | ID<br>ID part of the Acceptance Filter 0                                                            |

**RKCAN ATF3**Address: **Operational Base** + offset (0x070C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                                                            |
| 30         | RW          | 0x0                | RTR_EN<br>RTR Bit Filter Enable<br>1'b0: Disable<br>1'b1: Enable                                    |
| 29         | RW          | 0x0                | RTR<br>RTR part of the Acceptance Filter 3<br>1'b0: Data Frame<br>1'b1: Remote Frame(Only CAN Mode) |
| 28:0       | RW          | 0x00000000         | ID<br>ID part of the Acceptance Filter 0                                                            |

**RKCAN ATF4**Address: **Operational Base** + offset (0x0710)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                                                            |
| 30         | RW          | 0x0                | RTR_EN<br>RTR Bit Filter Enable<br>1'b0: Disable<br>1'b1: Enable                                    |
| 29         | RW          | 0x0                | RTR<br>RTR part of the Acceptance Filter 4<br>1'b0: Data Frame<br>1'b1: Remote Frame(Only CAN Mode) |
| 28:0       | RW          | 0x00000000         | ID<br>ID part of the Acceptance Filter 0                                                            |

**RKCAN ATFMO**Address: **Operational Base** + offset (0x0714)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | MASK<br>1'b0: Mask Mode, Register ATF0M[30:0] is used to configure the mask filed of each rule for ATF0;<br>1'b1: List Mode, Register ATF0M[30:0] is used as acceptance filter ATF5. |
| 30         | RW          | 0x0                | RTR_EN<br>RTR Bit Filter Enable<br>1'b0: Disable<br>1'b1: Enable                                                                                                                     |
| 29         | RW          | 0x0                | RTR<br>RTR part of the Acceptance Filter M0<br>1'b0: Data Frame<br>1'b1: Remote Frame(Only CAN Mode)                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 28:0       | RW          | 0x1fffffff         | ID<br>when ATF0M.MASK is 1'b0, ATF0M.ID is ID part of the Acceptance Filter;<br>when ATF0M.MASK is 1'b1, ATF0M.ID is ID Mask Field for ATF0.ID. |

**RKCAN ATFM1**Address: **Operational Base** + offset (0x0718)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | MASK<br>1'b0: Mask Mode, Register ATF1M[30:0] is used to configure the mask filed of each rule for ATF1;<br>1'b1: List Mode, Register ATF1M[30:0] is used as acceptance filter ATF6; |
| 30         | RW          | 0x0                | RTR_EN<br>RTR Bit Filter Enable<br>1'b0: Disable<br>1'b1: Enable                                                                                                                     |
| 29         | RW          | 0x0                | RTR<br>RTR part of the Acceptance Filter M1<br>1'b0: Data Frame<br>1'b1: Remote Frame(Only CAN Mode)                                                                                 |
| 28:0       | RW          | 0x1fffffff         | ID<br>when ATF0M.MASK is 1'b0, ATF0M.ID is ID part of the Acceptance Filter;<br>when ATF0M.MASK is 1'b1, ATF0M.ID is ID Mask Field for ATF0.ID.                                      |

**RKCAN ATFM2**Address: **Operational Base** + offset (0x071C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | MASK<br>1'b0: Mask Mode, Register ATF2M[30:0] is used to configure the mask filed of each rule for ATF2;<br>1'b1: List Mode, Register ATF2M[30:0] is used as acceptance filter ATF7. |
| 30         | RW          | 0x0                | RTR_EN<br>RTR Bit Filter Enable<br>1'b0: Disable<br>1'b1: Enable                                                                                                                     |
| 29         | RW          | 0x0                | RTR<br>RTR part of the Acceptance Filter M2<br>1'b0: Data Frame<br>1'b1: Remote Frame(Only CAN Mode)                                                                                 |
| 28:0       | RW          | 0x1fffffff         | ID<br>when ATF0M.MASK is 1'b0, ATF0M.ID is ID part of the Acceptance Filter;<br>when ATF0M.MASK is 1'b1, ATF0M.ID is ID Mask Field for ATF0.ID.                                      |

**RKCAN ATFM3**Address: **Operational Base** + offset (0x0720)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | MASK<br>1'b0: Mask Mode, Register ATF3M[30:0] is used to configure the mask filed of each rule for ATF3;<br>1'b1: List Mode, Register ATF3M[30:0] is used as acceptance filter ATF8. |
| 30         | RW          | 0x0                | RTR_EN<br>RTR Bit Filter Enable<br>1'b0: Disable<br>1'b1: Enable                                                                                                                     |
| 29         | RW          | 0x0                | RTR<br>RTR part of the Acceptance Filter M3<br>1'b0: Data Frame<br>1'b1: Remote Frame(Only CAN Mode)                                                                                 |
| 28:0       | RW          | 0x1fffffff         | ID<br>when ATF0M.MASK is 1'b0, ATF0M.ID is ID part of the Acceptance Filter;<br>when ATF0M.MASK is 1'b1, ATF0M.ID is ID Mask Field for ATF0.ID.                                      |

**RKCAN\_ATFM4**Address: **Operational Base** + offset (0x0724)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | MASK<br>1'b0: Mask Mode, Register ATF4M[30:0] is used to configure the mask filed of each rule for ATF4;<br>1'b1: List Mode, Register ATF4M[30:0] is used as acceptance filter ATF9. |
| 30         | RW          | 0x0                | RTR_EN<br>RTR Bit Filter Enable<br>1'b0: Disable<br>1'b1: Enable                                                                                                                     |
| 29         | RW          | 0x0                | RTR<br>RTR part of the Acceptance Filter M4<br>1'b0: Data Frame<br>1'b1: Remote Frame(Only CAN Mode)                                                                                 |
| 28:0       | RW          | 0x1fffffff         | ID<br>when ATF0M.MASK is 1'b0, ATF0M.ID is ID part of the Acceptance Filter;<br>when ATF0M.MASK is 1'b1, ATF0M.ID is ID Mask Field for ATF0.ID.                                      |

**RKCAN\_ATF\_DLC**Address: **Operational Base** + offset (0x0728)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                   |
| 5          | RW          | 0x0                | atf_dlc_mode<br>1'b0: Over Mode, DLC filter process is only passed if the DLC value of the message accepted is equal to or higher than the value of ATF_DLC.atf_dlc;<br>1'b1: Less Mode, DLC filter process is only passed if the DLC value of the message accepted is equal to or less than the value of ATF_DLC.atf_dlc. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                               |
|------------|-------------|--------------------|------------------------------------------------------------------|
| 4          | RW          | 0x0                | atf_dlc_en<br>DLC Filter Enable<br>1'b0: Disable<br>1'b1: Enable |
| 3:0        | RW          | 0x0                | atf_dlc<br>Configure DLC value of received message               |

**RKCAN ATF CTL**Address: **Operational Base** + offset (0x072C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:10      | RO          | 0x000000           | reserved                                                                |
| 9          | RW          | 0x0                | atf9_en<br>Acceptance Filter 9 Disable<br>1'b0: Disable<br>1'b1: Enable |
| 8          | RW          | 0x0                | atf8_en<br>Acceptance Filter 8 Disable<br>1'b0: Disable<br>1'b1: Enable |
| 7          | RW          | 0x0                | atf7_en<br>Acceptance Filter 7 Disable<br>1'b0: Disable<br>1'b1: Enable |
| 6          | RW          | 0x0                | atf6_en<br>Acceptance Filter 6 Disable<br>1'b0: Disable<br>1'b1: Enable |
| 5          | RW          | 0x0                | atf5_en<br>Acceptance Filter 5 Disable<br>1'b0: Disable<br>1'b1: Enable |
| 4          | RW          | 0x0                | atf4_en<br>Acceptance Filter 4 Disable<br>1'b0: Disable<br>1'b1: Enable |
| 3          | RW          | 0x0                | atf3_en<br>Acceptance Filter 3 Disable<br>1'b0: Disable<br>1'b1: Enable |
| 2          | RW          | 0x0                | atf2_en<br>Acceptance Filter 2 Disable<br>1'b0: Disable<br>1'b1: Enable |
| 1          | RW          | 0x0                | atf1_en<br>Acceptance Filter 1 Disable<br>1'b0: Disable<br>1'b1: Enable |
| 0          | RW          | 0x0                | atf0_en<br>Acceptance Filter 0 Enable<br>1'b0: Disable<br>1'b1: Enable  |

**RKCAN AUTO RETX CFG**Address: **Operational Base** + offset (0x0808)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                                                                                                                                            |
| 19         | RW          | 0x0                | retx_cnt_self_clr<br>retx_cnt clear bit                                                                                                                                                                             |
| 18:3       | RO          | 0x0064             | retx_time_limit<br>Auto Retx Time Threshold                                                                                                                                                                         |
| 2          | RW          | 0x0                | auto_retx_cnt_clr<br>Set to 1 to clear the Auto Retransmission Counter(auto_retx_cnt)                                                                                                                               |
| 1          | RW          | 0x0                | retx_limit_en<br>1'b0: Disable retx_time_limit. Keep resending until the transmission is successful;<br>1'b1: Enable retx_time_limit. Stop retransmission when the number of retransmissions reaches the threshold. |
| 0          | RW          | 0x0                | auto_retx_mode<br>Auto Retransmission Mode<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                         |

### **RKCAN AUTO RETX STATE0**

Address: **Operational Base** + offset (0x080C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                |
|------------|-------------|--------------------|---------------------------------------------------|
| 31:16      | RO          | 0x0000             | noack_cnt<br>No ACK Counter                       |
| 15:0       | RO          | 0x0000             | auto_retx_cnt<br>Automatic Retransmission Counter |

### **RKCAN AUTO RETX STATE1**

Address: **Operational Base** + offset (0x0810)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:16      | RO          | 0x0000             | txerr_cnt<br>TX Error Counter        |
| 15:0       | RO          | 0x0000             | arbit_fail_cnt<br>Arbit Fail Counter |

### **RKCAN OLF CFG**

Address: **Operational Base** + offset (0x0814)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x00               | reserved                                                                                                                     |
| 23:16      | RO          | 0x00               | tx_wait_thr<br>Used to configure the number of bits for transmission wait.                                                   |
| 15:13      | RO          | 0x0                | reserved                                                                                                                     |
| 12         | RO          | 0x0                | tx_wait_clr<br>tx_wait_cnt Clear                                                                                             |
| 11         | RO          | 0x0                | tx_wait_mode<br>Transmit wait mode.<br>1'b0: Immediate transmission<br>1'b1: Wait for "tx_wait_thr" bits before transmitting |
| 10         | RW          | 0x0                | ovd_time<br>1'b0: Transmit one overload frame at a time<br>1'b1: Continuously transmit two overload frame at a time          |
| 9          | RW          | 0x0                | auto_ovd_mode<br>Auto transmit Overload frame mode<br>1'b0: Disable<br>1'b1: Enable                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:0        | RW          | 0x000              | <p>ovd_tx_thr<br/>Overload Frame Transmit Threshold Level. The configurable range is from 0 to 256. Unit:Word<br/>When the remaining space of the RXFIFO is less than the threshold set by ovd_tx_thr, RKCAN will automatically send an overload frame.</p> |

**RKCAN\_RXINT\_CTRL**Address: **Operational Base** + offset (0x0818)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18      | RO          | 0x0000             | reserved                                                                                                                                                                                                      |
| 17         | RW          | 0x0                | <p>mfi_timeout_mode<br/>Multi Frame Interrupt(MFI) Timeout Mode<br/>1'b0: Disable<br/>1'b1: Enable</p>                                                                                                        |
| 16         | RW          | 0x0                | <p>mfi_mode<br/>Multi Frame Interrupt(MFI) Mode<br/>1'b0: Generate an interrupt when a frame is received;<br/>1'b1: Generate an interrupt when N frames are received, N is configured by RXINT.rxint_num.</p> |
| 15:0       | RW          | 0x0100             | rxint_num<br>Used to configure mulit frame interrupt mode                                                                                                                                                     |

**RKCAN\_RXINT\_TIMEOUT**Address: **Operational Base** + offset (0x081C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                          |
|------------|-------------|--------------------|---------------------------------------------|
| 31:0       | RW          | 0x0000ffff         | threshold<br>Timeout Threshold for MFI Mode |

**RKCAN\_ERROR\_CODE**Address: **Operational Base** + offset (0x0900)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | <p>tx_crc_error_flag<br/>When RKCAN is the transmitter, CRC error is detected.<br/>1'b0: No CRC Error<br/>1'b1: An CRC Error has occurred</p>                                  |
| 30         | RW          | 0x0                | <p>rx_crc_error_flag<br/>When RKCAN is the receiver, CRC error is detected.<br/>1'b0: No CRC Error<br/>1'b1: An CRC Error has occurred</p>                                     |
| 29         | RO          | 0x0                | <p>error_phase<br/>1'b0: Arbitration Phase<br/>1'b1: Data Phase</p>                                                                                                            |
| 28:26      | RO          | 0x0                | <p>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</p>                         |
| 25         | RW          | 0x0                | <p>error_direction<br/>'error_direction' is used to indicate whether RKCAN was in a sending or receiving state when an error occurred.<br/>1'b0: TX Node<br/>1'b1: RX Node</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24:19      | RO          | 0x00               | <p>tx_state<br/>           Indicate the status of TX FSM when an error occurs<br/>           6'b000001: TRANSMIT_IDLE<br/>           6'b000010: TRANSMIT_SOF_DLC<br/>           6'b000100: TRANSMIT_DATA<br/>           6'b001000: TRANSMIT_STUFF_COUNT<br/>           6'b010000: TRANSMIT_CRC<br/>           6'b100000: TRANSMIT_ACK_EOF</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 18:0       | RO          | 0x00000            | <p>rx_state<br/>           Indicate the status of RX FSM when an error occurs<br/>           19'b00000000000000000001: RECEIVE_STOP<br/>           19'b000000000000000000010: RECEIVE_BUS_INT<br/>           19'b0000000000000000000100: RECEIVE_BUS_IDLE<br/>           19'b00000000000000000001000: RECEIVE_SOF_IDE<br/>           19'b000000000000000000010000: RECEIVE_ID2_RTR<br/>           19'b0000000000000000000100000: RECEIVE_FDF<br/>           19'b00000000000000001000000: RECEIVE_RES<br/>           19'b00000000000010000000: RECEIVE_BRS_ESI<br/>           19'b0000000000001000000000: RECEIVE_DLC<br/>           19'b00000000010000000000: RECEIVE_DATA<br/>           19'b000000000100000000000: RECEIVE_STUFF_COUNT<br/>           19'b00000000100000000000: RECEIVE_CRC<br/>           19'b00000010000000000000: RECEIVE_CRC_LIM<br/>           19'b00000100000000000000: RECEIVE_ACK_SLOT<br/>           19'b00001000000000000000: RECEIVE_ACK_LIM<br/>           19'b00010000000000000000: RECEIVE_EOF<br/>           19'b00100000000000000000: RECEIVE_SPACE<br/>           19'b01000000000000000000: RECEIVE_OVERLOAD<br/>           19'b10000000000000000000: RECEIVE_ERROR</p> |

**RKCAN ERROR MASK**Address: **Operational Base** + offset (0x0904)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0000000          | reserved                                                                                                               |
| 4          | RW          | 0x0                | <p>ack_error<br/>           Error mask for ack error<br/>           1'b0: Unmasked<br/>           1'b1: Masked</p>     |
| 3          | RW          | 0x0                | <p>form_error<br/>           Error mask for form error<br/>           1'b0: Unmasked<br/>           1'b1: Masked</p>   |
| 2          | RW          | 0x0                | <p>crc_error<br/>           Error mask for crc error<br/>           1'b0: Unmasked<br/>           1'b1: Masked</p>     |
| 1          | RW          | 0x0                | <p>stuff_error<br/>           Error mask for stuff error<br/>           1'b0: Unmasked<br/>           1'b1: Masked</p> |
| 0          | RW          | 0x0                | <p>bit_error<br/>           Error mask for bit error<br/>           1'b0: Unmasked<br/>           1'b1: Masked</p>     |

**RKCAN\_RXERRORCNT**

Address: **Operational Base** + offset (0x0910)

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

**RKCAN TXERRORCNT**Address: **Operational Base** + offset (0x0914)

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

**RKCAN ARBIT FAIL STATE**Address: **Operational Base** + offset (0x0918)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------|
| 31:9       | RO          | 0x000000           | reserved                                                                                                           |
| 8:0        | RO          | 0x000              | arbit_fail_code<br>This register indicates the bit position of arbitration section where the arbitration was lost. |

**RKCAN RTL VERSION**Address: **Operational Base** + offset (0x0F0C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:0       | RO          | 0xcfdbaa0eb        | version<br>RKCAN Version = 32'hCFD_B_A0_E5 |

**34.4 Interface Description**

Table 34-1 CAN IO Interface Description

| <b>Module Pin</b> | <b>Direction</b> | <b>Rockchip Matrix IO</b> | <b>IOMUX Setting</b> |
|-------------------|------------------|---------------------------|----------------------|
| CAN0 TX           | I/O              | RM_IO                     |                      |
| CAN0 RX           | I/O              | RM_IO                     |                      |
| CAN1 TX           | I/O              | RM_IO                     |                      |
| CAN1 RX           | I/O              | RM_IO                     |                      |

Notes: I=Input, O=Output, I/O=Input/Output. For the configuration of RM\_IO, please refer to chapter "Rockchip Matrix IO".

**34.5 Application Notes****34.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. 34-11 Initialization Flow

### 34.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. 34-12 Loop-back Mode

### 34.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. 34-13 Silent Mode

#### 34.5.4 RXSTX Mode

- (1) rxstx\_mode=0, RKCAN cannot receive the data sent by itself;
- (2) 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 RX storage.

#### 34.5.5 Auto Retx Mode

RKCAN supports two automatic retransmission modes:

- (1) Unlimited Retransmission Mode: There is no limit to the number of retransmissions until the retransmission is successful.
- (2) Limited Retransmissions Mode: The threshold for the number of automatic retransmissions can be configured. If the limit threshold is reached and the retransmission is still not successful, the retransmission will stop, and a retransmission failure interrupt will be issued. RKCAN will also count the reasons and corresponding times that cause the transmission failure during the retransmission process, such as arbitration failure, NoACK, or bus error, etc.

#### 34.5.6 Bus Off Recovery Mechanism

RKCAN supports three configurable Bus\_off recovery mechanisms, which are:

- (1) Automatic Recovery: When the RKCAN node detects 11 recessive bits (no active messages on the CAN bus) appearing consecutively 128 times, it can automatically exit the Bus\_off state.
- (2) Timed Recovery: The timing length can be set by configuring the register. After the timer expires, RKCAN exits the Bus\_off state. The software can implement fast recovery and slow recovery functions using the timed recovery mode.
- (3) Manual Recovery: In manual recovery mode, RKCAN will not automatically exit the Bus-off state. It can only exit the Bus-off state by configuring the manual recovery register.

#### 34.5.7 Sleep Mode

After enabling Sleep Mode, RKCAN will automatically enter a low-power mode when the bus is idle, turning off the internal clock. The internal clock will automatically turn on when there is a data frame on the bus or when a data frame needs to be sent.

#### 34.5.8 Multi-frame Mode

RKCAN supports an interrupt being issued upon receiving each frame, and it can also be configured to issue an interrupt only after receiving N frames in multi-frame mode. This can reduce the number of interrupts and reduce software intervention. The related configuration can be found in the register RXINT\_CTRL register and RXINT\_TIMEOUT.

## **Chapter 35 Master Double Data Rate Serial Memory Controller (MASTER DSMC)**

### **35.1 Overview**

The DSMC module provides function and operation for interfacing to the DSMC memory devices, and the Rockchip LocalBus devices. The DSMC achieves high speed read/write throughput by double data rate interface.

The main feature is shown below.

- Support the double data rate interface
- Support up to select 4 chips
- Support 8-wire and 16-wire serial transfer mode
- Support configurable write/read contiguous address merging transaction
- Support configurable write/read boundary address splitting transaction
- Support to transform WRAP transfer to INCR transfer
- Support byte access
- Support configurable DQS input clock delay line
- For LocalBus devices, support to assert the selecting signals CS simultaneously in the write transaction
- For LocalBus devices, support 3 clock mode : normal mode, always-on mode, no-edge-clk mode
- For LocalBus devices, support to request DMAC to transfer data when receiving interrupt 0/1
- For LocalBus devices, support configurable serial address width: 16 bits or 32 bits in different region

### **35.2 Block Diagram**

DSMC is comprised of:

- APB Interface

The APB Interface implements the APB slave operation. Its data bus width is 32 bits.

- AXI Interface

The AXI Interface is a XIP interface to access internal device. Its data bus width is 64 bits.

- I/O Port Interface

External data interface to or from I/O pads.

- Core

The core module is used to control the data stream of TX/RX datapath.



Fig. 35-1 DSMC Block Diagram

### 35.3 Function Description

The DSMC module is high throughput memory interface. It provides execute in place (XIP) and block copy access to DSMC memory devices (HyperRAM and HyperFlash). The DSMC module is compliant to the Cypress DSMC™ Specification. Meanwhile, it could access Rockchip LocalBus devices, and transfer instructions or bulk data with high speed.

#### 35.3.1 DSMC Core

This section describes physical interface of DSMC module. The DSMC core generates DSMC timing from control signals.

##### 35.3.1.1 Read

DSMC Core module asserts CSn, CLKP/CLKN, and DQ. Then, it outputs 3 words command/address, and reads 1 or more data by the timing of DQS. The DSMC Core puts the transaction request from AXI bus, such as the burst type and the burst length, to the C/A cycle on DSMC as is shown below.



Fig. 35-2 HyperRAM Read Waveform

##### 35.3.1.2 Write

This section describes the write operation of DSMC Core. The DSMC Core asserts CSn,

CLKP/CLKN, and DQ. Then, it outputs 3 words command/address, and writes 1 or more data. For HyperRAM write operation, there is initial clock latency before writing data.



Fig. 35-3 HyperRAM Write Waveform

### 35.3.1.3 Byte Mask

This DSMC Memory Interface Controller outputs DQS signal as a byte mask during write operation. When byte access is requested from Main Controller, not write data is masked by DQS=HIGH. When target device is HyperFlash, byte masked data is written to device because of only supporting 16-bit access (byte masked data is fill in all 1 bit). In the HyperRAM Write Waveform, the  $D_n A$  and  $D_{n+1} B$  is invalid data which is masked.

### 35.3.2 TX/RX Controller

The TX/RX Controller performs operation control by state machine, and flow control of data between AXI bus and DSMC. In addition, when next access address is accepted by multiple outstanding address on AXI bus, it could be merged to the present transaction to improve the bandwidth if the address of subsequent access is continuous address to the present access.

### 35.3.3 C/A Encoder

DSMC memory device uses 6 bytes of command/address information to define the transactions characteristics. Table below shows the assignments of CA bit in DSMC Memory Interface Controller.

Table 35-1 C/A Format of DSMC for Hyper Device

| C/A Bit | Name           | Assignment        |
|---------|----------------|-------------------|
| 47      | R/W#           | 0: Write, 1: Read |
| 46      | Target         | CRT in DSMC_MCRn  |
| 45      | Burst Type     | 0: WRAP, 1: INCR  |
| 44      | RFU            | 0                 |
| 43-16   | Page Address   | Address [31:4]    |
| 15      | RFU            | 0                 |
| 14-13   | RFU            | 3                 |
| 12-3    | RFU            | 0                 |
| 2-0     | Column Address | Address [3:1]     |

*note: The CA bit function of different devices slightly differs, and the exact meaning need to be referred to the datasheet of the device.*

### 35.3.4 FIFO

This section describes the FIFO for processing transaction request.

#### 35.3.4.1 ADDR FIFO

ADR FIFO is a synchronizer module from AXI clock domain to DSMC clock domain. This FIFO has 46-bit width. This FIFO stores the control data which includes address, length, burst type and r/w flag. From these data, the control signals are generated for Main Controller.

#### 35.3.4.2 W DAT FIFO

This FIFO is used to store the write data, valid information and strobe information written from the master in order to receive the command sequence of write buffer programming without a wait on AXI interface. The valid information indicates the 8-bit data is valid or not. The strobe information is used for strobe data from AXI interface to DSMC Core. When

valid and strobe is 1, the 8-bit data is written data.

### 35.3.4.3 R DAT FIFO

This FIFO is used to store the data read from RX FIFO and the error detection information, and data stored is outputted according to timing of ACLK on AXI interface. This error information is transferred to HOST by RRESP signals.

### 35.3.5 LocalBus

#### 35.3.5.1 Region division

The internal space of LocalBus device could be divided into different region, and they could be applied in suitable case. The size of regions is configue by DSMC\_DEV\_SIZE and DSMC\_SLV\_RGN\_DIVn. The attribution of different region could be set to DPRA, REG or FIFO.



Fig. 35-4 Region division of LocalBus device

#### 35.3.5.2 CA Encoder

Table 35-2 C/A Format of DSMC for LocalBus Device

| C/A Bit | Name       | Assignment            |
|---------|------------|-----------------------|
| 47      | R/W#       | 0: Read, 1: Write     |
| 46      | Target     | CRT in DSMC_MCRn      |
| 45      | Burst Type | 0: WRAP, 1: INCR      |
| 44      | Space Type | 0: FIFO, 1: DPRA      |
| 43      | FIFO Merge | 0: No Merge, 1: Merge |
| 42      | RFU        | 0                     |
| 41-40   | Region     | Region 0/1/2/3        |
| 39-32   | Length     | Burst length          |
| 31-0    | Address    | Address [31:0]        |

#### 35.3.5.3 Back pressure

The back pressure mechanism is used to make full use of FIFO region space.

In the read transaction, when the FIFO is empty and could not provide data to the DSMC interface, the slave could enter the wait state, in which slave stop to send DQS clock, and latch the output DQ data. When the FIFO is recovered, the slave could continue sending the DQS and DQ, which could save bandwidth comparing to restart another burst.

In the write transaction, when the FIFO is full and could not receive data from the DSMC interface, the asynchronous signal DSMC\_RDYN would be asserted. When the DSMC received, it would not send DQ and DSMC\_CLK until the DSMC\_RDYN is not asserted, which means there are enough space in the slave FIFO to accept data.

## 35.4 Register Description

### 35.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

### 35.4.2 Registers Summary

| Name              | Offset | Size | Reset Value | Description                                                                                                                    |
|-------------------|--------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| DSMC VER          | 0x0000 | W    | 0x000000100 | IP Version Register                                                                                                            |
| DSMC CSR          | 0x0008 | W    | 0x000000000 | Controller Status Register                                                                                                     |
| DSMC TAR          | 0x0010 | W    | 0x000000000 | Transaction Allocation Register                                                                                                |
| DSMC AXICTL       | 0x0014 | W    | 0x000000020 | AXI Transaction Control Register                                                                                               |
| DSMC CLK MD       | 0x0020 | W    | 0x000000000 | Clock Mode Register                                                                                                            |
| DSMC DEV SIZE     | 0x0030 | W    | 0x000000017 | Device Region Size Register                                                                                                    |
| DSMC INT EN       | 0x0040 | W    | 0x000000000 | Interrupt Enable Register                                                                                                      |
| DSMC INT STATUS   | 0x0044 | W    | 0x000000000 | Interrupt Status Register                                                                                                      |
| DSMC INT MASK     | 0x0048 | W    | 0x000000000 | Interrupt Mask Register                                                                                                        |
| DSMC DMA EN       | 0x0050 | W    | 0x000000000 | Interrupt Mask Register                                                                                                        |
| DSMC DMA REQ NUM0 | 0x0054 | W    | 0x000000000 | DMA Request Number Register 0                                                                                                  |
| DSMC DMA REQ NUM1 | 0x0058 | W    | 0x000000000 | DMA Request Number Register 1                                                                                                  |
| DSMC DMA MUX      | 0x005C | W    | 0x000000010 | Interrupt to DMA Request Multiplexer Register                                                                                  |
| DSMC VDMC0        | 0x1000 | W    | 0x000000226 | Vendor Device Mode Control Register, and it could be expanded to CS1/2/3# for sub base address 0x2000/0x3000/0x4000            |
| DSMC MCR0         | 0x1010 | W    | 0x000000003 | CS0# Memory Configuration Register, and it could be expanded to CS1/2/3# for sub base address 0x2000/0x3000/0x4000             |
| DSMC MTR0         | 0x1014 | W    | 0x000000022 | CS0# Memory Base Address, and it could be expanded to CS1/2/3# for sub base address 0x2000/0x3000/0x4000                       |
| DSMC WAIT TIME0   | 0x1018 | W    | 0x0000007FF | CS0# Memory Base Address, and it could be expanded to CS1/2/3# for sub base address 0x2000/0x3000/0x4000                       |
| DSMC BDRTCRO      | 0x1020 | W    | 0x000000002 | Boundary Transfer Control Register 0, and it could be expanded to CS1/2/3# for sub base address 0x2000/0x3000/0x4000           |
| DSMC MRGTCR0      | 0x1024 | W    | 0x000000000 | Merge Transfer Control Register 0, and it could be expanded to CS1/2/3# for sub base address 0x2000/0x3000/0x4000              |
| DSMC WRAP2INCR0   | 0x1028 | W    | 0x000000000 | The function register of changing WRAP to INCR, and it could be expanded to CS1/2/3# for sub base address 0x2000/0x3000/0x4000 |

| Name                      | Offset | Size | Reset Value | Description                                                                                                      |
|---------------------------|--------|------|-------------|------------------------------------------------------------------------------------------------------------------|
| <u>DSMC_RDS_DLL0_CTL0</u> | 0x1030 | W    | 0x80000010  | RDS Clock DLL Control Register 0, and it could be expanded to CS1/2/3# for sub base address 0x2000/0x3000/0x4000 |
| <u>DSMC_RDS_DLL1_CTL0</u> | 0x1034 | W    | 0x80000010  | RDS Clock DLL Control Register 1, and it could be expanded to CS1/2/3# for sub base address 0x2000/0x3000/0x4000 |
| <u>DSMC_SLV_RGN_DIV0</u>  | 0x1040 | W    | 0x00000002  | The division of slave region , and it could be expanded to CS1/2/3# for sub base address 0x2000/0x3000/0x4000    |
| <u>DSMC_RGN0_ATTR0</u>    | 0x1050 | W    | 0x00000000  | The attribution of region 0, and it could be expanded to CS1/2/3# for sub base address 0x2000/0x3000/0x4000      |
| <u>DSMC_RGN1_ATTR0</u>    | 0x1054 | W    | 0x00000000  | The attribution of region 0, and it could be expanded to CS1/2/3# for sub base address 0x2000/0x3000/0x4000      |
| <u>DSMC_RGN2_ATTR0</u>    | 0x1058 | W    | 0x00000000  | The attribution of region 2, and it could be expanded to CS1/2/3# for sub base address 0x2000/0x3000/0x4000      |
| <u>DSMC_RGN3_ATTR0</u>    | 0x105C | W    | 0x00000000  | The attribution of region 3, and it could be expanded to CS1/2/3# for sub base address 0x2000/0x3000/0x4000      |

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

### 35.4.3 Detail Registers Description

#### DSMC\_VER

Address: Operational Base(0xFF8B0000) + offset (0x0000)

| Bit  | Attr | Reset Value | Description           |
|------|------|-------------|-----------------------|
| 31:0 | RO   | 0x00000100  | version<br>IP Version |

#### DSMC\_CSR

Address: Operational Base(0xFF8B0000) + offset (0x0008)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                   |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:27 | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                      |
| 26    | RO   | 0x0         | wrstoerr<br>Write RSTO error. This bit indicates whether HyperBus memory is under reset state in the latest write operation.<br>1'b0: Normal operation<br>1'b1: HyperBus memory is under reset<br>When this bit is set, HyperBus Memory Controller IP responds by AXI SLVERR. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25         | RO          | 0x0                | wtrserr<br>Write Transaction Error. This bit indicates whether AXI protocol is acceptable by HyperBus Memory Controller IP in the latest write transaction.<br>1'b0: Normal operation<br>1'b1: This protocol is not supported<br>When this bit is set, HyperBus Memory Controller IP responds by AXI SLVERR. |
| 24         | RO          | 0x0                | wdecerr<br>Write Decode Error. This bit indicates whether access address is acceptable in the latest write transaction.<br>1'b0: Normal operation<br>1'b1: Access address is not reachable<br>When this bit is set, HyperBus Memory Controller IP responds by AXI DECERR.                                    |
| 23:17      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                     |
| 16         | RO          | 0x0                | wact<br>Write is Active. This bit indicates whether write transaction is in progress or not.<br>1'b0: Write is idle<br>1'b1: Write is active                                                                                                                                                                 |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                     |
| 11         | RO          | 0x0                | rdsstall<br>RDS Stall. This bit indicates whether read data transfer from HyperBus memory is stalled (RDS remains LOW) in the latest read transaction.<br>1'b0: Normal operation<br>1'b1: RDS is stalled<br>When this bit is set, HyperBus Memory Controller IP responds by AXI SLVERR.                      |
| 10         | RO          | 0x0                | rrstoerr<br>Read RSTO error. This bit indicates whether HyperBus memory is under reset state in the latest read operation.<br>1'b0: Normal operation<br>1'b1: HyperBus memory is under reset<br>When this bit is set, HyperBus Memory Controller IP responds by AXI SLVERR.                                  |
| 9          | RO          | 0x0                | rtrserr<br>Read Transaction Error. This bit indicates whether AXI protocol is acceptable by HyperBus Memory Controller IP in the latest read transaction.<br>1'b0: Normal operation<br>1'b1: This protocol is not supported<br>When this bit is set, HyperBus Memory Controller IP responds by AXI SLVERR.   |
| 8          | RO          | 0x0                | rdecerr<br>Read Decode Error. This bit indicates whether access address is acceptable in the latest read transaction.<br>1'b0: Normal operation<br>1'b1: Access address is not reachable<br>When this bit is set, HyperBus Memory Controller IP responds by AXI DECERR.                                      |
| 7:1        | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RO          | 0x0                | ract<br>Read is Active. This bit indicates whether read transaction is in progress or not.<br>1'b0: Read is idle<br>1'b1: Read is active |

**DSMC TAR**

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                                                                                                                        |
| 5:4        | RW          | 0x0                | rta<br>Read Transaction Allocation.<br>2'b00: 1 read transaction<br>2'b01: 2 read transactions<br>2'b10: 3 read transactions<br>2'b11: 4 read transactions      |
| 3:2        | RO          | 0x0                | reserved                                                                                                                                                        |
| 1:0        | RW          | 0x0                | wta<br>Write Transaction Allocation.<br>2'b00: 1 write transaction<br>2'b01: 2 write transactions<br>2'b10: 3 write transactions<br>2'b11: 4 write transactions |

**DSMC AXICTL**

Address: Operational Base(0xFF8B0000) + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9       | RO          | 0x0000000          | reserved                                                                                                                                                                                                                                                |
| 8          | RW          | 0x0                | rd_no_err<br>The axi read response will be tied 0 if this bit is enabled.<br>1'b0: disable<br>1'b1: enable                                                                                                                                              |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                |
| 5:4        | RW          | 0x2                | write_bvalid_ctl<br>2'b00: Generate the bvalid after the burst data TX end in IO<br>2'b01: Generate the bvalid after the TX state machine accept the request FIFO<br>2'b10: Generate the bvalid after burst write granted by arbiter<br>2'b11: Reserved |
| 3:1        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                |
| 0          | RW          | 0x0                | nowait_write_data_done_en<br>1'b0: Disable<br>1'b1: Enable<br>Only support "0" in current project                                                                                                                                                       |

**DSMC CLK MD**

Address: Operational Base(0xFF8B0000) + offset (0x0020)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0        | RW          | 0x0                | <p>clk_mode<br/>This register is only configured in local bus application.<br/>2'b00: Normal-toggle Mode, the ck only toggles when cs is asserted<br/>2'b01: Always-on Mode, the ck is always on<br/>2'b10: No-edge-clk Mode, the ck is always on except for the cs changing edge<br/>2'b11: Reserved</p> |

**DSMC DEV SIZE**

Address: Operational Base(0xFF8B0000) + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                               |
| 4:0        | RW          | 0x17               | <p>dev_size<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: 2G bytes<br/>In Memory-Mapped mode, the CS is controlled by AXI address bus, region size is used to generate CS.</p> |

**DSMC INT EN**

Address: Operational Base(0xFF8B0000) + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                                                                                                                |
| 4          | RW          | 0x0                | <p>rdstall_int_en<br/>This bit is used to control the read stall time out interrupt enable.<br/>1'b0: Disable<br/>1'b1: Enable</p>                      |
| 3          | RW          | 0x0                | <p>int_en3<br/>This bit is used to control the interrupt3. This register is only valid in local bus application.<br/>1'b0: Disable<br/>1'b1: Enable</p> |
| 2          | RW          | 0x0                | <p>int_en2<br/>This bit is used to control the interrupt2. This register is only valid in local bus application.<br/>1'b0: Disable<br/>1'b1: Enable</p> |
| 1          | RW          | 0x0                | <p>int_en1<br/>This bit is used to control the interrupt1. This register is only valid in local bus application.<br/>1'b0: Disable<br/>1'b1: Enable</p> |
| 0          | RW          | 0x0                | <p>int_en0<br/>This bit is used to control the interrupt0. This register is only valid in local bus application.<br/>1'b0: Disable<br/>1'b1: Enable</p> |

**DSMC INT STATUS**

Address: Operational Base(0xFF8B0000) + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                           |
| 4          | W1C         | 0x0                | rdstall_int_status<br>Read stall time out interrupt status of DSMC. High level means occurring 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.<br>This register is only valid in local bus application. |
| 3          | W1C         | 0x0                | int_status3<br>Interrupt 3 status of DSMC. High level means occurring 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.<br>This register is only valid in local bus application.                          |
| 2          | W1C         | 0x0                | int_status2<br>Interrupt 2 status of DSMC. High level means occurring 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.<br>This register is only valid in local bus application.                          |
| 1          | W1C         | 0x0                | int_status1<br>Interrupt 1 status of DSMC. High level means occurring 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.<br>This register is only valid in local bus application.                          |
| 0          | W1C         | 0x0                | int_status0<br>Interrupt 0 status of DSMC. High level means occurring 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.<br>This register is only valid in local bus application.                          |

**DSMC INT MASK**

Address: Operational Base(0xFF8B0000) + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                                                                                                |
| 4          | RW          | 0x0                | rdstall_int_mask<br>This register is used to mask the read stall interrupt.<br>1'b0: Interrupt is unmasked<br>1'b1: Interrupt is masked |
| 3          | RW          | 0x0                | int_mask3<br>This register is only valid in local bus application.<br>1'b0: Interrupt is unmasked<br>1'b1: Interrupt is masked          |
| 2          | RW          | 0x0                | int_mask2<br>This register is only valid in local bus application.<br>1'b0: Interrupt is unmasked<br>1'b1: Interrupt is masked          |
| 1          | RW          | 0x0                | int_mask1<br>This register is only valid in local bus application.<br>1'b0: Interrupt is unmasked<br>1'b1: Interrupt is masked          |
| 0          | RW          | 0x0                | int_mask0<br>This register is only valid in local bus application.<br>1'b0: Interrupt is unmasked<br>1'b1: Interrupt is masked          |

**DSMC DMA EN**

Address: Operational Base(0xFF8B0000) + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                                                                                                           |
| 1          | RW          | 0x0                | dma_req_en1<br>This bit is used to control the DMA request from interrupt1. This register is only valid in local bus application.<br>1'b0: Disable<br>1'b1: Enable |
| 0          | RW          | 0x0                | dma_req_en0<br>This bit is used to control the DMA request from interrupt0. This register is only valid in local bus application.<br>1'b0: Disable<br>1'b1: Enable |

**DSMC DMA REQ NUM0**

Address: Operational Base(0xFF8B0000) + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                              |
| 15:0       | RW          | 0x0000             | dma_req_num0<br>This register is used to indicate the dma request number when DSMC accepts the interrupt0 from local bus slave. This register is only valid in local bus application. |

**DSMC DMA REQ NUM1**

Address: Operational Base(0xFF8B0000) + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                              |
| 15:0       | RW          | 0x0000             | dma_req_num1<br>This register is used to indicate the dma request number when DSMC accepts the interrupt1 from local bus slave. This register is only valid in local bus application. |

**DSMC DMA MUX**

Address: Operational Base(0xFF8B0000) + offset (0x005C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                                                                                                    |
| 5:4        | RW          | 0x1                | dma_req1_mux<br>This bit field is used to select the interrupt to DMA request1.<br>2'b00: int0<br>2'b01: int1<br>2'h10: int2<br>2'b11: int3 |
| 3:2        | RO          | 0x0                | reserved                                                                                                                                    |
| 1:0        | RW          | 0x0                | dma_req0_mux<br>This bit field is used to select the interrupt to DMA request0.<br>2'b00: int0<br>2'b01: int1<br>2'h10: int2<br>2'b11: int3 |

**DSMC VDMC0**

Address: Operational Base(0xFF8B0000) + offset (0x1000)

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

| Bit | Attr | Reset Value | Description                                                                                                                                                                                    |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9   | RW   | 0x1         | latency_fixed<br>Only valid to APM pSRAM Read Memory.<br>1'b0: Variable<br>1'b1: Fixed                                                                                                         |
| 8   | RW   | 0x0         | reset_cmd_mode<br>Generate reset Command to Device. Only valid in APM mid when CR register mode is set. If this bit is set, any write access in CR mode will initiate the FF command sequence. |
| 7:4 | RW   | 0x2         | protocol<br>Device Type<br>4'h0: Reserved<br>4'h1: OPI_Xccela (reserved)<br>4'h2: HyperBus (reserved)<br>4'h3: Local Bus<br>Others: Reserved                                                   |
| 3:0 | RW   | 0x6         | mid<br>MID<br>4'h1: Infineon/Cypress<br>4'h3: ISSI<br>4'h6: Winbond<br>4'hd: APM<br>Others: Reserved                                                                                           |

**DSMC\_MCR0**

Address: Operational Base(0xFF8B0000) + offset (0x1010)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                             |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | RW   | 0x0         | maxen<br>Maximum length Enable<br>1'b0: No configurable CS# low time<br>1'b1: Configurable CS# low time<br>When this bit 1, CS# low time can be configurable by MAXLEN bit.                                                                                                                                                                                             |
| 30:27 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                |
| 26:18 | RW   | 0x000       | maxlen<br>Maximum Length<br>This bit indicates maximum read/write transaction length to memory.<br>This bit is ignored when MAXEN bit is 0.<br>9'h000: 2 Byte (1 HyperBus CK)<br>9'h001: 4 Byte (2 HyperBus CK)<br>9'h002: 6 Byte (3 HyperBus CK)<br>.....<br>9'h1ff: 1024 Byte (512 HyperBus CK)                                                                       |
| 17    | RW   | 0x0         | tcmo<br>True Continuous Merge Option.<br>1'b0: No merging WRAP and INCR<br>1'b1: Merging WRAP and INCR<br>Note that this function can be used with the HyperBus memory with specific function. Please confirm whether it is corresponding HyperBus memory before enabling this function.<br>If set to 1, it means the controller can merge the Wrap and INCR operation. |

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16   | RW   | 0x0         | <p>acs<br/>Asymmetry Cache Support.<br/>1'b0: No asymmetry cache system support.<br/>1'b1: Asymmetry cache system support.<br/>This function should be disabled if the HyperBus memory itself supports the asymmetry cache system.<br/>If this bit set to 1, then the HyperBus memory interface controller accepts the wrap read transaction, and compares the required wrap size with the wrap size of HyperBus memory in register;<br/>When the wrap size is the same, HyperBus memory interface controller requires the wrap burst read to HyperBus memory;<br/>When the wrap size differs, HyperBus memory interface controller emulates wrap burst read by requesting two continuous burst read to HyperBus memory.</p> |
| 15:6 | RO   | 0x000       | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 5    | RW   | 0x0         | <p>crt<br/>Configuration Register Target.<br/>1'b0: Memory space<br/>1'b1: CR space<br/>This bit indicates whether the read or write operation accesses the memory or CR space. This bit is mapped to CA[46] bit in HyperRAM. When using HyperFlash, this bit should be set to 0.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 4    | RW   | 0x0         | <p>devtype<br/>Device Type.<br/>1'b0: HyperFlash<br/>1'b1: HyperRAM<br/>Device type for control target. Only support "1" in current project</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 3    | RW   | 0x0         | <p>iowidth<br/>IO Width.<br/>1'b0: x8 interface<br/>1'b1: x16 interface<br/>Note that "1'b1: x16 interface" can be set when DEVTYPE is set to "1'b1: HyperRAM"</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 2    | RW   | 0x0         | <p>exclusive_dqs<br/>This bit field indicates the number of valid dqs bit when iowidth is 16 bits, and it is only valid in local bus application.<br/>1'b0: 2 bits<br/>1'b1: 1 bit</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 1:0  | RW   | 0x3         | <p>wrapsize<br/>Wrap Size.<br/>2'b00: Reserved<br/>2'b01: 32(Clocks), 64 bytes for x8 and 128 bytes for x16<br/>2'b10: 8(Clocks), 16 bytes for x8 and 32 bytes for x16<br/>2'b11: 16(Clocks), 32 bytes for x8 and 64 bytes for x16<br/>The wrap burst length of HyperBus memory. This bit is ignored when the asymmetry cache support bit is 0. When the asymmetry cache support is 1, this bit should be set the same as wrap size of configuration register in HyperBus memory.</p>                                                                                                                                                                                                                                        |

**DSMC\_MTR0**

Address: Operational Base(0xFF8B0000) + offset (0x1014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RW          | 0x0                | rcshi<br>Read Chip Select High Between Operations.<br>This bit indicates CS# high time for read between operations. 0x0 corresponds to 1.5 clock cycle, 0xF corresponds to 16.5 clock cycle.                                                                                                                                                                                                                                                                                      |
| 27:24      | RW          | 0x0                | wcshi<br>Write Chip Select High Between Operations.<br>This bit indicates CS# high time for write between operations. 0x0 corresponds to 1.5 clock cycle, 0xF corresponds to 16.5 clock cycle.                                                                                                                                                                                                                                                                                    |
| 23:20      | RW          | 0x0                | rcss<br>Read Chip Select Setup to next CK rising edge.<br>This bit indicates CS# setup time for read from CS# assertion. 0x0 corresponds to 1 clock cycle, 0xF corresponds to 16 clock cycle.                                                                                                                                                                                                                                                                                     |
| 19:16      | RW          | 0x0                | wcss<br>Write Chip Select Setup to next CK rising edge.<br>This bit indicates CS# setup time for write from CS# assertion. 0x0 corresponds to 1 clock cycle, 0xF corresponds to 16 clock cycle.                                                                                                                                                                                                                                                                                   |
| 15:12      | RW          | 0x0                | rcsh<br>Read Chip Select Hold after CK falling edge.<br>This bit indicates CS# hold time for read to CS# de-assertion. 0x0 corresponds to 1 clock cycle, 0xF corresponds to 16 clock cycle.                                                                                                                                                                                                                                                                                       |
| 11:8       | RW          | 0x0                | wcsh<br>Write Chip Select Hold after CK falling edge.<br>This bit indicates CS# hold time for write to CS# de-assertion. 0x0 corresponds to 1 clock cycle, 0xF corresponds to 16 clock cycle.                                                                                                                                                                                                                                                                                     |
| 7:4        | RW          | 0x2                | rltcy<br>Read Latency Cycle. Only uses in HyperRAM.<br>This bit indicates initial latency code for write access. This bit is ignored when MCRX.DEVTYPE is 0 (HyperFlash).<br>4'h0: 5 clock latency<br>4'h1: 6 clock latency<br>4'h2: 7 clock latency<br>4'h3: 8 clock latency<br>4'h4: 9 clock latency<br>4'h5: 10 clock latency<br>4'hb: 0 clock latency<br>4'hc: 1 clock latency<br>4'hd: 2 clock latency<br>4'he: 3 clock latency<br>4'hf: 4 clock latency<br>Others: Reserved |
| 3:0        | RW          | 0x2                | wltcy<br>Write Latency Cycle. Only uses in HyperRAM.<br>This bit indicates initial latency code for write access. This bit is ignored when MCRX.DEVTYPE is 0 (HyperFlash).<br>4'h0: 5 clock latency<br>4'h1: 6 clock latency<br>4'h2: 7 clock latency<br>4'h3: 8 clock latency<br>4'h4: 9 clock latency<br>4'h5: 10 clock latency                                                                                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
|            |             |                    | 4'hb: 0 clock latency<br>4'hc: 1 clock latency<br>4'hd: 2 clock latency<br>4'he: 3 clock latency<br>4'hf: 4 clock latency<br>Others: Reserved |

#### **DSMC\_WAIT\_TIME0**

Address: Operational Base(0xFF8B0000) + offset (0x1018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------|
| 31:11      | RO          | 0x0000000          | reserved                                                                                             |
| 10:0       | RW          | 0x7ff              | rdstall_wait_time<br>This bit filed is used to configure the max wait time of the read stall status. |

#### **DSMC\_BDRTCRO**

Address: Operational Base(0xFF8B0000) + offset (0x1020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                                                                                                                                                   |
| 5          | RW          | 0x0                | rd_bdr_xfer_en<br>Enable Cross Row Address Data Read Transfer.<br>1'b0: Disable<br>1'b1: Enable                                                                                            |
| 4          | RW          | 0x0                | wr_bdr_xfer_en<br>Enable Cross Row Address Data Write Transfer.<br>1'b0: Disable<br>1'b1: Enable                                                                                           |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                                   |
| 2:0        | RW          | 0x2                | col_bit_num<br>The valid column address bit, also the cycle numbers in the port.<br>3'h0: 6bit<br>3'h1: 7bit<br>3'h2: 8bit<br>3'h3: 9bit<br>3'h4: 10bit<br>3'h5: 11bit<br>Others: Reserved |

#### **DSMC\_MRGTTCRO**

Address: Operational Base(0xFF8B0000) + offset (0x1024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                              |
|------------|-------------|--------------------|-------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                        |
| 1          | RW          | 0x0                | read_merge_en<br>1'b0: Disable<br>1'b1: Enable  |
| 0          | RW          | 0x0                | write_merge_en<br>1'b0: Disable<br>1'b1: Enable |

#### **DSMC\_WRAP2INCR0**

Address: Operational Base(0xFF8B0000) + offset (0x1028)

| <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>wrap2incr_en</p> <p>This bit is used to enable the function of changing WRAP transfer to INCR transfer. This register is only configured in local bus application.</p> <p>1'b0: Disable<br/>1'b1: Enable</p> |

**DSMC RDS DLL0 CTL0**

Address: Operational Base(0xFF8B0000) + offset (0x1030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x1                | <p>rds_0_clk_smp_sel</p> <p>DQ[7:0] Sampling Clock Selection</p> <p>1'b0: Without DLL<br/>1'b1: With DLL</p> |
| 30:8       | RO          | 0x0000000          | reserved                                                                                                     |
| 7:0        | RW          | 0x10               | <p>rds_0_clk_delay_num</p> <p>RDS Clock 0 Delay Line Cell Number</p>                                         |

**DSMC RDS DLL1 CTL0**

Address: Operational Base(0xFF8B0000) + offset (0x1034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x1                | <p>rds_1_clk_smp_sel</p> <p>DQ[7:0] Sampling Clock Selection</p> <p>1'b0: Without DLL<br/>1'b1: With DLL</p> |
| 30:8       | RO          | 0x0000000          | reserved                                                                                                     |
| 7:0        | RW          | 0x10               | <p>rds_1_clk_delay_num</p> <p>RDS Clock 0 Delay Line Cell Number</p>                                         |

**DSMC SLV RGN DIV0**

Address: Operational Base(0xFF8B0000) + offset (0x1040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                                                                                                                                                               |
| 1:0        | RW          | 0x2                | <p>slv_rgn_div</p> <p>This register is only valid in local bus application.</p> <p>This bit filed indicate the region division of the slave memory.</p> <p>2'b00: 1<br/>2'b01: 2<br/>2'b10: 4<br/>Others: Reserved</p> |

**DSMC RGNO ATTR0**

Address: Operational Base(0xFF8B0000) + offset (0x1050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9       | RO          | 0x0000000          | reserved                                                                                                                                                                       |
| 8          | RW          | 0x0                | <p>rgn0_addr_width</p> <p>This bit is used to indicate the address width of the CA phase when access region 0.</p> <p>1'b0: 32 bits<br/>1'b1: 16 bits</p>                      |
| 7          | RW          | 0x0                | <p>rgn0_dum_clk_num</p> <p>Write transfer dummy clock cycle number. This bit field is valid only whe write dummy clock is enabled.</p> <p>1'b0: 1 cycle<br/>1'b1: 2 cycles</p> |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                 |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6   | RW   | 0x0         | rgn0_dum_clk_en<br>DSMC will output additional dummy clock cycle in write transaction when access region0.<br>1'b0: Disable<br>1'b1: Enable                                                                                 |
| 5   | RW   | 0x0         | rgn0_be_ctrlled<br>The cs0 accessing region0 will be controlled by other cs1/cs2/cs3 when this bit is enabled.<br>1'b0: Disabled<br>1'b1: Enable                                                                            |
| 4   | RW   | 0x0         | rgn0_ctrl<br>The cs0 accessing region0 will control other cs1/cs2/cs3 when this bit is enabled.<br>1'b0: Disabled<br>1'b1: Enable                                                                                           |
| 3:2 | RO   | 0x0         | reserved                                                                                                                                                                                                                    |
| 1:0 | RW   | 0x0         | rgn0_attr<br>This register is only valid in local bus application.<br>The attribution of the region0 could be configured in this bit filed.<br>2'b00: Register<br>2'b01: DPRA<br>2'b10: No-Merge FIFO<br>2'b11: Merged FIFO |

**DSMC RGN1 ATTR0**

Address: Operational Base(0xFF8B0000) + offset (0x1054)

| Bit  | Attr | Reset Value | Description                                                                                                                                                    |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9 | RO   | 0x0000000   | reserved                                                                                                                                                       |
| 8    | RW   | 0x0         | rgn1_addr_width<br>This bit is used to indicate the address width of the CA phase when access region 1.<br>1'b0: 32 bits<br>1'b1: 16 bits                      |
| 7    | RW   | 0x0         | rgn1_dum_clk_num<br>Write transfer dummy clock cycle number. This bit field is valid only whe write dummy clock is enabled.<br>1'b0: 1 cycle<br>1'b1: 2 cycles |
| 6    | RW   | 0x0         | rgn1_dum_clk_en<br>DSMC will output additional dummy clock cycle in write transaction when access region1.<br>1'b0: Disable<br>1'b1: Enable                    |
| 5    | RW   | 0x0         | rgn1_be_ctrlled<br>The cs0 accessing region1 will be controlled by other cs1/cs2/cs3 when this bit is enabled.<br>1'b0: Disabled<br>1'b1: Enable               |
| 4    | RW   | 0x0         | rgn1_ctrl<br>The cs0 accessing region1 will control other cs1/cs2/cs3 when this bit is enabled.<br>1'b0: Disabled<br>1'b1: Enable                              |
| 3:2  | RO   | 0x0         | reserved                                                                                                                                                       |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                 |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0 | RW   | 0x0         | <p>rgn1_attr<br/>This register is only valid in local bus application.<br/>The attribution of the region1 could be configured in this bit filed.</p> <p>2'b00: Register<br/>2'b01: DPRA<br/>2'b10: No-Merge FIFO<br/>2'b11: Merged FIFO</p> |

**DSMC RGN2 ATTR0**

Address: Operational Base(0xFF8B0000) + offset (0x1058)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                 |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9 | RO   | 0x000000    | reserved                                                                                                                                                                                                                                    |
| 8    | RW   | 0x0         | <p>rgn2_addr_width<br/>This bit is used to indicate the address width of the CA phase when access region 2.</p> <p>1'b0: 32 bits<br/>1'b1: 16 bits</p>                                                                                      |
| 7    | RW   | 0x0         | <p>rgn2_dum_clk_num<br/>Write transfer dummy clock cycle number. This bit field is valid only when write dummy clock is enabled.</p> <p>1'b0: 1 cycle<br/>1'b1: 2 cycles</p>                                                                |
| 6    | RW   | 0x0         | <p>rgn2_wr_dum_clk_en<br/>DSMC will output additional dummy clock cycle in write transaction when access region2.</p> <p>1'b0: Disable<br/>1'b1: Enable</p>                                                                                 |
| 5    | RW   | 0x0         | <p>rgn2_be_ctrl_en<br/>The cs0 accessing region2 will be controlled by other cs1/cs2/cs3 when this bit is enabled.</p> <p>1'b0: Disabled<br/>1'b1: Enable</p>                                                                               |
| 4    | RW   | 0x0         | <p>rgn2_ctrl<br/>The cs0 accessing region2 will control other cs1/cs2/cs3 when this bit is enabled.</p> <p>1'b0: Disabled<br/>1'b1: Enable</p>                                                                                              |
| 3:2  | RO   | 0x0         | reserved                                                                                                                                                                                                                                    |
| 1:0  | RW   | 0x0         | <p>rgn2_attr<br/>This register is only valid in local bus application.<br/>The attribution of the region1 could be configured in this bit filed.</p> <p>2'b00: Register<br/>2'b01: DPRA<br/>2'b10: No-Merge FIFO<br/>2'b11: Merged FIFO</p> |

**DSMC RGN3 ATTR0**

Address: Operational Base(0xFF8B0000) + offset (0x105C)

| Bit  | Attr | Reset Value | Description                                                                                                                                            |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9 | RO   | 0x000000    | reserved                                                                                                                                               |
| 8    | RW   | 0x0         | <p>rgn3_addr_width<br/>This bit is used to indicate the address width of the CA phase when access region 3.</p> <p>1'b0: 32 bits<br/>1'b1: 16 bits</p> |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                 |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | RW   | 0x0         | rgn3_dum_clk_num<br>Write transfer dummy clock cycle number. This bit field is valid only when write dummy clock is enabled.<br>1'b0: 1 cycle<br>1'b1: 2 cycles                                                             |
| 6   | RW   | 0x0         | rng3_dum_clk_en<br>DSMC will output additional dummy clock cycle in write transaction when access region3.<br>1'b0: Disable<br>1'b1: Enable                                                                                 |
| 5   | RW   | 0x0         | rgn3_be_ctrlled<br>The cs0 accessing region3 will be controlled by other cs1/cs2/cs3 when this bit is enabled.<br>1'b0: Disabled<br>1'b1: Enable                                                                            |
| 4   | RW   | 0x0         | rgn3_ctrl<br>The cs0 accessing region3 will control other cs1/cs2/cs3 when this bit is enabled.<br>1'b0: Disabled<br>1'b1: Enable                                                                                           |
| 3:2 | RO   | 0x0         | reserved                                                                                                                                                                                                                    |
| 1:0 | RW   | 0x0         | rgn3_attr<br>This register is only valid in local bus application.<br>The attribution of the region3 could be configured in this bit filed.<br>2'b00: Register<br>2'b01: DPRA<br>2'b10: No-Merge FIFO<br>2'b11: Merged FIFO |

## 35.5 Interface Description

Table 35-3 DSMC interface description

| Module Pin | Direction | Pin Name | IOmux Setting                            |
|------------|-----------|----------|------------------------------------------|
| CLKP       | O         | GPIO1_A0 | GPIO1_IOC_GPIO1A_IOMUX_SEL_0[3:0]=4'h2   |
| CLKN       | O         | GPIO1_A1 | GPIO1_IOC_GPIO1A_IOMUX_SEL_0[7:4]=4'h2   |
| CS0        | O         | GPIO1_B6 | GPIO1_IOC_GPIO1B_IOMUX_SEL_1[11:8]=4'h2  |
| CS1        | O         | GPIO1_B1 | GPIO1_IOC_GPIO1B_IOMUX_SEL_0[7:4]=4'h2   |
| CS2        | O         | GPIO1_D2 | GPIO1_IOC_GPIO1D_IOMUX_SEL_0[11:8]=4'h2  |
| CS3        | O         | GPIO1_D3 | GPIO1_IOC_GPIO1D_IOMUX_SEL_0[15:12]=4'h2 |
| RESETN     | O         | GPIO1_C0 | GPIO1_IOC_GPIO1C_IOMUX_SEL_0[3:0]=4'h2   |
| DQS0       | I/O       | GPIO1_A2 | GPIO1_IOC_GPIO1A_IOMUX_SEL_0[11:8]=4'h2  |
| DQS1       | I/O       | GPIO1_D1 | GPIO1_IOC_GPIO1D_IOMUX_SEL_0[7:4]=4'h2   |
| DQ0        | I/O       | GPIO1_A3 | GPIO1_IOC_GPIO1A_IOMUX_SEL_0[15:12]=4'h2 |
| DQ1        | I/O       | GPIO1_A4 | GPIO1_IOC_GPIO1A_IOMUX_SEL_1[3:0]=4'h2   |
| DQ2        | I/O       | GPIO1_A5 | GPIO1_IOC_GPIO1A_IOMUX_SEL_1[7:4]=4'h2   |
| DQ3        | I/O       | GPIO1_A6 | GPIO1_IOC_GPIO1A_IOMUX_SEL_1[11:8]=4'h2  |
| DQ4        | I/O       | GPIO1_A7 | GPIO1_IOC_GPIO1A_IOMUX_SEL_1[15:12]=4'h2 |
| DQ5        | I/O       | GPIO1_B0 | GPIO1_IOC_GPIO1B_IOMUX_SEL_0[3:0]=4'h2   |
| DQ6        | I/O       | GPIO1_B4 | GPIO1_IOC_GPIO1B_IOMUX_SEL_1[3:0]=4'h2   |
| DQ7        | I/O       | GPIO1_B5 | GPIO1_IOC_GPIO1B_IOMUX_SEL_1[7:4]=4'h2   |
| DQ8        | I/O       | GPIO1_C1 | GPIO1_IOC_GPIO1C_IOMUX_SEL_0[7:4]=4'h2   |
| DQ9        | I/O       | GPIO1_C2 | GPIO1_IOC_GPIO1C_IOMUX_SEL_0[11:8]=4'h2  |
| DQ10       | I/O       | GPIO1_C3 | GPIO1_IOC_GPIO1C_IOMUX_SEL_0[15:12]=4'h2 |
| DQ11       | I/O       | GPIO1_C4 | GPIO1_IOC_GPIO1C_IOMUX_SEL_1[3:0]=4'h2   |

| Module Pin | Direction | Pin Name | IOMUX Setting                            |
|------------|-----------|----------|------------------------------------------|
| DQ12       | I/O       | GPIO1_C5 | GPIO1_IOC_GPIO1C_IOMUX_SEL_1[7:4]=4'h2   |
| DQ13       | I/O       | GPIO1_C6 | GPIO1_IOC_GPIO1C_IOMUX_SEL_1[11:8]=4'h2  |
| DQ14       | I/O       | GPIO1_C7 | GPIO1_IOC_GPIO1C_IOMUX_SEL_1[15:12]=4'h2 |
| DQ15       | I/O       | GPIO1_D0 | GPIO1_IOC_GPIO1D_IOMUX_SEL_0[3:0]=4'h2   |
| INT0       | I         | GPIO1_A1 | GPIO1_IOC_GPIO1A_IOMUX_SEL_0[7:4]=4'h4   |
| INT1       | I         | GPIO1_C0 | GPIO1_IOC_GPIO1C_IOMUX_SEL_0[3:0]=4'h4   |
| INT2       | I         | GPIO1_B2 | GPIO1_IOC_GPIO1B_IOMUX_SEL_0[11:8]=4'h2  |
| INT3       | I         | GPIO1_B3 | GPIO1_IOC_GPIO1B_IOMUX_SEL_0[15:12]=4'h2 |
| RDYN       | I         | GPIO1_B7 | GPIO1_IOC_GPIO1B_IOMUX_SEL_1[15:12]=4'h2 |

Notes: I=input, O=output, I/O=input/output, bidirectional.

## 35.6 Application Notes

### 35.6.1 Typical Program Flow for Hyper Device

1. Configure the DSMC\_DEV\_SIZE according to the size of device applied.
2. Configure the DSMC\_MRGTCSR to support merge operation, and the DSMC\_BDRTRCSR to support crossing the boundary.
3. Configure the DSMC\_MTR to adjust the transfer timing.
4. Configure DSMC\_MCR to access the slave configure register.
5. Set the slave configuration to be consistent with the host, such as write and read latency.
6. Configure DSMC\_MCR to access the slave memory space.

### 35.6.2 Typical Program Flow for LocalBus Device

1. Configure the DSMC\_DEV\_SIZE according to the size of device applied.
2. Configure the DSMC\_MRGTCSR to support merge operation, and the DSMC\_BDRTRCSR to support crossing the boundary.
3. Configure the DSMC\_MTR to adjust the transfer timing.
4. Configure the DSMC\_VDMCx to LocalBus.
5. Enable the DSMC\_WRAP2INCR function if the slave required.
6. Configure DSMC\_MCR to access the slave configure register.
7. Keep the configuration parameter of the slave is the same as the master.
8. Configure DSMC\_MCR to access the slave memory space.

### 35.6.3 Chip Select selection

This section describes how to select Chip Select. This controller can't assert two Chip Select at the same time except for the LocalBus write.

When the device size is configured, the 2 address bits higher than device size are used as chip select signals.

### 35.6.4 Configurable CS# Low Time

This section describes configurable CS# low time. HyperRAM has a regulation for CS# low time ( $t_{CSM}$ ). To meet CS# low time, a read/write transaction can be regulated by setting MCRx.MAXLEN bit. By MCRx.MAXLEN bit, one transaction is split multi transactions.

**DSMC\_MCR\_maxen = 0**



**DSMC\_MCR\_maxen = 1**

**DSMC\_MCR maxlen = 32**



Fig. 35-5 Separated Transaction

### 35.6.5 Data Map

The data mapping relationship between memory and DSMC interface is shown as below.



Fig. 35-6 Data mapping relationship between memory and DSMC interface

### 35.6.6 Merge Operation

The merge operation function supports Hyper device and LocalBus device, and it is configured by the DSMC\_MRGTCSR register.

- Merge operation removes address output period and latency cycles for subsequent transaction.
- When DSMC Memory Controller IP accepts subsequent read transaction with continuous address, it is merged to one CS# period on DSMC memory interface.

### 35.6.7 Timing Adjustment

This section describes the DSMC timing adjustment. DSMC core has timing adjustment circuit and timing adjustment is controlled by DSMC\_MTRn. RCSHI, RCSS, and RCHS in DSMC\_MTRn are used for the read timing adjustment, and WCSHI, WCSS, and WCSH in DSMC\_MTRn are used for the write timing adjustment.



Fig. 35-7 Timing Adjustment

Rockchip Confidential

## Chapter 36 Slave Double Date Rate Serial Memory Controller (SLAVE DSMC)

### 36.1 Overview

The Slave DSMC is the slave controller of Rockchip LocalBus, and it works in combination with DSMC. There are two regions of register and FIFO in the SLAVE DSMC to achieve low latency and high bandwidth.

The main feature is shown below

- Support the double data rate interface
- Support 8-wire serial transfer mode
- Support 2 interrupts of host2slave and slave2host
- Support 2 region attributions of register and FIFO
- Support wait state in FIFO read mode
- Support back pressure in FIFO write mode
- Support configurable serial address width: 16 bits or 32 bits in different region
- Support configurable internal bus accessing address

### 36.2 Block Diagram

SLAVE DSMC is comprised of:

- AHB Interface

The APB Interface implements the AHB slave operation. Its data bus width is 32 bits.

- AXI Interface

The AXI Interface is a XIP interface to access internal device. Its data bus width is 64 bits.

- LocalBus Control Interface

The interface to transmit data with MASTER DSMC.

- Bus Control

The core module to access internal memory in FIFO region.

- Common Register Bank

The DSMC transfer configuration register bank.

- Application & Control Status Register Bank

The SLAVE DSMC control and status register banks, and they are shadow registers.



Fig. 36-1 SLAVE DSMC Block Diagram

### 36.3 Function Description

The SLAVE DSMC is responsible for transmitting data from the Local Bus to the Register Memory and resolving read/write transmission from the LocalBus to the internal memory space of the slave chip.

The MASTER accesses the CMN\_REG and LBC\_REG of the LBC\_SLAVE through the LocalBus interface, and the slave accesses the APP\_REG of the LBC\_SLAVE through the AHB interface. The LBC\_REG and APP\_REG are shadow of each other and can be read but not configured in each other's clock domain.

For data read and write access on the host, the LBC\_SLAVE converts the LocalBus transmission to the data transfer of the AXI interface pair on the slave internal memory.

Before the SLAVE DSMC access, the bus must be switch from the flexible bus to the SLAVE DSMC.

#### 36.3.1 DSMC Interface

This section describes physical interface of the SLAVE DSMC module.

##### 36.3.1.1 Read

DSMC asserts cs, dsmc\_clk, and dsmc\_dq. Then, the SLAVE DSMC receives 3 words command/address, and outputs data by the timing of dqs\_clk. The read data is edge aligned with dqs\_clk and the read latency is configurable.



Fig. 36-2 LocalBus Read Waveform

##### 36.3.1.2 Write

This section describes the write operation of LocalBus. The DSMC asserts cs, dsmc\_clk, and dsmc\_dq. Then, the Slave DSMC receives 3 words command/address, and then the data information. The write data is center aligned with dsmc\_clk and the data latency is configurable.



Fig. 36-3 LocalBus Write Waveform

##### 36.3.1.3 Byte Mask

This SLAVE DSMC could also support byte write access as same as the MASTER

##### 36.3.1.4 C/A Encoder

The C/A Encoder could be referred in the corresponding part of the MASTER DSMC.

#### 36.3.2 FIFO Access

The FIFO region could be empty or full due to the bandwidth difference, and the wait state and back pressure is introduced to improve bandwidth.

### 36.3.2.1 Read Wait State

In the read transaction, when the FIFO is empty and could not provide data to the DSMC interface, the slave could enter the wait state, in which slave stop to send DQS clock, and latch the output DQ data. When the FIFO is recovered, the slave could continue sending the DQS and DQ, which could save bandwidth comparing to restart another burst.



Fig. 36-4 LocalBus Read Waveform

### 36.3.2.2 Write Back Pressure

In the write transaction, when the FIFO is full and could not receive data from the DSMC interface, the asynchronous signal **DSMC\_RDYN** would be asserted. When the DSMC received, it would not send DQ and **DSMC\_CLK** until the **DSMC\_RDYN** is not asserted, which means there are enough space in the slave FIFO to accept data.



Fig. 36-5 LocalBus Read Waveform

## 36.4 Register Description

### 36.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

### 36.4.2 Registers Summary

| Name                 | Offset | Size | Reset Value | Description                     |
|----------------------|--------|------|-------------|---------------------------------|
| SLAVE DSMC APP CON0  | 0x0000 | W    | 0x00000000  | Application Control Register 0  |
| SLAVE DSMC APP CON1  | 0x0004 | W    | 0x00000000  | Application Control Register 1  |
| SLAVE DSMC APP CON2  | 0x0008 | W    | 0x00000000  | Application Control Register 2  |
| SLAVE DSMC APP CON3  | 0x000C | W    | 0x00000000  | Application Control Register 3  |
| SLAVE DSMC APP CON4  | 0x0010 | W    | 0x00000000  | Application Control Register 4  |
| SLAVE DSMC APP CON5  | 0x0014 | W    | 0x00000000  | Application Control Register 5  |
| SLAVE DSMC APP CON6  | 0x0018 | W    | 0x00000000  | Application Control Register 6  |
| SLAVE DSMC APP CON7  | 0x001C | W    | 0x00000000  | Application Control Register 7  |
| SLAVE DSMC APP CON8  | 0x0020 | W    | 0x00000000  | Application Control Register 8  |
| SLAVE DSMC APP CON9  | 0x0024 | W    | 0x00000000  | Application Control Register 9  |
| SLAVE DSMC APP CON10 | 0x0028 | W    | 0x00000000  | Application Control Register 10 |
| SLAVE DSMC APP CON11 | 0x002C | W    | 0x00000000  | Application Control Register 11 |
| SLAVE DSMC APP CON12 | 0x0030 | W    | 0x00000000  | Application Control Register 12 |

| Name                              | Offset | Size | Reset Value | Description                                                       |
|-----------------------------------|--------|------|-------------|-------------------------------------------------------------------|
| SLAVE DSMC APP CON1_3             | 0x0034 | W    | 0x00000000  | Application Control Register 13                                   |
| SLAVE DSMC APP CON1_4             | 0x0038 | W    | 0x00000000  | Application Control Register 14                                   |
| SLAVE DSMC APP CON1_5             | 0x003C | W    | 0x00000000  | Application Control Register 15                                   |
| SLAVE DSMC APP H2S INT STA        | 0x0080 | W    | 0x00000000  | Application Host to Slave Interrupt Status                        |
| SLAVE DSMC APP H2S INT STA EN     | 0x0084 | W    | 0x00000000  | Application Host to Slave Interrupt Status Enable                 |
| SLAVE DSMC APP H2S INT STA SIG EN | 0x0088 | W    | 0x00000000  | Application Host to Slave Interrupt Status Signal Enable          |
| SLAVE DSMC LBC CON0               | 0x0100 | W    | 0x00000000  | Local Bus Control Register 0                                      |
| SLAVE DSMC LBC CON1               | 0x0104 | W    | 0x00000000  | Local Bus Control Register 1                                      |
| SLAVE DSMC LBC CON2               | 0x0108 | W    | 0x00000000  | Local Bus Control Register 2                                      |
| SLAVE DSMC LBC CON3               | 0x010C | W    | 0x00000000  | Local Bus Control Register 3                                      |
| SLAVE DSMC LBC CON4               | 0x0110 | W    | 0x00000000  | Local Bus Control Register 0                                      |
| SLAVE DSMC LBC CON5               | 0x0114 | W    | 0x00000000  | Local Bus Control Register 1                                      |
| SLAVE DSMC LBC CON6               | 0x0118 | W    | 0x00000000  | Local Bus Control Register 2                                      |
| SLAVE DSMC LBC CON7               | 0x011C | W    | 0x00000000  | Local Bus Control Register 3                                      |
| SLAVE DSMC LBC CON8               | 0x0120 | W    | 0x00000000  | Local Bus Control Register 8                                      |
| SLAVE DSMC LBC CON9               | 0x0124 | W    | 0x00000000  | Local Bus Control Register 9                                      |
| SLAVE DSMC LBC CON10              | 0x0128 | W    | 0x00000000  | Local Bus Control Register 10                                     |
| SLAVE DSMC LBC CON11              | 0x012C | W    | 0x00000000  | Local Bus Control Register 11                                     |
| SLAVE DSMC LBC CON12              | 0x0130 | W    | 0x00000000  | Local Bus Control Register 12                                     |
| SLAVE DSMC LBC CON13              | 0x0134 | W    | 0x00000000  | Local Bus Control Register 13                                     |
| SLAVE DSMC LBC CON14              | 0x0138 | W    | 0x00000000  | Local Bus Control Register 14                                     |
| SLAVE DSMC LBC CON15              | 0x013C | W    | 0x00000000  | Local Bus Control Register 15                                     |
| SLAVE DSMC LBC S2H INT STA        | 0x0180 | W    | 0x00000000  | Local Bus Controller Slave to Host Interrupt Status               |
| SLAVE DSMC LBC S2H INT STA EN     | 0x0184 | W    | 0x00000000  | Local Bus Controller Slave to Host Interrupt Status Enable        |
| SLAVE DSMC LBC S2H INT STA SIG EN | 0x0188 | W    | 0x00000000  | Local Bus Controller Slave to Host Interrupt Status Signal Enable |
| SLAVE DSMC AXI WR A DDR BASE      | 0x0800 | W    | 0x00000000  | AXI Write Base Address                                            |
| SLAVE DSMC AXI RD A DDR BASE      | 0x0804 | W    | 0x00000000  | AXI Read Base Address                                             |
| SLAVE DSMC DBG STA0               | 0x0900 | W    | 0x00000000  | Debug Status 0                                                    |
| SLAVE DSMC DBG STA1               | 0x0904 | W    | 0x00000000  | Debug Status 1                                                    |
| SLAVE DSMC DBG STA2               | 0x0908 | W    | 0x00000000  | Debug Status 2                                                    |
| SLAVE DSMC VER                    | 0x0A00 | W    | 0x00000100  | The version code                                                  |

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

**36.4.3 Detail Registers Description****SLAVE DSMC APP CON0**

Address: Operational Base(0xFF880000) + offset (0x0000)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | app_con0<br>Write access will trigger interrupt from slave to host, the interrupt status is lbc_s2h_int_sta[0].<br>The corresponding shadow register could be read through DSMC interface. |

**SLAVE DSMC APP CON1**

Address: Operational Base(0xFF880000) + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | app_con1<br>Write access will trigger interrupt from slave to host, the interrupt status is lbc_s2h_int_sta[1].<br>The corresponding shadow register could be read through DSMC interface. |

**SLAVE DSMC APP CON2**

Address: Operational Base(0xFF880000) + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | app_con2<br>Write access will trigger interrupt from slave to host, the interrupt status is lbc_s2h_int_sta[2].<br>The corresponding shadow register could be read through DSMC interface. |

**SLAVE DSMC APP CON3**

Address: Operational Base(0xFF880000) + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | app_con3<br>Write access will trigger interrupt from slave to host, the interrupt status is lbc_s2h_int_sta[3].<br>The corresponding shadow register could be read through DSMC interface. |

**SLAVE DSMC APP CON4**

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | app_con4<br>Write access will trigger interrupt from slave to host, the interrupt status is lbc_s2h_int_sta[4].<br>The corresponding shadow register could be read through DSMC interface. |

**SLAVE DSMC APP CON5**

Address: Operational Base(0xFF880000) + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | app_con5<br>Write access will trigger interrupt from slave to host, the interrupt status is lbc_s2h_int_sta[5].<br>The corresponding shadow register could be read through DSMC interface. |

**SLAVE DSMC APP CON6**

Address: Operational Base(0xFF880000) + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | app_con6<br>Write access will trigger interrupt from slave to host, the interrupt status is lbc_s2h_int_sta[6].<br>The corresponding shadow register could be read through DSMC interface. |

**SLAVE DSMC APP CON7**

Address: Operational Base(0xFF880000) + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | app_con7<br>Write access will trigger interrupt from slave to host, the interrupt status is lbc_s2h_int_sta[7].<br>The corresponding shadow register could be read through DSMC interface. |

**SLAVE DSMC APP CON8**

Address: Operational Base(0xFF880000) + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | app_con8<br>Write access will trigger interrupt from slave to host, the interrupt status is lbc_s2h_int_sta[8].<br>The corresponding shadow register could be read through DSMC interface. |

**SLAVE DSMC APP CON9**

Address: Operational Base(0xFF880000) + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | app_con9<br>Write access will trigger interrupt from slave to host, the interrupt status is lbc_s2h_int_sta[9].<br>The corresponding shadow register could be read through DSMC interface. |

**SLAVE DSMC APP CON10**

Address: Operational Base(0xFF880000) + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | app_con10<br>Write access will trigger interrupt from slave to host, the interrupt status is lbc_s2h_int_sta[10].<br>The corresponding shadow register could be read through DSMC interface. |

**SLAVE DSMC APP CON11**

Address: Operational Base(0xFF880000) + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | app_con11<br>Write access will trigger interrupt from slave to host, the interrupt status is lbc_s2h_int_sta[11].<br>The corresponding shadow register could be read through DSMC interface. |

**SLAVE DSMC APP CON12**

Address: Operational Base(0xFF880000) + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | app_con12<br>Write access will trigger interrupt from slave to host, the interrupt status is lbc_s2h_int_sta[12].<br>The corresponding shadow register could be read through DSMC interface. |

**SLAVE DSMC APP CON13**

Address: Operational Base(0xFF880000) + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | app_con13<br>Write access will trigger interrupt from slave to host, the interrupt status is lbc_s2h_int_sta[13].<br>The corresponding shadow register could be read through DSMC interface. |

**SLAVE DSMC APP CON14**

Address: Operational Base(0xFF880000) + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | app_con14<br>Write access will trigger interrupt from slave to host, the interrupt status is lbc_s2h_int_sta[14].<br>The corresponding shadow register could be read through DSMC interface. |

**SLAVE DSMC APP CON15**

Address: Operational Base(0xFF880000) + offset (0x003C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | app_con15<br>Write access will trigger interrupt from slave to host, the interrupt status is lbc_s2h_int_sta[15].<br>The corresponding shadow register could be read through DSMC interface. |

**SLAVE DSMC APP H2S INT STA**

Address: Operational Base(0xFF880000) + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                              |
| 15:0       | W1 C        | 0x0000             | app_h2s_int_sta<br>The interrupt status from host to slave. The interrupt is originating from the writing of LBC_CON. |

**SLAVE DSMC APP H2S INT STA EN**

Address: Operational Base(0xFF880000) + offset (0x0084)

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

**SLAVE DSMC APP H2S INT STA SIG EN**

Address: Operational Base(0xFF880000) + offset (0x0088)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:0       | RW          | 0x0000             | app_h2s_int_sta_sig_en<br>The interrupt signal out registers of 16 h2s interrupt status.<br>1'b0: disable<br>1'b1: enable          |

**SLAVE\_DSMC\_LBC\_CON0**

Address: Operational Base(0xFF880000) + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | lbc_con0<br>Write access from DSMC will trigger interrupt from host to slave,<br>the interrupt status is app_h2s_int_sta[0].<br>The corresponding shadow register could be read through Slave<br>AHB interface. |

**SLAVE\_DSMC\_LBC\_CON1**

Address: Operational Base(0xFF880000) + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | lbc_con1<br>Write access from DSMC will trigger interrupt from host to slave,<br>the interrupt status is app_h2s_int_sta[1].<br>The corresponding shadow register could be read through Slave<br>AHB interface. |

**SLAVE\_DSMC\_LBC\_CON2**

Address: Operational Base(0xFF880000) + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | lbc_con2<br>Write access from DSMC will trigger interrupt from host to slave,<br>the interrupt status is app_h2s_int_sta[2].<br>The corresponding shadow register could be read through Slave<br>AHB interface. |

**SLAVE\_DSMC\_LBC\_CON3**

Address: Operational Base(0xFF880000) + offset (0x010C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | lbc_con3<br>Write access from DSMC will trigger interrupt from host to slave,<br>the interrupt status is app_h2s_int_sta[3].<br>The corresponding shadow register could be read through Slave<br>AHB interface. |

**SLAVE\_DSMC\_LBC\_CON4**

Address: Operational Base(0xFF880000) + offset (0x0110)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | lbc_con4<br>Write access from DSMC will trigger interrupt from host to slave,<br>the interrupt status is app_h2s_int_sta[4].<br>The corresponding shadow register could be read through Slave<br>AHB interface. |

**SLAVE\_DSMC\_LBC\_CON5**

Address: Operational Base(0xFF880000) + offset (0x0114)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | lbc_con5<br>Write access from DSMC will trigger interrupt from host to slave,<br>the interrupt status is app_h2s_int_sta[5].<br>The corresponding shadow register could be read through Slave<br>AHB interface. |

**SLAVE DSMC LBC CON6**

Address: Operational Base(0xFF880000) + offset (0x0118)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | lbc_con6<br>Write access from DSMC will trigger interrupt from host to slave,<br>the interrupt status is app_h2s_int_sta[6].<br>The corresponding shadow register could be read through Slave<br>AHB interface. |

**SLAVE DSMC LBC CON7**

Address: Operational Base(0xFF880000) + offset (0x011C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | lbc_con7<br>Write access from DSMC will trigger interrupt from host to slave,<br>the interrupt status is app_h2s_int_sta[7].<br>The corresponding shadow register could be read through Slave<br>AHB interface. |

**SLAVE DSMC LBC CON8**

Address: Operational Base(0xFF880000) + offset (0x0120)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | lbc_con8<br>Write access from DSMC will trigger interrupt from host to slave,<br>the interrupt status is app_h2s_int_sta[8].<br>The corresponding shadow register could be read through Slave<br>AHB interface. |

**SLAVE DSMC LBC CON9**

Address: Operational Base(0xFF880000) + offset (0x0124)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | lbc_con9<br>Write access from DSMC will trigger interrupt from host to slave,<br>the interrupt status is app_h2s_int_sta[9].<br>The corresponding shadow register could be read through Slave<br>AHB interface. |

**SLAVE DSMC LBC CON10**

Address: Operational Base(0xFF880000) + offset (0x0128)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | lbc_con10<br>Write access from DSMC will trigger interrupt from host to slave,<br>the interrupt status is app_h2s_int_sta[10].<br>The corresponding shadow register could be read through Slave<br>AHB interface. |

**SLAVE DSMC LBC CON11**

Address: Operational Base(0xFF880000) + offset (0x012C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | lbc_con11<br>Write access from DSMC will trigger interrupt from host to slave, the interrupt status is app_h2s_int_sta[11].<br>The corresponding shadow register could be read through Slave AHB interface. |

**SLAVE DSMC LBC CON12**

Address: Operational Base(0xFF880000) + offset (0x0130)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | lbc_con12<br>Write access from DSMC will trigger interrupt from host to slave, the interrupt status is app_h2s_int_sta[12].<br>The corresponding shadow register could be read through Slave AHB interface. |

**SLAVE DSMC LBC CON13**

Address: Operational Base(0xFF880000) + offset (0x0134)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | lbc_con13<br>Write access from DSMC will trigger interrupt from host to slave, the interrupt status is app_h2s_int_sta[13].<br>The corresponding shadow register could be read through Slave AHB interface. |

**SLAVE DSMC LBC CON14**

Address: Operational Base(0xFF880000) + offset (0x0138)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | lbc_con14<br>Write access from DSMC will trigger interrupt from host to slave, the interrupt status is app_h2s_int_sta[14].<br>The corresponding shadow register could be read through Slave AHB interface. |

**SLAVE DSMC LBC CON15**

Address: Operational Base(0xFF880000) + offset (0x013C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | lbc_con15<br>Write access from DSMC will trigger interrupt from host to slave, the interrupt status is app_h2s_int_sta[15].<br>The corresponding shadow register could be read through Slave AHB interface. |

**SLAVE DSMC LBC S2H INT STA**

Address: Operational Base(0xFF880000) + offset (0x0180)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                              |
| 15:0       | W1 C        | 0x0000             | lbc_s2h_int_sta<br>The interrupt status from slave to host. The interrupt is originating from the writing of APP_CON. |

**SLAVE DSMC LBC S2H INT STA EN**

Address: Operational Base(0xFF880000) + 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:0       | RO          | 0x0000             | lbc_s2h_int_sta_en<br>The interrupt enable registers of 16 s2h interrupt status.<br>1'b0: disable<br>1'b1: enable                  |

**SLAVE DSMC LBC S2H INT STA SIG EN**

Address: Operational Base(0xFF800000) + 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:0       | RO          | 0x0000             | lbc_s2h_int_sta_sig_en<br>The interrupt signal out registers of 16 s2h interrupt status.<br>1'b0: disable<br>1'b1: enable          |

**SLAVE DSMC AXI WR ADDR BASE**

Address: Operational Base(0xFF800000) + offset (0x0800)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | axi_wr_addr_base<br>The access base address of write transaction in AXI interface. |

**SLAVE DSMC AXI RD ADDR BASE**

Address: Operational Base(0xFF800000) + offset (0x0804)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | axi_rd_addr_base<br>The access base address of read transaction in AXI interface. |

**SLAVE DSMC DBG STA 0**

Address: Operational Base(0xFF800000) + offset (0x0900)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                   |
| 3:2        | RO          | 0x0                | axi_wr_resp_error<br>AXI write transaction response error. |
| 1:0        | RO          | 0x0                | axi_rd_resp_error<br>AXI read transaction response error.  |

**SLAVE DSMC DBG STA 1**

Address: Operational Base(0xFF800000) + offset (0x0904)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                         |
| 3:0        | RO          | 0x0                | bus_current_state<br>The state machine of slave. |

**SLAVE DSMC DBG STA 2**

Address: Operational Base(0xFF800000) + offset (0x0908)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 31:22      | RO          | 0x000              | reserved                                                            |
| 21:16      | RO          | 0x00               | tx_dat_fifo_space2empty<br>The remained FIFO space of TX data FIFO. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------|
| 15         | RO          | 0x0                | reserved                                                               |
| 14:8       | RO          | 0x00               | rx_dat_fifo_space2empty<br>The remained FIFO space of RX data FIFO.    |
| 7:5        | RO          | 0x0                | reserved                                                               |
| 4:0        | RO          | 0x00               | rx_cmd_fifo_space2empty<br>The remained FIFO space of RX command FIFO. |

**SLAVE DSMC VER**

Address: Operational Base(0xFF880000) + offset (0x0A00)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:0       | RO          | 0x000000100        | version_code<br>The version code of the DSMC slave. |

## 36.5 Common Register Description

### 36.5.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

### 36.5.2 Registers Summary

| <b>Name</b>                  | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>            |
|------------------------------|---------------|-------------|--------------------|-------------------------------|
| SLAVE DSMC CMN CMN CON0      | 0x0000        | W           | 0x000000211        | Common Configuration0         |
| SLAVE DSMC CMN CMN CON1      | 0x0004        | W           | 0x00001818         | Common Configuration0         |
| SLAVE DSMC CMN CMN CON2      | 0x0008        | W           | 0x01010F0F         | Common Configuration0         |
| SLAVE DSMC CMN CMN CON3      | 0x000C        | W           | 0x000000010        | Common Configuration0         |
| SLAVE DSMC CMN RGN0 CMN CON0 | 0x0100        | W           | 0x000000221        | Region0 Common Configuration0 |
| SLAVE DSMC CMN RGN1 CMN CON0 | 0x0200        | W           | 0x000000221        | Region1 Common Configuration0 |
| SLAVE DSMC CMN RGN2 CMN CON0 | 0x0300        | W           | 0x000000221        | Region2 Common Configuration0 |
| SLAVE DSMC CMN RGN3 CMN CON0 | 0x0400        | W           | 0x000000221        | Region3 Common Configuration0 |
| SLAVE DSMC CMN DBG STATUS_0  | 0x0900        | W           | 0x000000000        | Debug Status Register0        |
| SLAVE DSMC CMN DBG STATUS_1  | 0x0904        | W           | 0x000000000        | Debug Status Register1        |
| SLAVE DSMC CMN DBG STATUS_2  | 0x0908        | W           | 0x000000000        | Debug Status Register2        |

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

### 36.5.3 Detail Registers Description

#### SLAVE DSMC CMN CMN CON0

Address: Operational Base + offset (0x0000)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                                                                                                                                                                |
| 11         | RW          | 0x0                | wr_data_cyc_extended<br>DSMC will output extended dummy clock cycle in write transaction when accessing CMN register.<br>1'b0: Normal write cycle mode<br>1'b1: Extend write cycle mode |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:8       | RW          | 0x2                | rd_latency_cyc<br>Read latency cycle when accessing CMN register.<br>3'h1: 1 clock latency<br>3'h2: 2 clock latency<br>Others: Reserved             |
| 7          | RO          | 0x0                | reserved                                                                                                                                            |
| 6:4        | RW          | 0x1                | wr_latency_cyc<br>Write latency cycle when accessing CMN register.<br>3'h1: 1 clock latency<br>3'h2: 2 clock latency<br>Others: Reserved            |
| 3:1        | RO          | 0x0                | reserved                                                                                                                                            |
| 0          | RW          | 0x1                | ca_cyc<br>This bit is used to indicate the address width of the CA phase when accessing CMN register.<br>1'b0: 16bit address<br>1'b1: 32bit address |

**SLAVE DSMC CMN CMN CON1**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                        |
| 28:24      | RW          | 0x00               | tx_almost_empty_watermark<br>Data TX FIFO almost full watermark. When the space of TX FIFO is less than this watermark, the almost_empty of RX FIFO will be asserted.                                                                                           |
| 23:21      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                        |
| 20:16      | RW          | 0x00               | tx_almost_full_watermark<br>Data TX FIFO almost full watermark. When the space of TX FIFO is less than this watermark, the almost_full of RX FIFO will be asserted. If the TX FIFO is almost full, slave will stop to send read transaction from AXI interface. |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                        |
| 13:8       | RW          | 0x18               | rx_almost_empty_watermark<br>Data RX FIFO almost full watermark. When the space of RX FIFO is less than this watermark, the almost_empty of RX FIFO will be asserted.                                                                                           |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                        |
| 5:0        | RW          | 0x18               | rx_almost_full_watermark<br>Data RX FIFO almost full watermark. When the RX FIFO is almost full, the DSMC master could not continue writing data in slave.                                                                                                      |

**SLAVE DSMC CMN CMN CON2**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                                                                                                          |
| 27:24      | RW          | 0x1                | rx_cmd_almost_empty_watermark<br>Data RX command FIFO almost full watermark. When the space of RX command FIFO is less than this watermark, the almost_empty of RX command FIFO will be asserted. |
| 23:20      | RO          | 0x0                | reserved                                                                                                                                                                                          |
| 19:16      | RW          | 0x1                | rx_cmd_almost_full_watermark<br>Data RX command FIFO almost full watermark. When the space of RX command FIFO is less than this watermark, the almost_full of RX command FIFO will be asserted.   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                          |
|------------|-------------|--------------------|---------------------------------------------|
| 15:12      | RO          | 0x0                | reserved                                    |
| 11:8       | RW          | 0xf                | axi_burst_rd_len<br>AXI read burst length.  |
| 7:4        | RO          | 0x0                | reserved                                    |
| 3:0        | RW          | 0xf                | axi_burst_wr_len<br>AXI write burst length. |

**SLAVE DSMC CMN CMN CON3**

Address: Operational Base + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                                                                          |
| 4          | RW          | 0x1                | rdyn_gen_ctrl<br>The capacity of RX FIFO will be made full use in enhanced mode.<br>1'b0: normal<br>1'b1: enhance |
| 3:1        | RO          | 0x0                | reserved                                                                                                          |
| 0          | RW          | 0x0                | data_width<br>The data width configuration of slave.<br>1'b0: X8<br>1'b1: X16                                     |

**SLAVE DSMC CMN RGN0 CMN CON0**

Address: Operational Base + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                                                                                                                                                           |
| 11         | RW          | 0x0                | wr_data_cyc_extended<br>DSMC will output extended dummy clock cycle in write transaction when accessing region0.<br>1'b0: Normal write cycle mode<br>1'b1: Extend write cycle mode |
| 10:8       | RW          | 0x2                | rd_latency_cyc<br>Read latency cycle when accessing region0.<br>3'h1: 1 clock latency<br>3'h2: 2 clock latency<br>Others: Reserved                                                 |
| 7          | RO          | 0x0                | reserved                                                                                                                                                                           |
| 6:4        | RW          | 0x2                | wr_latency_cyc<br>Write latency cycle when accessing region0.<br>3'h1: 1 clock latency<br>3'h2: 2 clock latency<br>Others: Reserved                                                |
| 3:1        | RO          | 0x0                | reserved                                                                                                                                                                           |
| 0          | RW          | 0x1                | ca_cyc<br>This bit is used to indicate the address width of the CA phase when accessing region0.<br>1'b0: 16bit address<br>1'b1: 32bit address                                     |

**SLAVE DSMC CMN RGN1 CMN CON0**

Address: Operational Base + offset (0x0200)

| <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         | RW          | 0x0                | wr_data_cyc_extended<br>DSMC will output extended dummy clock cycle in write transaction when accessing region1.<br>1'b0: Normal write cycle mode<br>1'b1: Extend write cycle mode |
| 10:8       | RW          | 0x2                | rd_latency_cyc<br>Read latency cycle when accessing region1.<br>3'h1: 1 clock latency<br>3'h2: 2 clock latency<br>Others: Reserved                                                 |
| 7          | RO          | 0x0                | reserved                                                                                                                                                                           |
| 6:4        | RW          | 0x2                | wr_latency_cyc<br>Write latency cycle when accessing region1.<br>3'h1: 1 clock latency<br>3'h2: 2 clock latency<br>Others: Reserved                                                |
| 3:1        | RO          | 0x0                | reserved                                                                                                                                                                           |
| 0          | RW          | 0x1                | ca_cyc<br>This bit is used to indicate the address width of the CA phase when accessing region1.<br>1'b0: 16bit address<br>1'b1: 32bit address                                     |

**SLAVE DSMC CMN RGN2 CMN CON0**

Address: Operational Base + offset (0x0300)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                                                                                                                                                           |
| 11         | RW          | 0x0                | wr_data_cyc_extended<br>DSMC will output extended dummy clock cycle in write transaction when accessing region2.<br>1'b0: Normal write cycle mode<br>1'b1: Extend write cycle mode |
| 10:8       | RW          | 0x2                | rd_latency_cyc<br>Read latency cycle when accessing region2.<br>3'h1: 1 clock latency<br>3'h2: 2 clock latency<br>Others: Reserved                                                 |
| 7          | RO          | 0x0                | reserved                                                                                                                                                                           |
| 6:4        | RW          | 0x2                | wr_latency_cyc<br>Write latency cycle when accessing region2.<br>3'h1: 1 clock latency<br>3'h2: 2 clock latency<br>Others: Reserved                                                |
| 3:1        | RO          | 0x0                | reserved                                                                                                                                                                           |
| 0          | RW          | 0x1                | ca_cyc<br>This bit is used to indicate the address width of the CA phase when accessing region2.<br>1'b0: 16bit address<br>1'b1: 32bit address                                     |

**SLAVE DSMC CMN RGN3 CMN CON0**

Address: Operational Base + offset (0x0400)

| <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         | RW          | 0x0                | wr_data_cyc_extended<br>DSMC will output extended dummy clock cycle in write transaction when accessing region3.<br>1'b0: Normal write cycle mode<br>1'b1: Extend write cycle mode |
| 10:8       | RW          | 0x2                | rd_latency_cyc<br>Read latency cycle when accessing region3.<br>3'h1: 1 clock latency<br>3'h2: 2 clock latency<br>Others: Reserved                                                 |
| 7          | RO          | 0x0                | reserved                                                                                                                                                                           |
| 6:4        | RW          | 0x2                | wr_latency_cyc<br>Write latency cycle when accessing region3.<br>3'h1: 1 clock latency<br>3'h2: 2 clock latency<br>Others: Reserved                                                |
| 3:1        | RO          | 0x0                | reserved                                                                                                                                                                           |
| 0          | RW          | 0x1                | ca_cyc<br>This bit is used to indicate the address width of the CA phase when accessing region3.<br>1'b0: 16bit address<br>1'b1: 32bit address                                     |

**SLAVE DSMC CMN DBG STATUS 0**

Address: Operational Base + offset (0x0900)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                   |
| 3:2        | RO          | 0x0                | axi_wr_resp_error<br>AXI write transaction response error. |
| 1:0        | RO          | 0x0                | axi_rd_resp_error<br>AXI read transaction response error.  |

**SLAVE DSMC CMN DBG STATUS 1**

Address: Operational Base + offset (0x0904)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                         |
| 3:0        | RO          | 0x0                | bus_current_state<br>The state machine of slave. |

**SLAVE DSMC CMN DBG STATUS 2**

Address: Operational Base + offset (0x0908)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------|
| 31:22      | RO          | 0x000              | reserved                                                               |
| 21:16      | RO          | 0x00               | tx_dat_fifo_space2empty<br>The remained FIFO space of TX data FIFO.    |
| 15         | RO          | 0x0                | reserved                                                               |
| 14:8       | RO          | 0x00               | rx_dat_fifo_space2empty<br>The remained FIFO space of RX data FIFO.    |
| 7:5        | RO          | 0x0                | reserved                                                               |
| 4:0        | RO          | 0x00               | rx_cmd_fifo_space2empty<br>The remained FIFO space of RX command FIFO. |

## 36.6 Interface Description

Table 36-1 SLAVE DSMC interface description

| <b>Module Pin</b> | <b>Direction</b> | <b>Pin Name</b> | <b>IOMUX Setting</b>                     |
|-------------------|------------------|-----------------|------------------------------------------|
| CLK               | I                | GPIO1_C0        | GPIO1_IOC_GPIO1C_IOMUX_SEL_0[3:0]=4'h8   |
| CSN               | I                | GPIO1_D2        | GPIO1_IOC_GPIO1D_IOMUX_SEL_0[11:8]=4'h8  |
| DQS0              | I/O              | GPIO1_C1        | GPIO1_IOC_GPIO1C_IOMUX_SEL_0[7:4]=4'h8   |
| D0                | I/O              | GPIO1_C2        | GPIO1_IOC_GPIO1C_IOMUX_SEL_0[11:8]=4'h8  |
| D1                | I/O              | GPIO1_C3        | GPIO1_IOC_GPIO1C_IOMUX_SEL_0[15:12]=4'h8 |
| D2                | I/O              | GPIO1_C4        | GPIO1_IOC_GPIO1C_IOMUX_SEL_1[3:0]=4'h8   |
| D3                | I/O              | GPIO1_C5        | GPIO1_IOC_GPIO1C_IOMUX_SEL_1[7:4]=4'h8   |
| D4                | I/O              | GPIO1_C6        | GPIO1_IOC_GPIO1C_IOMUX_SEL_1[11:8]=4'h8  |
| D5                | I/O              | GPIO1_C7        | GPIO1_IOC_GPIO1C_IOMUX_SEL_1[15:12]=4'h8 |
| D6                | I/O              | GPIO1_D0        | GPIO1_IOC_GPIO1D_IOMUX_SEL_0[3:0]=4'h8   |
| D7                | I/O              | GPIO1_D1        | GPIO1_IOC_GPIO1D_IOMUX_SEL_0[7:4]=4'h8   |
| INT               | O                | GPIO1_A1        | GPIO1_IOC_GPIO1A_IOMUX_SEL_0[7:4]=4'h8   |
| RDYN              | O                | GPIO1_D3        | GPIO1_IOC_GPIO1D_IOMUX_SEL_0[15:12]=4'h8 |

Notes: I=input, O=output, I/O=input/output, bidirectional.

## 36.7 Application Notes

### 36.7.1 Typical Program Flow

7. Configure the SLAVE\_DSMC\_AXI\_WR\_ADDR\_SIZE and SLAVE\_DSMC\_AXI\_RD\_ADDR\_SIZE according to Chip Address Map.
8. The MASTER DSMC configures the Common register bank according to the host setting.
9. The MASTER access the register of FIFO region.

### 36.7.2 Bulk Data Transfer Program Flow

9. Configure the SLAVE\_DSMC\_AXI\_WR\_ADDR\_SIZE and SLAVE\_DSMC\_AXI\_RD\_ADDR\_SIZE according to Chip Address Map.
10. Configure the SLAVE\_DSMC\_LBC\_H2S\_INT\_STA\_EN and SLAVE\_DSMC\_LBC\_H2S\_INT\_STA\_SIG\_EN to allow the host to interrupt to slave.
11. The MASTER DSMC configures the Common register bank according to the host setting.
12. The slave chip sends DMA request interrupt signal to the host chip, and the host chip start DMA transfer.
13. The host chip access application register bank to generate host2slave interrupt to inform the slave chip that the transfer is finished.

## Chapter 37 Flexible Bus (FlexBUS)

### 37.1 Overview

FlexBUS is an AHB slave device. FlexBUS can achieve high-speed IO toggle and imitate some irregular or standards protocols. There are four possible combinations for the serial clock phase and polarity. The chip select signal (csn) is held high when the FlexBUS is idle or disabled. There are two channels which are transmission channel and receiving channel in FlexBUS. Therefore, FlexBUS can support both transmitting and receiving simultaneously. The flexbus0\_clk, flexbus0\_csn and flexbus0\_data ports can be used for transmission channel and receiving channel. The flexbus1\_clk, flexbus1\_csn and flexbus1\_data ports can only be used for receiving channel.

FlexBUS Controller supports the following features:

- Support for built-in DMA and ping-pong operation for allocating two address
- Support for filling in all 0 if the last DMA burst is less than 32Bytes or 64Bytes in receiving mode
- Support timeout interrupt of DMA response
- The direction of flexbus0\_data port is I/O, flexbus0\_data port can be used for transmission and receiving operation. The direction of flexbus1\_data port is Input, flexbus1\_data port can only be used for receiving operation
- Support for four working modes
  - Flexbus0\_data port is used for transmission channel and receiving channel, flexbus0\_clk port is used for transmission channel and receiving channel, supporting three mode: transmit only, receive only, transmission then receive
  - Flexbus0\_data port is only used for transmission channel, flexbus0\_clk port is used for transmission channel and receiving channel, supporting four mode: transmit only, receive only, transmission then receive, transmission and receive
  - Flexbus0\_data port is only used for transmission channel, flexbus0\_clk port is only used for transmission channel, supporting three mode: transmit only, receive only, transmission and receive
- Support software configuration and following data for csn port
- Support the image format of BT601 YUV422 and RGB565
- Support YUV422 image format conversion of RGB888
- Support image cropping function
- Support clock port two modes, free running and following data mode
  - Free running mode
    - ◆ Txfifo is empty and supports the following two processing modes
      - 1) Stop transmission, pull up csn and send abnormal interruption
      - 2) Data, csn remain unchanged and clock hold toggle, send abnormal interruption
    - ◆ Rxfifo is pre-full
      - 1) Stop transmission, pull up csn and send abnormal interruption
  - Following data mode
    - ◆ Txfifo is empty and supports the following two processing modes
      - 1) Stop transmission, pull up csn and send abnormal interruption
      - 2) Data, csn and clock remain unchanged, send abnormal interruption
    - ◆ Rxfifo is pre-full and supports the following two processing modes
      - 1) Stop transmission, pull up csn and send abnormal interruption
      - 2) Data, csn and clock remain unchanged, send abnormal interruption
- Support single mode and continuous mode. Continuous mode can not support transmission then receive mode
- Support configurable four possible combinations for the clock port polarity and phase
- Support 1,2,4,8,16bits parallel data transfer
- Support clock port masking function
- Support the maximum of clock port up to 100MHz in transmission mode and receive mode
- Support software configuration modification of sampling points

## 37.2 Block Diagram

The FlexBUS Controller comprises with:

- **AHB\_CFG**

The AHB\_CFG contains control registers of transmitters and receiver.

- **AXI Master Interface and DMA Controller**

The AXI Master Interface and DMA Controller implement for reading data from DDR and writing data to DDR.

- **Engine**

The Engine implements control over all modules and monitor the generation of abnormal interrupts.

- **IOBUF**

The IOBUF implements logic of data, csn and clock port.

- **TX and RX FIFO**

The TX FIFO is the buffer to store transmitted data. The RX FIFO is the buffer to store received data. The size of the TX and RX FIFO is 32bits x 256.



Fig. 37-1 FlexBUS Controller Block diagram

## 37.3 Function Description

### 37.3.1 Transfer Modes

According to multiplexed of flexbus0\_data and flexbus0\_clk ports, FlexBUS can be divided into different working modes. The following table shows the ports in different transfer modes.

Table 37-1 FlexBUS Tranfer Modes Port List

| COM_CTL[3:2] | TX Only                                          | RX Only                                          | TX and RX                                                                             | TX then RX                                                    |
|--------------|--------------------------------------------------|--------------------------------------------------|---------------------------------------------------------------------------------------|---------------------------------------------------------------|
| 2'b11        | flexbus0_data/<br>flexbus0_clk/<br>flexbus0_csn/ | flexbus0_data/<br>flexbus0_clk/<br>flexbus0_csn/ | not support                                                                           | flexbus0_data/<br>flexbus0_clk/<br>flexbus0_csn/              |
| 2'b01        |                                                  | flexbus1_data/<br>flexbus0_clk/<br>flexbus0_csn/ | flexbus0_data/flexbus1_data<br>flexbus0_clk/<br>flexbus0_csn/                         | flexbus0_data/flexbus1_data<br>flexbus0_clk/<br>flexbus0_csn/ |
| 2'b00        |                                                  | flexbus1_data/<br>flexbus1_clk/<br>flexbus1_csn/ | flexbus0_data/flexbus1_data<br>flexbus0_clk/flexbus1_clk<br>flexbus0_csn/flexbus1_csn | not support                                                   |

### 37.3.2 Free Running

Flexbus0/1\_clk can output earlier than csn begin active in free running mode.

Flexbus0/1\_clk can output as soon as FLEXBUS\_FREE\_SCLK is configured to 1. When FLEXBUS\_FREE\_SCLK is configured to 0, Flexbus0/1\_clk will follow data after flexbus0/1\_csn being active.

### 37.3.3 Single and Continuous Mode

#### 37.3.3.1 Single Mode

In this mode, the amount of data transmitted or received is determined by FLEXBUS\_TX\_NUM/RX\_NUM. FlexBUS will stop and send interrupt when the amount of data transmitted or received reaches the FLEXBUS\_TX\_NUM/RX\_NUM. The address of

transmission is FLEXBUS\_DMA\_SRC\_ADDR0/DMA\_DST\_ADDR0. If the value of FLEXBUS\_TX\_NUM/RX\_NUM is greater than FLEXBUS\_DMA\_SRC\_LEN0/DMA\_DST\_LEN0, FlexBUS will automatically jump to FLEXBUS\_DMA\_SRC\_ADDR1/DMA\_DST\_ADDR1 after FLEXBUS\_DMA\_SRC\_ADDR0/ DMA\_DST\_ADDR0 is full. So it is recommended that the value of FLEXBUS\_TX\_NUM/RX\_NUM is smaller than FLEXBUS\_DMA\_SRC\_LEN0/DMA\_DST\_LEN0 in single mode.

### 37.3.3.2 Continuous Mode

In continuous mode, FlexBUS keeps working until the value of FLEXBUS\_STOP is set and FLEXBUS\_RX\_NUM/TX\_NUM will be ignored. FlexBUS will send interrupt when FLEXBUS\_STOP is set. The user can configures two buffer which buffer0 is configured by FLEXBUS\_DMA\_SRC\_ADDR0/DMA\_DST\_ADDR0 and FLEXBUS\_DMA\_SRC\_LEN0/DMA\_DST\_LEN0, buffer1 is configured by FLEXBUS\_DMA\_SRC\_ADDR1/DMA\_DST\_ADDR1 and FLEXBUS\_DMA\_SRC\_LEN1/DMA\_DST\_LEN1. After the amount of data transmitted and received reaches the value of buffer0, FlexBUS will automatically jump to buffer1 and the user can configure new address of buffer0 and clear buffer0 interrupt status. Similarly, FlexBUS will automatically jump to buffer0 and the user can configure new address of buffer1 and clear buffer1 interrupt status after the amount of data transmitted and received reaches the value of buffer1.

### 37.3.4 CPOL and CPHA

The clock polarity (CPOL) configuration parameter determines whether the inactive state of the serial clock is high or low. This is same as SPI. To transmit data, both FlexBUS and peripherals must have identical serial clock phase (CPHA) and clock polarity (CPOL) values. The data frame can be 1/2/4/8/16 bits in length.

When the configuration parameter CPHA = 0, data transmission begins on the falling edge of the slave select signal. The first data bit is captured by the slave peripherals on the first edge of the serial clock; therefore, valid data must be present on the data lines prior to the first serial clock edge. The following two figures show a timing diagram for FlexBUS data transfer with CPHA = 0. The serial clock is shown for configuration parameters CPOL = 0 and CPOL = 1.



Fig. 37-2 FlexBUS Format (CPHA=0 CPOL=0)



Fig. 37-3 FlexBUS Format (CPHA=0 CPOL=1)

When the configuration parameter CPHA = 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 signal 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 FlexBUS format when the configuration parameter CPHA = 1.



Fig. 37-4 FlexBUS Format (CPHA=1 CPOL=0)



Fig. 37-5 FlexBUS Format (CPHA=1 CPOL=1)

### 37.3.5 TX Then RX Mode

CPHA=1, CPOL=0, transmit data at the posedge of CLKA and receive data at the negedge of CLKA. At T2, the last data is transmitted, and at T3, data pad would change to input. When FLEXBUS\_RXCLK\_DUMMY[4:0]=0, at T3 negedge of CLKA, rx channel would sample data; when FLEXBUS\_RXCLK\_DUMMY[4:0]=1, at T4 negedge of CLKA, rx channel would sample data.



Fig. 37-6 FlexBUS TX Then RX Mode (CPHA=1 CPOL=0)

### 37.3.6 DVP Slave Mode

#### 37.3.6.1 Support Vsync high active or low active

Vsync Low active



Fig. 37-7 Timing Diagram When VSYNC Low Active

Vsync High active



Fig. 37-8 Timing Diagram When VSYNC High Active

#### 37.3.6.2 Support Href High Active or Low Active

Href high active



Fig. 37-9 Timing Diagram When HREF High Active

Href Low active



Fig. 37-10 Timing Diagram When HREF Low Active

### 37.3.6.3 Data Format

YUV422 For Y first



Fig. 37-11 Timing Diagram When Y Data First

YUV422 For U first



Fig. 37-12 Timing Diagram When U Data First

RGB565 For B first



Fig. 37-13 Timing Diagram When B Data First

RGB565 For R first



Fig. 37-14 Timing Diagram When R Data First

### 37.3.6.4 One Frame Stop Mode

In this mode, configure the register FLEXBUS\_RX\_CTL to one frame stop mode. After one frame captured, FlexBUS will automatic stop and send interrupt. FlexBUS will not capture the sensor data. The address of Y/UV is FLEXBUS\_DMA\_DST\_ADDR0.

### 37.3.6.5 Frame Ping-Pong Mode

After one frame(F0) captured, FlexBUS will jump to buffer1 and start to capture the next frame(F1) automatically, and host must assign new address pointer of frame0 and clear the frame0 status, thus FlexBUS will capture the third frame automatically(by new F0 address) without any stop and so on for the following frames.

### 37.3.6.6 Storage

Y/UV data or R/G/B data will be storage in the same buffer. In addition, the amount of data in a row must be an integer multiple of 4Bytes.

### 37.3.6.7 Crop

The register FLEXBUS\_DVP\_CROP\_START defines the coordinate of crop start point. And the frame size after cropping is following the value of FLEXBUS\_DVP\_CROP\_SIZE. Bypass or crop the source video data to a smaller size destination.



Fig. 37-15 Crop

### 37.3.7 QSPI

#### 37.3.7.1 Command and Address

There are three phases in QSPI mode, which are command phase, address phase and data phase. The user can configure FLEXBUS\_TX\_CMD0 and FLEXBUS\_TX\_CMD1 in command and address phase. The register FLEXBUS\_TX\_CMD0 and FLEXBUS\_TX\_CMD1 can store up to 64bits data and data is sent from MSB of TX\_CMD0 and TX\_CMD1. FlexBUS can support x1 and x4 for command phase and address phase.



Fig. 37-16 Timing diagram in QSPI Mode

The user can configure FLEXBUS\_TX\_CMD0 = 0xDE006000 to achieve the timing shown in the figure above.

#### 37.3.7.2 Multi-Line

FlexBUS can support multi-line transfer mode. The command and address should be same on each line of transmission. FLEXBUS\_TX\_CMD\_LEN controls the length of the command and address, which unit is determined by FLEXBUS\_TX\_CTL[12](1bit or 4bits).

FLEXBUS\_TX\_WIDTH controls the length of pixel data per line, which unit is determined by FLEXBUS\_TX\_CTL[31:29]. Flexbus0\_csn will automatically be switched to high level when a line of pixel data is sent. The duration of high level is determined by FLEXBUS\_TX\_CSN\_DUMMY.

The relation between FLEXBUS\_TX\_NUM and FLEXBUS\_TX\_WIDTH/FLEXBUS\_TX\_CMD\_LEN is as follows:

$\text{FLEXBUS\_TX\_NUM} = (\text{number of lines}) \times (\text{FLEXBUS\_TX\_WIDTH} + \text{FLEXBUS\_TX\_CMD\_LEN})$ .



Fig. 37-17 Timing diagram in Multi-line

## 37.4 Register Description

### 37.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

### 37.4.2 Registers Summary

| Name                    | Offset | Size | Reset Value | Description                                     |
|-------------------------|--------|------|-------------|-------------------------------------------------|
| FLEXBUS ENR             | 0x0000 | W    | 0x00000000  | Enable Register                                 |
| FLEXBUS FREE SCLK       | 0x0004 | W    | 0x00000000  | Sclk Free Register                              |
| FLEXBUS CSN CFG         | 0x0008 | W    | 0x00000000  | Csn Config Register                             |
| FLEXBUS COM CTL         | 0x000C | W    | 0x00000004  | Common Control Register                         |
| FLEXBUS REMAP           | 0x0010 | W    | 0x00000000  | Data IO Remap Register                          |
| FLEXBUS STOP            | 0x0014 | W    | 0x00000000  | Continue Mode Stop Register                     |
| FLEXBUS SLAVE MODE      | 0x0018 | W    | 0x00000001  | Slave Mode Register                             |
| FLEXBUS DVP POL         | 0x001C | W    | 0x00000000  | DVP Interface Register                          |
| FLEXBUS DVP CROP SIZE   | 0x0020 | W    | 0x00000000  | The Expected Width And Height of Received Image |
| FLEXBUS DVP CROP START  | 0x0024 | W    | 0x00000000  | The Start Point of DVP Path Cropping            |
| FLEXBUS DVP ORDER       | 0x0028 | W    | 0x00000000  | YVYU422 Mode Order                              |
| FLEXBUS DVP YUV2RGB     | 0x002C | W    | 0x00000000  | YUV2RGB Mode                                    |
| FLEXBUS TX CTL          | 0x0040 | W    | 0x00000000  | Tx Control Register                             |
| FLEXBUS TX NUM          | 0x0044 | W    | 0x00000000  | Tx Length Register                              |
| FLEXBUS TXWAT START     | 0x0048 | W    | 0x00000000  | Waterline To Start Transmission Register        |
| FLEXBUS TXFIFO DNUM     | 0x004C | W    | 0x00000000  | Transmit FIFO Level                             |
| FLEXBUS TX WIDTH        | 0x0050 | W    | 0x00000000  | The Expected Width of Image                     |
| FLEXBUS TX CSN DUMMY    | 0x0054 | W    | 0x00000000  | Csn Inactive Counter                            |
| FLEXBUS TX CMD LEN      | 0x0058 | W    | 0x00000000  | TX Command Width                                |
| FLEXBUS TX CMD0         | 0x005C | W    | 0x00000000  | TX Command0 Register                            |
| FLEXBUS TX CMD1         | 0x0060 | W    | 0x00000000  | TX Command1 Register                            |
| FLEXBUS RX CTL          | 0x0080 | W    | 0x00000000  | RX Control Register                             |
| FLEXBUS RX NUM          | 0x0084 | W    | 0x00000000  | RX Length Register                              |
| FLEXBUS RXFIFO DNUM     | 0x0088 | W    | 0x00000000  | Receive FIFO Level                              |
| FLEXBUS DLL EN          | 0x008C | W    | 0x00000000  | Delayline Enable Register                       |
| FLEXBUS DLL NUM         | 0x0090 | W    | 0x00000000  | Delayline Number Register                       |
| FLEXBUS RXCLK DUMMY     | 0x0094 | W    | 0x00000000  | RX CLK Dummy Register                           |
| FLEXBUS RXCLK CAP COUNT | 0x0098 | W    | 0x00000000  | RX Capture Counter Register                     |
| FLEXBUS DMA RD OUTS TD  | 0x0100 | W    | 0x0000000F  | DMA Read Outstanding Register                   |
| FLEXBUS DMA WR OUTS TD  | 0x0104 | W    | 0x0000000F  | DMA Write Outstanding Register                  |
| FLEXBUS DMA SRC ADD R0  | 0x0108 | W    | 0x00000000  | DMA Source Address0 Register                    |
| FLEXBUS DMA DST ADD R0  | 0x010C | W    | 0x00000000  | DMA Destination Address0 Register               |
| FLEXBUS DMA SRC ADD R1  | 0x0110 | W    | 0x00000000  | DMA Source Address1 Register                    |
| FLEXBUS DMA DST ADD R1  | 0x0114 | W    | 0x00000000  | DMA Destination Address1 Register               |
| FLEXBUS DMA SRC LEN 0   | 0x0118 | W    | 0x00000000  | DMA Source Address0 Size Register               |

| Name                             | Offset | Size | Reset Value | Description                            |
|----------------------------------|--------|------|-------------|----------------------------------------|
| FLEXBUS DMA DST LEN <sub>0</sub> | 0x011C | W    | 0x00000000  | DMA Destination Address0 Size Register |
| FLEXBUS DMA SRC LEN <sub>1</sub> | 0x0120 | W    | 0x00000000  | DMA Source Address1 Size Register      |
| FLEXBUS DMA DST LEN <sub>1</sub> | 0x0124 | W    | 0x00000000  | DMA Source Address0 Size Register      |
| FLEXBUS DMA WAT INT              | 0x0128 | W    | 0x00000000  | DMA Watermark Register                 |
| FLEXBUS DMA TIMEOUT              | 0x012C | W    | 0x00000000  | DMA Timeout Register                   |
| FLEXBUS DMA RD LEN               | 0x0130 | W    | 0x00000000  | DMA Read Burst Length                  |
| FLEXBUS STATUS                   | 0x0160 | W    | 0x00000000  | Status Register                        |
| FLEXBUS IMR                      | 0x0164 | W    | 0x00000000  | Interrupt Mask                         |
| FLEXBUS RISR                     | 0x0168 | W    | 0x00000000  | Raw Interrupt Status                   |
| FLEXBUS ISR                      | 0x016C | W    | 0x00000000  | Interrupt Status                       |
| FLEXBUS ICR                      | 0x0170 | W    | 0x00000000  | Interrupt Clear                        |
| FLEXBUS REVISION                 | 0x01F0 | W    | 0x010D0844  | SVN Revision                           |

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

### 37.4.3 Detail Registers Description

#### FLEXBUS\_ENR

Address: Operational Base(0xFF880000) + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                           |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18 | RO   | 0x0000      | reserved                                                                                                                                              |
| 17:16 | RW   | 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     | RW   | 0x0         | rx_enr<br>Enables and disables all rx logic operations. Receive FIFO buffers are cleared when rx logic is disabled.<br>1'b1: Enable<br>1'b0: Disable  |
| 0     | RW   | 0x0         | tx_enr<br>Enables and disables all tx logic operations. Transmit FIFO buffers are cleared when tx logic is disabled.<br>1'b1: Enable<br>1'b0: Disable |

#### FLEXBUS\_FREE\_SCLK

Address: Operational Base(0xFF880000) + offset (0x0004)

| Bit   | Attr | Reset Value | Description                                                                                                                      |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:18 | RO   | 0x0000      | reserved                                                                                                                         |
| 17:16 | RW   | 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     | RW   | 0x0         | rx_free_mode<br>If set to 1, rx 1xclk output in advance, not following data.                                                     |
| 0     | RW   | 0x0         | tx_free_mode<br>If set to 1, tx 1xclk output in advance, not following data.                                                     |

#### FLEXBUS\_CSN\_CFG

Address: Operational Base(0xFF880000) + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:18      | RO          | 0x0000             | reserved                                                                                                                         |
| 17:16      | RW          | 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          | RW          | 0x0                | rx_csn_cfg<br>1'b1: If set to 1, rx csn is active low in advance.<br>1'b0: Rx csn follows data.                                  |
| 0          | RW          | 0x0                | tx_csn_cfg<br>1'b1: If set to 1, tx csn is active low in advance.<br>1'b0: Tx csn follows data.                                  |

### **FLEXBUS COM CTL**

Address: Operational Base(0xFF880000) + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                                                                                                                                         |
| 5          | RW          | 0x0                | rxfifo_expand<br>If set to 1, txfifo would be used for rxfifo in rx only mode. The capacity of rxfifo would be doubled to the original.                                          |
| 4          | RW          | 0x0                | txfifo_expand<br>If set to 1, rxfifo would be used for txfifo in tx only mode. The capacity of txfifo would be doubled to the original.                                          |
| 3          | RW          | 0x0                | tx_use_rx<br>If set to 1, tx data channel will be used for rx data channel.                                                                                                      |
| 2          | RW          | 0x1                | sclk_share<br>If set to 1, rx logic and tx logic use the same 2xclk and 1xclk.                                                                                                   |
| 1:0        | RW          | 0x0                | tx_rx_mode<br>Transmit and receive mode select.<br>2'b00: Transmit & Receive<br>2'b01: Transmit Only<br>2'b10: Receive Only<br>2'b11: Transmit first, and then change to receive |

### **FLEXBUS REMAP**

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

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

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:4 | RW   | 0x0         | <p>rx_data_remap</p> <p>When rx_data_width=0,</p> <p>3'b000: Din[0] PAD input valid.</p> <p>3'b001: Din[1] PAD input valid.</p> <p>3'b010: Din[2] PAD input valid.</p> <p>3'b011: Din[3] PAD input valid.</p> <p>3'b100: Din[4] PAD input valid.</p> <p>3'b101: Din[5] PAD input valid.</p> <p>3'b110: Din[6] PAD input valid.</p> <p>3'b111: Din[7] PAD input valid.</p> <p>When rx_data_width=1,</p> <p>3'b000: Din[1:0] PAD input valid.</p> <p>3'b001: Din[3:2] PAD input valid.</p> <p>3'b010: Din[5:4] PAD input valid.</p> <p>3'b011: Din[7:6] PAD input valid.</p> <p>3'b100: Din[9:8] PAD input valid.</p> <p>3'b101: Din[11:10] PAD input valid.</p> <p>3'b110: Din[13:12] PAD input valid.</p> <p>3'b111: Din[15:14] PAD input valid.</p> <p>When rx_data_width=2,</p> <p>3'b000: Din[3:0] PAD input valid.</p> <p>3'b001: Din[7:4] PAD input valid.</p> <p>3'b010: Din[11:8] PAD input valid.</p> <p>3'b011: Din[15:12] PAD input valid.</p> <p>Reserved.</p> <p>When rx_data_width=3,</p> <p>3'b000: Din[7:0] PAD input valid.</p> <p>3'b001: Din[15:8] PAD input valid.</p> <p>Reserved.</p> <p>When rx_data_width=4,</p> <p>3'b000: Din[15:0] PAD input valid.</p> <p>Reserved.</p> |
| 3   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 2:0 | RW   | 0x0         | <p>tx_data_remap</p> <p>When tx_data_width=0,</p> <p>3'b000: Dout[0] PAD output valid.</p> <p>3'b001: Dout[1] PAD output valid.</p> <p>3'b010: Dout[2] PAD output valid.</p> <p>3'b011: Dout[3] PAD output valid.</p> <p>3'b100: Dout[4] PAD output valid.</p> <p>3'b101: Dout[5] PAD output valid.</p> <p>3'b110: Dout[6] PAD output valid.</p> <p>3'b111: Dout[7] PAD output valid.</p> <p>When tx_data_width=1,</p> <p>3'b000: Dout[1:0] PAD output valid.</p> <p>3'b001: Dout[3:2] PAD output valid.</p> <p>3'b010: Dout[5:4] PAD output valid.</p> <p>3'b011: Dout[7:6] PAD output valid.</p> <p>3'b100: Dout[9:8] PAD output valid.</p> <p>3'b101: Dout[11:10] PAD output valid.</p> <p>3'b110: Dout[13:12] PAD output valid.</p> <p>3'b111: Dout[15:14] PAD output valid.</p> <p>When tx_data_width=2,</p> <p>3'b000: Dout[3:0] PAD output valid.</p> <p>3'b001: Dout[7:4] PAD output valid.</p> <p>3'b010: Dout[11:8] PAD output valid.</p>                                                                                                                                                                                                                                                |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                           |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 3'b011: Dout[15:12] PAD output valid.<br>Reserved.<br>When tx_data_width=3,<br>3'b000: Dout[7:0] PAD output valid.<br>3'b001: Dout[15:8] PAD output valid.<br>Reserved.<br>When tx_data_width=4,<br>3'b000: Dout[15:0] PAD output valid.<br>Reserved. |

### **FLEXBUS STOP**

Address: Operational Base(0xFF880000) + offset (0x0014)

| Bit  | Attr   | Reset Value | Description                                                        |
|------|--------|-------------|--------------------------------------------------------------------|
| 31:2 | RO     | 0x00000000  | reserved                                                           |
| 1    | R/W SC | 0x0         | rx_stop<br>In rx continue mode, used to stop receive.              |
| 0    | R/W SC | 0x0         | tx_stop<br>If set to 1, it used to stop transmit in continue mode. |

### **FLEXBUS SLAVE MODE**

Address: Operational Base(0xFF880000) + offset (0x0018)

| Bit  | Attr | Reset Value | Description                                                                                   |
|------|------|-------------|-----------------------------------------------------------------------------------------------|
| 31:2 | RO   | 0x00000000  | reserved                                                                                      |
| 1    | RW   | 0x0         | dvp_sel<br>1'b0: Work as ADC<br>1'b1: Work as DVP interface                                   |
| 0    | RW   | 0x1         | clk1_in<br>If set to 1, slave mode is enabled and rx logic uses flexbus_clk1_in as the 2xclk. |

### **FLEXBUS DVP POL**

Address: Operational Base(0xFF880000) + offset (0x001C)

| Bit  | Attr | Reset Value | Description                                          |
|------|------|-------------|------------------------------------------------------|
| 31:2 | RO   | 0x00000000  | reserved                                             |
| 1    | RW   | 0x0         | href_pol<br>1'b1: High active.<br>1'b0: Low active.  |
| 0    | RW   | 0x0         | vsync_pol<br>1'b1: High active.<br>1'b0: Low active. |

### **FLEXBUS DVP CROP SIZE**

Address: Operational Base(0xFF880000) + offset (0x0020)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                             |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | sw_height<br>The expected height of received image.                                                                                                                                                     |
| 15:0  | RW   | 0x0000      | sw_width<br>The expected width of received image. The value of the register is equal to the number of bytes. So if one pixel is equal to 2bytes, the value of the register is double to width of image. |

### **FLEXBUS DVP CROP START**

Address: Operational Base(0xFF880000) + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | sw_start_y<br>The vertical ordinate of the start point.                                                                                                                                                         |
| 15:0       | RW          | 0x0000             | sw_start_x<br>The horizontal ordinate of the start point. The value of the register is equal to the number of bytes. So if one pixel is equal to 2bytes, the value of the register is double to width of image. |

**FLEXBUS DVP ORDER**

Address: Operational Base(0xFF880000) + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                                      |
| 3:2        | RW          | 0x0                | out_order<br>2'b00: YVYU(Y is LSB)<br>2'b01: VYUY(V is LSB)<br>2'b10: YUYV(Y is LSB)<br>2'b11: UYVY(U is LSB) |
| 1:0        | RW          | 0x0                | in_order<br>2'b00: YVYU(Y is LSB)<br>2'b01: VYUY(V is LSB)<br>2'b10: YUYV(Y is LSB)<br>2'b11: UYVY(U is LSB)  |

**FLEXBUS DVP YUV2RGB**

Address: Operational Base(0xFF880000) + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                                                                                          |
| 3          | RW          | 0x0                | rb_swap<br>1'b1: B is in LSB byte.<br>1'b0: B is in MSB byte.                                                                                                     |
| 2:1        | RW          | 0x0                | mode<br>Source bitmap YUV2RGB conversion mode<br>2'b00,2'b01: BT.601-range0(limit range)<br>2'b10: BT.601-range1(full range)<br>2'b11: BT.709-range0(limit range) |
| 0          | RW          | 0x0                | enable<br>1'b1: YUV2RGB mode enable.<br>1'b0: YUV2RGB mode disable.                                                                                               |

**FLEXBUS TX CTL**

Address: Operational Base(0xFF880000) + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29      | RW          | 0x0                | data_width<br>Selects the data frame length.<br>3'b000: 1bit data<br>3'b001: 2bit data<br>3'b010: 4bit data<br>3'b011: 8bit data<br>3'b100: 16bit data                                                                        |
| 28:17      | RO          | 0x000              | reserved                                                                                                                                                                                                                      |
| 16         | RW          | 0x0                | oen_pre<br>To improve the data IO timing of switching from input to output, the application can set this register to switch IO from input to output in advance for one cycle. Unit is 2xclk.<br>1'b0: Zero<br>1'b1: One cycle |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15         | RW          | 0x0                | oen_dly<br>To improve the data IO timing of switching from output to input, the application can set this register to extend data IO output time at the last 1xclk. Unit is 2xclk.<br>1'b0: One cycle<br>1'b1: Two cycle                                           |
| 14         | RW          | 0x0                | dat_unit<br>1'b0: Unit is word when shift is 1'b1.<br>1'b1: Unit is byte when shift is 1'b1.                                                                                                                                                                      |
| 13         | RW          | 0x0                | shift<br>1'b0: First parallel bit is LSB in shift register.<br>1'b1: First parallel bit is MSB in shift register.                                                                                                                                                 |
| 12         | RW          | 0x0                | cmd_width<br>Command and address line width.<br>1'b0: x1 mode.<br>1'b1: x4 mode.                                                                                                                                                                                  |
| 11         | RW          | 0x0                | multi_line<br>1'b1: Multi-line transmission and csn auto switching is enable.<br>1'b0: Multi-line transmission and csn auto switching is disable.                                                                                                                 |
| 10:9       | RW          | 0x0                | csn_pos_cnt_cfg<br>The register should be configured to define the number of the 2xclk cycles between csn inactive and data stop transmission. Unit is 2xclk.<br>2'b00: 2 cycles delay<br>2'b01: 3 cycles delay<br>2'b10: 4 cycles delay<br>2'b11: 5 cycles delay |
| 8:7        | RW          | 0x0                | csn_neg_cnt_cfg<br>The register should be configured to define the number of the 1xclk cycles between csn active and data active. Unit is 1xclk.<br>2'b00: Do not delay<br>2'b01: half cycle delay<br>2'b10: one cycles delay<br>2'b11: one and half cycles delay |
| 6          | RW          | 0x0                | cutoff_cfg<br>Cutoff function enable/disable. When txfifo is empty, tx logic will stop 1xclk until txfifo is not empty.<br>1'b1: Enable<br>1'b0: Disable                                                                                                          |
| 5          | RW          | 0x0                | 1xclk_mask<br>1xclk mask enable/disable.<br>1'b1: Enable<br>1'b0: Disable                                                                                                                                                                                         |
| 4          | RW          | 0x0                | continue_mode<br>Continue mode enable/disable.<br>1'b1: Enable<br>1'b0: Disable                                                                                                                                                                                   |
| 3          | RW          | 0x0                | cpol<br>1'b0: Inactive state of 1xclk is low.<br>1'b1: Inactive state of 1xclk is high.                                                                                                                                                                           |
| 2          | RW          | 0x0                | cpha<br>1'b0: 1xclk toggles in middle of first data bit.<br>1'b1: 1xclk toggles at start of first data bit.                                                                                                                                                       |
| 1:0        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                          |

**FLEXBUS TX\_NUM**

## RK3506 TRM (Part 1)

Address: Operational Base(0xFF880000) + offset (0x0044)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                   |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:27 | RO   | 0x00        | reserved                                                                                                                                                                                                      |
| 26:0  | RW   | 0x00000000  | num<br>The register field sets the number of data frames to transmit. The FlexBUS continues to transmit data until the number of data frames transmitted is equal to this register value. Unit is data_width. |

### FLEXBUS TXWAT START

Address: Operational Base(0xFF880000) + offset (0x0048)

| Bit  | Attr | Reset Value | Description                                                                                                                                      |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9 | RO   | 0x0000000   | reserved                                                                                                                                         |
| 8:0  | RW   | 0x000       | txfifo_wat_start<br>When the number of words in transmit FIFO is more than or equal to this value, the transmit logic starts work. Unit is word. |

### FLEXBUS TXFIFO DNUM

Address: Operational Base(0xFF880000) + offset (0x004C)

| Bit   | Attr | Reset Value | Description                                                                           |
|-------|------|-------------|---------------------------------------------------------------------------------------|
| 31:10 | RO   | 0x0000000   | reserved                                                                              |
| 9:0   | RO   | 0x000       | dnum<br>Contains the number of valid data entries in the transmit FIFO. Unit is word. |

### FLEXBUS TX WIDTH

Address: Operational Base(0xFF880000) + offset (0x0050)

| Bit   | Attr | Reset Value | Description                                                                                                                                            |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12 | RO   | 0x0000000   | reserved                                                                                                                                               |
| 11:0  | RW   | 0x000       | width_size<br>In tx multi-line mode, the number of data will be transmitted when csn is low at one time, excluding command length. Unit is data_width. |

### FLEXBUS TX CSN DUMMY

Address: Operational Base(0xFF880000) + offset (0x0054)

| Bit   | Attr | Reset Value | Description                                                                                                                                 |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0000      | reserved                                                                                                                                    |
| 15:0  | RW   | 0x0000      | csn_dummy<br>The register should be configured to define the number of the 2xclk cycles between csn inactive and csn active. Unit is 2xclk. |

### FLEXBUS TX CMD LEN

Address: Operational Base(0xFF880000) + offset (0x0058)

| Bit  | Attr | Reset Value | Description                                                                                                                             |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:7 | RO   | 0x00000000  | reserved                                                                                                                                |
| 6:0  | RW   | 0x00        | cmd_len<br>The number of data will be transmitted in one wire mode. Unit is bit. The minimum configured value should be greater than 1. |

### FLEXBUS TX CMD0

Address: Operational Base(0xFF880000) + offset (0x005C)

| Bit  | Attr | Reset Value | Description                                     |
|------|------|-------------|-------------------------------------------------|
| 31:0 | RW   | 0x00000000  | cmd0<br>Data used to transmit in one wire mode. |

**FLEXBUS TX CMD1**

Address: Operational Base(0xFF800000) + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                              |
|------------|-------------|--------------------|-------------------------------------------------|
| 31:0       | RW          | 0x00000000         | cmd1<br>Data used to transmit in one wire mode. |

**FLEXBUS RX CTL**

Address: Operational Base(0xFF800000) + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29      | RW          | 0x0                | data_width<br>Selects the data frame length.<br>3'b000: 1bit data<br>3'b001: 2bit data<br>3'b010: 4bit data<br>3'b011: 8bit data<br>3'b100: 16bit data                                                                                                                                      |
| 28:18      | RO          | 0x000              | reserved                                                                                                                                                                                                                                                                                    |
| 17         | RW          | 0x0                | fill_dummy<br>FlexBUS will automatically fill in dummy 0 when the last data is not enough to make up for 4bytes.<br>1'b1: Enable<br>1'b0: Disable                                                                                                                                           |
| 16         | RW          | 0x0                | dat_unit<br>1'b0: Unit is word when shift is 1'b1.<br>1'b1: Unit is byte when shift is 1'b1.                                                                                                                                                                                                |
| 15         | RW          | 0x0                | shift<br>1'b0: First parallel bit is LSB in shift register.<br>1'b1: First parallel bit is MSB in shift register.                                                                                                                                                                           |
| 14         | RW          | 0x0                | auto_pad<br>When the remaining number of data entries in rxfifo is less than one burst data of DMA, the DMA request will not be set high, but if this bit set to 1, the DMA request will be raised, and 0 will be automatically added to make up for the data volume.                       |
| 13:9       | RW          | 0x00               | csn_pos_cnt_cfg<br>The register should be configured to define the number of the 2xclk cycles between csn inactive and data stop receiving. Unit is 2xclk.<br>5'b00: 1 cycle delay<br>5'b01: 2 cycles delay<br>5'b10: 3 cycles delay<br>5'b11: 4 cycles delay<br>5'h1f: Max 32 cycles delay |
| 8:7        | RW          | 0x0                | csn_neg_cnt_cfg<br>The register should be configured to define the number of the 1xclk cycles between csn active and data active.<br>2'b00: Do not delay<br>2'b01: half cycle delay<br>2'b10: one cycles delay<br>2'b11: one and half cycles delay                                          |
| 6          | RW          | 0x0                | cutoff_cfg<br>Cutoff function enable/disable. When rxfifo is full, rx logic will stop 1xclk until rxfifo is not full.<br>1'b1: Enable<br>1'b0: Disable                                                                                                                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | RW          | 0x0                | rxd_dy<br>If the rxd data cannot be sampled by the sclk edge at the right time, this register should be configured to define the number of the 2xclk cycles after the active 1xclk edge to sample rxd data later when FlexBUS works at high frequency. Unit is 2xclk.<br>1'b0: Do not delay<br>1'b1: One cycle delay |
| 4          | RW          | 0x0                | continue_mode<br>Continue mode enable/disable.<br>1'b1: Enable<br>1'b0: Disable                                                                                                                                                                                                                                      |
| 3          | RW          | 0x0                | cpol<br>1'b0: Inactive state of 1xclk is low.<br>1'b1: Inactive state of 1xclk is high.                                                                                                                                                                                                                              |
| 2          | RW          | 0x0                | cpha<br>1'b0: 1xclk toggles in middle of first data bit.<br>1'b1: 1xclk clock toggles at start of first data bit.                                                                                                                                                                                                    |
| 1:0        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                             |

**FLEXBUS RX\_NUM**

Address: Operational Base(0xFF880000) + offset (0x0084)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:27      | RO          | 0x00               | reserved                                                                                                                                                                                                                                      |
| 26:0       | RW          | 0x0000000          | num<br>The register field sets the number of data frames to receive. The FlexBUS continues to receive data until the number of data frames transmitted is equal to this register value. This value contains rx_clk_dummy. Unit is data_width. |

**FLEXBUS RXFIFO\_DNUM**

Address: Operational Base(0xFF880000) + offset (0x0088)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x000000           | reserved                                                                             |
| 9:0        | RO          | 0x000              | dnum<br>Contains the number of valid data entries in the receive FIFO. Unit is word. |

**FLEXBUS DLL\_EN**

Address: Operational Base(0xFF880000) + offset (0x008C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                             |
| 0          | RW          | 0x0                | enable<br>If set to 1, rx delayline clock is enable. |

**FLEXBUS DLL\_NUM**

Address: Operational Base(0xFF880000) + offset (0x0090)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                    |
|------------|-------------|--------------------|---------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                              |
| 7:0        | RW          | 0x00               | num<br>The number steps of delayline. |

**FLEXBUS\_RXCLK\_DUMMY**

Address: Operational Base(0xFF880000) + offset (0x0094)

| <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          | 0x00               | rx_clk_dummy<br>In transmission then receive mode, this register should be configured to define the number of the 1xclk cycles after transmit operation finish to sample rx data. Unit is 1xclk. |

**FLEXBUS RXCLK CAP CNT**

Address: Operational Base(0xFF880000) + offset (0x0098)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                                                   |
| 4:0        | RW          | 0x00               | rx_cap_cnt<br>Used to define the position of the first data being captured. Unit is 1xclk. |

**FLEXBUS DMA RD OUTSTD**

Address: Operational Base(0xFF880000) + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                             |
| 5:0        | RW          | 0x0f               | read_outstanding<br>DMA read outstanding is equal to (register + 1). |

**FLEXBUS DMA WR OUTSTD**

Address: Operational Base(0xFF880000) + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                               |
| 5:0        | RW          | 0x0f               | write_outstanding<br>DMA write outstanding is equal to (register + 1). |

**FLEXBUS DMA SRC ADDR0**

Address: Operational Base(0xFF880000) + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                          |
| 29:0       | RW          | 0x00000000         | src_addr0<br>The first source address. The address is 4Byte alignment. Unit is 4Byte. So the register value is equal to 1, DMA source address is equal to 30'h04. |

**FLEXBUS DMA DST ADDR0**

Address: Operational Base(0xFF880000) + offset (0x010C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                   |
| 29:0       | RW          | 0x00000000         | dst_addr0<br>The first destination address. Unit is 4Byte. |

**FLEXBUS DMA SRC ADDR1**

Address: Operational Base(0xFF880000) + offset (0x0110)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                               |
| 29:0       | RW          | 0x00000000         | src_addr1<br>The second source address. Unit is 4Byte. |

**FLEXBUS DMA DST ADDR1**

Address: Operational Base(0xFF880000) + offset (0x0114)

| <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:0       | RW          | 0x00000000         | dst_addr1<br>The second destination address. Unit is 4Byte. |

**FLEXBUS DMA SRC LENO**

Address: Operational Base(0xFF880000) + offset (0x0118)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                    |
| 27:6       | RW          | 0x0000000          | src_len0<br>The size of first source address. Unit is byte. |
| 5:0        | RO          | 0x00               | reserved                                                    |

**FLEXBUS DMA DST LENO**

Address: Operational Base(0xFF880000) + offset (0x011C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                               |
|------------|-------------|--------------------|------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                         |
| 27:6       | RW          | 0x0000000          | dst_len0<br>The size of first destination address. Unit is byte. |
| 5:0        | RO          | 0x00               | reserved                                                         |

**FLEXBUS DMA SRC LEN1**

Address: Operational Base(0xFF880000) + offset (0x0120)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                           |
|------------|-------------|--------------------|--------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                     |
| 27:6       | RW          | 0x0000000          | src_len1<br>The size of second source address. Unit is byte. |
| 5:0        | RO          | 0x00               | reserved                                                     |

**FLEXBUS DMA DST LEN1**

Address: Operational Base(0xFF880000) + offset (0x0124)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                          |
| 27:6       | RW          | 0x0000000          | dst_len1<br>The size of second destination address. Unit is byte. |
| 5:0        | RO          | 0x00               | reserved                                                          |

**FLEXBUS DMA WAT INT**

Address: Operational Base(0xFF880000) + offset (0x0128)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                              |
| 3:2        | RW          | 0x0                | src_wat_lvl<br>Used to configure the watermark interrupt of read buffer0 and buffer1.<br>2'b00: The amount of data read from DDR is up to one-quarter of the size of source address.<br>2'b00: The amount of data read from DDR is up to half of the size of source address.<br>2'b10 or 2'b11: The amount of data read from DDR is up to the size of source address. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0        | RW          | 0x0                | <p>dst_wat_lvl<br/>Used to configure the watermark interrupt of write buffer0 and buffer1.</p> <p>2'b00: The amount of data written to DDR is up to one-quarter of the size of destination address.</p> <p>2'b00: The amount of data written to DDR is up to half of the size of destination address.</p> <p>2'b10 or 2'b11: The amount of data written to DDR is up to the size of destination address.</p> |

### **FLEXBUS DMA TIMEOUT**

Address: Operational Base(0xFF880000) + offset (0x012C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13      | RO          | 0x00000            | reserved                                                                                                                                                                           |
| 12:1       | RW          | 0x000              | <p>counter</p> <p>The register is used to define the time when the timeout interrupt is triggered. The actual internal delay time is x16 the value of register. Unit is 2xclk.</p> |
| 0          | RW          | 0x0                | <p>en</p> <p>1'b1: Timeout function is enable.</p> <p>1'b0: Timeout function is disable.</p>                                                                                       |

### **FLEXBUS DMA RD LEN**

Address: Operational Base(0xFF880000) + offset (0x0130)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                               |
| 0          | RW          | 0x0                | <p>burst_len8</p> <p>1'b1: DMA read burst length is equal to 8.</p> <p>1'b0: DMA read burst length is equal to 16.</p> |

### **FLEXBUS STATUS**

Address: Operational Base(0xFF880000) + offset (0x0160)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                                                                                                                |
| 5          | RO          | 0x0                | <p>rx_empty</p> <p>1'b0: Receive FIFO is not empty.</p> <p>1'b1: Receive FIFO is empty.</p>                                                             |
| 4          | RO          | 0x0                | <p>rx_full</p> <p>1'b0: Receive FIFO is not full.</p> <p>1'b1: Receive FIFO is full.</p>                                                                |
| 3          | RO          | 0x0                | <p>tx_empty</p> <p>1'b0: Transmit FIFO is not empty.</p> <p>1'b1: Transmit FIFO is empty.</p>                                                           |
| 2          | RO          | 0x0                | <p>tx_full</p> <p>1'b0: Transmit FIFO is not full.</p> <p>1'b1: Transmit FIFO is full.</p>                                                              |
| 1          | RO          | 0x0                | <p>rx_busy</p> <p>When set, indicates that receive transfer is in progress; when cleared, indicates that the receive is idle or disabled.</p>           |
| 0          | RO          | 0x0                | <p>tx_busy</p> <p>When set, indicates that transmission transfer is in progress; when cleared, indicates that the transmission is idle or disabled.</p> |

### **FLEXBUS IMR**

Address: Operational Base(0xFF880000) + offset (0x0164)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------|
| 31:14      | RO          | 0x00000            | reserved                                                                                                           |
| 13         | RW          | 0x0                | dma_timeout_im<br>1'b0: Timeout interrupt is masked.<br>1'b1: Timeout interrupt is not masked.                     |
| 12         | RW          | 0x0                | dma_err_im<br>1'b0: DMA error response interrupt is masked.<br>1'b1: DMA error response interrupt is not masked.   |
| 11         | RW          | 0x0                | dma_dst1_im<br>1'b0: DMA write buffer1 interrupt is masked.<br>1'b1: DMA write buffer1 interrupt is not masked.    |
| 10         | RW          | 0x0                | dma_dst0_im<br>1'b0: DMA write buffer0 interrupt is masked.<br>1'b1: DMA write buffer0 interrupt is not masked.    |
| 9          | RW          | 0x0                | dma_src1_im<br>1'b0: DMA read buffer1 interrupt is masked.<br>1'b1: DMA read buffer1 interrupt is not masked.      |
| 8          | RW          | 0x0                | dma_src0_im<br>1'b0: DMA read buffer0 interrupt is masked.<br>1'b1: DMA read buffer0 interrupt is not masked.      |
| 7          | RW          | 0x0                | dvp_frame_start_im<br>1'b0: Frame start interrupt is masked.<br>1'b1: Frame start interrupt is not masked.         |
| 6          | RW          | 0x0                | dvp_frame_ab<br>1'b0: Frame abnormal interrupt is masked.<br>1'b1: Frame abnormal interrupt is not masked.         |
| 5          | RW          | 0x0                | rx_done_im<br>1'b0: Receive finish interrupt is masked.<br>1'b1: Receive finish interrupt is not masked.           |
| 4          | RW          | 0x0                | rx_udf_im<br>1'b0: Rxfifo underflow interrupt is masked.<br>1'b1: Rxfifo underflow interrupt is not masked.        |
| 3          | RW          | 0x0                | rx_ovf_im<br>1'b0: Rxfifo overflow interrupt is masked.<br>1'b1: Rxfifo overflow interrupt is not masked.          |
| 2          | RW          | 0x0                | tx_done_im<br>1'b0: Transmission finish interrupt is masked.<br>1'b1: Transmission finish interrupt is not masked. |
| 1          | RW          | 0x0                | tx_udf_im<br>1'b0: Txfifo underflow interrupt is masked.<br>1'b1: Txfifo underflow interrupt is not masked.        |
| 0          | RW          | 0x0                | tx_ovf_im<br>1'b0: Txfifo overflow interrupt is masked.<br>1'b1: Txfifo overflow interrupt is not masked.          |

### **FLEXBUS RISR**

Address: Operational Base(0xFF880000) + offset (0x0168)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:14      | RO          | 0x00000            | reserved                                                                                                                                            |
| 13         | RO          | 0x0                | dma_timeout_ris<br>1'b0: DMA timeout interrupt is not active prior to masking.<br>1'b1: DMA timeout interrupt is active prior to masking.           |
| 12         | RO          | 0x0                | dma_err_ris<br>1'b0: DMA error response interrupt is not active prior to masking.<br>1'b1: DMA error response interrupt is active prior to masking. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11         | RO          | 0x0                | dma_dst1_ris<br>1'b0: DMA write buffer1 interrupt is not active prior to masking.<br>1'b1: DMA write buffer1 interrupt is active prior to masking.    |
| 10         | RO          | 0x0                | dma_dst0_ris<br>1'b0: DMA write buffer0 interrupt is not active prior to masking.<br>1'b1: DMA write buffer0 interrupt is active prior to masking.    |
| 9          | RO          | 0x0                | dma_src1_ris<br>1'b0: DMA read buffer1 interrupt is not active prior to masking.<br>1'b1: DMA read buffer1 interrupt is active prior to masking.      |
| 8          | RO          | 0x0                | dma_src0_ris<br>1'b0: DMA read buffer0 interrupt is not active prior to masking.<br>1'b1: DMA read buffer0 interrupt is active prior to masking.      |
| 7          | RO          | 0x0                | dvp_frame_start_ris<br>1'b0: Frame start interrupt is not active prior to masking.<br>1'b1: Frame start interrupt is active prior to masking.         |
| 6          | RO          | 0x0                | dvp_frame_ab_ris<br>1'b0: Frame abnormal interrupt is not active prior to masking.<br>1'b1: Frame abnormal interrupt is active prior to masking.      |
| 5          | RO          | 0x0                | rx_done_ris<br>1'b0: Receive finish interrupt is not active prior to masking.<br>1'b1: Receive finish interrupt is active prior to masking.           |
| 4          | RO          | 0x0                | rx_udf_ris<br>1'b0: Rx fifo underflow interrupt is not active prior to masking.<br>1'b1: Rx fifo underflow interrupt is active prior to masking.      |
| 3          | RO          | 0x0                | rx_ovf_ris<br>1'b0: Rx fifo overflow interrupt is not active prior to masking.<br>1'b1: Rx fifo overflow interrupt is active prior to masking.        |
| 2          | RO          | 0x0                | tx_done_ris<br>1'b0: Transmission finish interrupt is not active prior to masking.<br>1'b1: Transmission finish interrupt is active prior to masking. |
| 1          | RO          | 0x0                | tx_udf_ris<br>1'b0: Tx fifo underflow interrupt is not active prior to masking.<br>1'b1: Tx fifo underflow interrupt is active prior to masking.      |
| 0          | RO          | 0x0                | tx_ovf_ris<br>1'b0: Tx fifo overflow interrupt is not active prior to masking.<br>1'b1: Tx fifo overflow interrupt is active prior to masking.        |

**FLEXBUS ISR**

Address: Operational Base(0xFF880000) + offset (0x016C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 31:14      | RO          | 0x00000            | reserved                                                                                                                                     |
| 13         | RO          | 0x0                | dma_timeout_is<br>1'b0: DMA timeout interrupt is not active after masking.<br>1'b1: DMA timeout interrupt is active after masking.           |
| 12         | RO          | 0x0                | dma_err_is<br>1'b0: DMA error response interrupt is not active after masking.<br>1'b1: DMA error response interrupt is active after masking. |
| 11         | RO          | 0x0                | dma_dst1_is<br>1'b0: DMA write buffer1 interrupt is not active after masking.<br>1'b1: DMA write buffer1 interrupt is active after masking.  |
| 10         | RO          | 0x0                | dma_dst0_is<br>1'b0: DMA write buffer0 interrupt is not active after masking.<br>1'b1: DMA write buffer0 interrupt is active after masking.  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 9          | RO          | 0x0                | dma_src1_is<br>1'b0: DMA read buffer1 interrupt is not active after masking.<br>1'b1: DMA read buffer1 interrupt is active after masking.   |
| 8          | RO          | 0x0                | dma_src0_is<br>1'b0: DMA read buffer0 interrupt is not active after masking.<br>1'b1: DMA read buffer0 interrupt is active after masking.   |
| 7          | RO          | 0x0                | dvp_frame_start_is<br>1'b0: Frame start interrupt is not active after masking.<br>1'b1: Frame start interrupt is active after masking.      |
| 6          | RO          | 0x0                | dvp_frame_ab_is<br>1'b0: Frame abnormal interrupt is not active after masking.<br>1'b1: Frame abnormal interrupt is active after masking.   |
| 5          | RO          | 0x0                | rx_done_is<br>1'b0: Receive finish interrupt is not active after masking.<br>1'b1: Receive finish interrupt is active after masking.        |
| 4          | RO          | 0x0                | rx_udf_is<br>1'b0: Rxfifo underflow interrupt is not active after masking.<br>1'b1: Rxfifo underflow interrupt is active after masking.     |
| 3          | RO          | 0x0                | rx_ovf_is<br>1'b0: Rxfifo overflow interrupt is not active after masking.<br>1'b1: Rxfifo overflow interrupt is active after masking.       |
| 2          | RO          | 0x0                | tx_done_is<br>1'b0: Transmission finish interrupt is not active after masking.<br>1'b1: Transmission finish interrupt active after masking. |
| 1          | RO          | 0x0                | tx_udf_is<br>1'b0: Txfifo underflow interrupt is not active after masking.<br>1'b1: Txfifo underflow interrupt is active after masking.     |
| 0          | RO          | 0x0                | tx_ovf_is<br>1'b0: Txfifo overflow interrupt is not active after masking.<br>1'b1: Txfifo overflow interrupt is active after masking.       |

**FLEXBUS ICR**

Address: Operational Base(0xFF880000) + offset (0x0170)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                             |
|------------|-------------|--------------------|----------------------------------------------------------------|
| 31         | R/W SC      | 0x0                | cci<br>Write 1 to Clear Combined Interrupt.                    |
| 30:14      | RO          | 0x00000            | reserved                                                       |
| 13         | R/W SC      | 0x0                | ctimeout<br>Write 1 to clear DMA timeout interrupt.            |
| 12         | R/W SC      | 0x0                | cdma_err<br>Write 1 to clear DMA error response interrupt.     |
| 11         | R/W SC      | 0x0                | cdst1<br>Write 1 to clear DMA write buffer1 interrupt.         |
| 10         | R/W SC      | 0x0                | cdst0<br>Write 1 to clear DMA write buffer0 interrupt.         |
| 9          | R/W SC      | 0x0                | csrc1<br>Write 1 to clear DMA read buffer1 interrupt.          |
| 8          | R/W SC      | 0x0                | csrc0<br>Write 1 to clear DMA read buffer0 interrupt.          |
| 7          | R/W SC      | 0x0                | cframe_start<br>Write 1 to clear DVP frame start interrupt.    |
| 6          | R/W SC      | 0x0                | crx_dvp_frame_ab<br>Write 1 to clear frame abnormal interrupt. |
| 5          | R/W SC      | 0x0                | crx_done<br>Write 1 to clear receive finish interrupt.         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 4          | R/W<br>SC   | 0x0                | crx_udf<br>Write 1 to clear rxfifo underflow Interrupt.     |
| 3          | R/W<br>SC   | 0x0                | crx_ovf<br>Write 1 to clear rxfifo overflow Interrupt.      |
| 2          | R/W<br>SC   | 0x0                | ctx_done<br>Write 1 to clear transmission finish interrupt. |
| 1          | R/W<br>SC   | 0x0                | ctx_udf<br>Write 1 to clear txfifo underflow Interrupt.     |
| 0          | R/W<br>SC   | 0x0                | ctx_ovf<br>Write 1 to clear txfifo overflow Interrupt.      |

**FLEXBUS REVISION**

Address: Operational Base(0xFF880000) + offset (0x01F0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------|
| 31:16      | RO          | 0x010d             | revision<br>[31:24]: Large version number<br>[23:16]: Minor version number |
| 15:0       | RO          | 0x0844             | svn<br>SVN revision.                                                       |

**37.5 Interface Description**

Table 37-2 Flexbus Interface Description

| <b>Module Pin</b> | <b>Direction</b> | <b>Pin Name</b> | <b>IOMUX Setting</b>                        |
|-------------------|------------------|-----------------|---------------------------------------------|
| flexbus0_clk      | O                | GPIO1_C1        | GPIO1_IOC_GPIO1C_IOMUX_S<br>EL_0[7:4]=0x3   |
| flexbus0_csn_m0   | O                | GPIO1_B0        | GPIO1_IOC_GPIO1B_IOMUX_S<br>EL_0[3:0]=0x5   |
| flexbus0_csn_m1   | O                | GPIO1_B2        | GPIO1_IOC_GPIO1B_IOMUX_S<br>EL_0[11:8]=0x5  |
| flexbus0_csn_m2   | O                | GPIO1_B4        | GPIO1_IOC_GPIO1B_IOMUX_S<br>EL_1[3:0]=0x5   |
| flexbus0_csn_m3   | O                | GPIO1_B6        | GPIO1_IOC_GPIO1B_IOMUX_S<br>EL_1[11:8]=0x5  |
| flexbus0_csn_m4   | O                | GPIO1_C0        | GPIO1_IOC_GPIO1C_IOMUX_S<br>EL_0[3:0]=0x5   |
| flexbus0_csn_m5   | O                | GPIO1_C2        | GPIO1_IOC_GPIO1C_IOMUX_S<br>EL_0[11:8]=0x5  |
| flexbus0_d0       | I/O              | GPIO1_D3        | GPIO1_IOC_GPIO1D_IOMUX_S<br>EL_0[15:12]=0x3 |
| flexbus0_d1       | I/O              | GPIO1_D2        | GPIO1_IOC_GPIO1D_IOMUX_S<br>EL_0[11:8]=0x3  |
| flexbus0_d2       | I/O              | GPIO1_D1        | GPIO1_IOC_GPIO1D_IOMUX_S<br>EL_0[7:4]=0x3   |
| flexbus0_d3       | I/O              | GPIO1_D0        | GPIO1_IOC_GPIO1D_IOMUX_S<br>EL_0[3:0]=0x3   |
| flexbus0_d4       | I/O              | GPIO1_C7        | GPIO1_IOC_GPIO1C_IOMUX_S<br>EL_1[15:12]=0x3 |

| <b>Module Pin</b> | <b>Direction</b> | <b>Pin Name</b> | <b>IOMUX Setting</b>                        |
|-------------------|------------------|-----------------|---------------------------------------------|
| flexbus0_d5       | I/O              | GPIO1_C6        | GPIO1_IOC_GPIO1C_IOMUX_S<br>EL_1[11:8]=0x3  |
| flexbus0_d6       | I/O              | GPIO1_C5        | GPIO1_IOC_GPIO1C_IOMUX_S<br>EL_1[7:4]=0x3   |
| flexbus0_d7       | I/O              | GPIO1_C4        | GPIO1_IOC_GPIO1C_IOMUX_S<br>EL_1[3:0]=0x3   |
| flexbus0_d8       | I/O              | GPIO1_C3        | GPIO1_IOC_GPIO1C_IOMUX_S<br>EL_0[15:12]=0x3 |
| flexbus0_d9       | I/O              | GPIO1_C2        | GPIO1_IOC_GPIO1C_IOMUX_S<br>EL_0[11:8]=0x3  |
| flexbus0_d10      | I/O              | GPIO1_B7        | GPIO1_IOC_GPIO1B_IOMUX_S<br>EL_1[15:12]=0x4 |
| flexbus0_d11      | I/O              | GPIO1_B6        | GPIO1_IOC_GPIO1B_IOMUX_S<br>EL_1[11:8]=0x4  |
| flexbus0_d12      | I/O              | GPIO1_B5        | GPIO1_IOC_GPIO1B_IOMUX_S<br>EL_1[7:4]=0x4   |
| flexbus0_d13      | I/O              | GPIO1_B4        | GPIO1_IOC_GPIO1B_IOMUX_S<br>EL_1[3:0]=0x4   |
| flexbus0_d14      | I/O              | GPIO1_B3        | GPIO1_IOC_GPIO1B_IOMUX_S<br>EL_0[15:12]=0x4 |
| flexbus0_d15      | I/O              | GPIO1_B2        | GPIO1_IOC_GPIO1B_IOMUX_S<br>EL_0[11:8]=0x4  |
| flexbus1_clk      | I/O              | GPIO1_C0        | GPIO1_IOC_GPIO1C_IOMUX_S<br>EL_0[3:0]=0x3   |
| flexbus1_csn_m0   | O                | GPIO1_B1        | GPIO1_IOC_GPIO1B_IOMUX_S<br>EL_0[7:4]=0x5   |
| flexbus1_csn_m1   | O                | GPIO1_B3        | GPIO1_IOC_GPIO1B_IOMUX_S<br>EL_0[15:12]=0x5 |
| flexbus1_csn_m2   | O                | GPIO1_B5        | GPIO1_IOC_GPIO1B_IOMUX_S<br>EL_1[7:4]=0x5   |
| flexbus1_csn_m3   | O                | GPIO1_B7        | GPIO1_IOC_GPIO1B_IOMUX_S<br>EL_1[15:12]=0x5 |
| flexbus1_csn_m4   | O                | GPIO1_C1        | GPIO1_IOC_GPIO1C_IOMUX_S<br>EL_0[7:4]=0x5   |
| flexbus1_csn_m5   | O                | GPIO1_C3        | GPIO1_IOC_GPIO1C_IOMUX_S<br>EL_0[15:12]=0x5 |
| flexbus1_d0       | I                | GPIO1_A0        | GPIO1_IOC_GPIO1A_IOMUX_S<br>EL_0[3:0]=0x3   |
| flexbus1_d1       | I                | GPIO1_A1        | GPIO1_IOC_GPIO1A_IOMUX_S<br>EL_0[7:4]=0x3   |
| flexbus1_d2       | I                | GPIO1_A2        | GPIO1_IOC_GPIO1A_IOMUX_S<br>EL_0[11:8]=0x3  |
| flexbus1_d3       | I                | GPIO1_A3        | GPIO1_IOC_GPIO1A_IOMUX_S<br>EL_0[15:12]=0x3 |

| Module Pin   | Direction | Pin Name | IOMUX Setting                               |
|--------------|-----------|----------|---------------------------------------------|
| flexbus1_d4  | I         | GPIO1_A4 | GPIO1_IOC_GPIO1A_IOMUX_S<br>EL_1[3:0]=0x3   |
| flexbus1_d5  | I         | GPIO1_A5 | GPIO1_IOC_GPIO1A_IOMUX_S<br>EL_1[7:4]=0x3   |
| flexbus1_d6  | I         | GPIO1_A6 | GPIO1_IOC_GPIO1A_IOMUX_S<br>EL_1[11:8]=0x3  |
| flexbus1_d7  | I         | GPIO1_A7 | GPIO1_IOC_GPIO1A_IOMUX_S<br>EL_1[15:12]=0x3 |
| flexbus1_d8  | I         | GPIO1_B0 | GPIO1_IOC_GPIO1B_IOMUX_S<br>EL_0[3:0]=0x3   |
| flexbus1_d9  | I         | GPIO1_B1 | GPIO1_IOC_GPIO1B_IOMUX_S<br>EL_0[7:4]=0x3   |
| flexbus1_d10 | I         | GPIO1_B2 | GPIO1_IOC_GPIO1B_IOMUX_S<br>EL_0[11:8]=0x3  |
| flexbus1_d11 | I         | GPIO1_B3 | GPIO1_IOC_GPIO1B_IOMUX_S<br>EL_0[15:12]=0x3 |
| flexbus1_d12 | I         | GPIO1_B4 | GPIO1_IOC_GPIO1B_IOMUX_S<br>EL_1[3:0]=0x3   |
| flexbus1_d13 | I         | GPIO1_B5 | GPIO1_IOC_GPIO1B_IOMUX_S<br>EL_1[7:4]=0x3   |
| flexbus1_d14 | I         | GPIO1_B6 | GPIO1_IOC_GPIO1B_IOMUX_S<br>EL_1[11:8]=0x3  |
| flexbus1_d15 | I         | GPIO1_B7 | GPIO1_IOC_GPIO1B_IOMUX_S<br>EL_1[15:12]=0x3 |

Notes: I=Input, O=Output, I/O=Input/Output, bidirectional.

## 37.6 Application Notes

### Clock Ratios

The frequency of PAD is half of FlexBUS operation clock. When FlexBUS operation clock is 200MHz, the frequency of flexbus0\_clk and flexbus1\_clk is 100MHz.

### FSPI Transfer Flow

If want to support FSPI feature, the configuration is showing as below:

- A. Set GRF\_SOC\_CON1[1]=1 to as master; set modes, transmit then receive, FLEXBUS\_COM\_CTL[3:0]=4'hf;
- B. Set RX CLK dummy counter, FLEXBUS\_RXCLK\_DUMMY;
- C. Set Interrupt mask, FLEXBUS\_IMR;
- D. Set format of transmit data, FLEXBUS\_TX\_CTL;
- E. Set tx start water line, FLEXBUS\_TXWAT\_START;
- F. Set tx length, FLEXBUS\_TX\_NUM;
- G. Set format of receive data, FLEXBUS\_RX\_CTL;
- H. Set rx length, FLEXBUS\_RX\_NUM;
- I. Set DMA,FLEXBUS\_DMA\_SRC\_ADDR0/DST\_ADDR0/SRC\_LEN0/DST\_LEN0;
- J. Set FlexBUS enable, FLEXBUS\_ENR[1:0]=2'b11;  
Wait Interrupt and clear interrupt;  
Final, disable FlexBUS.

### ADC with Sync CLKIN Transfer Flow

- A. Set GRF\_SOC\_CON1[1] based on ADC interface timing and set GRF\_SOC\_CON1[1]=0 to

- as slave;
- B. Set modes, rx only mode, FLEXBUS\_COM\_CTL[3:0]=4'h2;
  - C. Set Interrupt mask, FLEXBUS\_IMR;
  - D. Set format of receive data, FLEXBUS\_RX\_CTL[4]=1, data frame configuration according to actual usage;
  - E. Set FLEXBUS\_SLAVE\_MODE=2'b01;
  - F. Set DMA;
  - G. Set FlexBUS enable, FLEXBUS\_ENR[1]=1'b1;
  - H. Wait interrupt, if dma\_dst0 is active indicating that buffer0 has finished and clear interrupt, FlexBUS can set new buffer0 address. FlexBUS will automatically jump to buffer1 address and capture new data; If don't want to receive data, set FLEXBUS\_STOP[1]=1, and then disable FlexBUS;
  - I. Wait interrupt, if dma\_dst1 is active indicating that buffer1 has finished and clear interrupt, FlexBUS can set new buffer1 address. FlexBUS will automatically jump to buffer0 address and capture new data; If don't want to receive new data, Set FLEXBUS\_STOP[1]=1, and then disable FlexBUS;
  - J. If want to stop receiving data , set FlexBUS.STOP[1]=1 at any time and wait rx\_done interrupt; final disable FlexBUS;
  - K. If want to continue to receive data, repeat H-I.

### **ADC without CLKIN Transfer Flow**

- A. Set GRF\_SOC\_CON1[1]=1;
- B. Set modes, rx only mode, FLEXBUS\_COM\_CTL[3:0]=4'h2;
- C. Set Interrupt mask, FLEXBUS\_IMR;
- D. Set format of receive data, FLEXBUS\_RX\_CTL[4]=1, data frame configuration according to actual usage;
- E. Set DMA;
- F. Set FlexBUS enable, FLEXBUS\_ENR[1]=1'b1;
- G. Wait interrupt, if dma\_dst0 is active indicating that buffer0 has finished and clear interrupt, FlexBUS can set new buffer0 address. FlexBUS will automatically jump to buffer1 address and capture new data; If don't want to receive data, set FLEXBUS\_STOP[1]=1, and then disable FlexBUS;
- H. Wait interrupt, if dma\_dst1 is active indicating that buffer1 has finished and clear interrupt, FlexBUS can set new buffer1 address. FlexBUS will automatically jump to buffer0 address and capture new data; If don't want to receive new data, Set FLEXBUS\_STOP[1]=1, and then disable FlexBUS;
- I. If want to stop receiving data , set FlexBUS.STOP[1]=1 at any time and wait rx\_done interrupt; final disable FlexBUS;
- J. If want to continue to receive data, repeat G-H-I.

### **DAC Transfer Flow**

If want to support DAC feature, the configuration is showing as below:

- A. Set modes, tx only, FLEXBUS\_COM\_CTL[3:0]=4'h1;
- B. Set Interrupt mask, FLEXBUS\_IMR;
- C. Set format of transmit data, FLEXBUS\_TX\_CTL and continue\_mode =1;
- D. Set tx start water line, FLEXBUS\_TXWAT\_START;
- E. Set DMA;
- F. Set FlexBUS enable, FLEXBUS\_ENR[1:0]=2'b01;
- G. Wait interrupt, if dma\_src0 is active indicating that buffer0 has finished and clear interrupt, FlexBUS can set new buffer0 address. FlexBUS will automatically jump to buffer1 address and send new data; If don't want to send data, set FLEXBUS\_STOP[0]=1, and then disable FlexBUS;
- H. Wait interrupt, if dma\_src1 is active indicating that buffer1 has finished and clear interrupt, FlexBUS can set new buffer1 address. FlexBUS will automatically jump to buffer0 address and send new data; If don't want to send new data, Set FLEXBUS\_STOP[0]=1, and then disable FlexBUS;
- I. If want to stop sending data , set FlexBUS.STOP[0]=1 at any time and wait tx\_done

interrupt; final disable FlexBUS;

J. If want to continue to receive data, repeat G-H-I.

**DVP Mode Transfer Flow**

- A. Set GRF\_SOC\_CON1[1] based on cif interface timing and set GRF\_SOC\_CON1[1]=0 to as slave;
- B. Set modes, rx only mode, FLEXBUS\_COM\_CTL[3:0]=4'h2;
- C. Set Interrupt mask, FLEXBUS\_IMR;
- D. Set format of receive data, FLEXBUS\_RX\_CTL.rx\_data\_width=2 and rx\_continue\_mode=1;
- E. Set FLEXBUS\_SLAVE\_MODE=2'b11;
- F. Set FLEXBUS\_DVP\_CROP\_SIZE, if want to support cropping function, need to Set FLEXBUS\_DVP\_CROP\_START.
- G. Set FLEXBUS\_DVP\_POL based on CIF interface of VSYNC and HREF;
- H. Set FLEXBUS\_DVP\_ORDER and DMA, FLEXBUS\_DMA\_DST\_ADD0/1, used to ping-pong operation;
- I. Set FlexBUS enable, FLEXBUS\_ENR[1]=1'b1;
- J. Wait interrupt, if dma\_dst0 is active indicating that a frame has finished and clear interrupt, FlexBUS can set new buffer0 address. FlexBUS will automatically jump to buffer1 address and capture new frame; If dvp\_frame\_ab is active, need to clear interrupt and FlexBUS will automatically continue to capture the next frame using buffer0 address; If don't want to receive new frame, Set FLEXBUS\_STOP[1]=1, and then disable FlexBUS;
- K. Wait interrupt, if dma\_dst1 is active indicating that a frame has finished and clear interrupt, FlexBUS can set new buffer1 address. FlexBUS will automatically jump to buffer0 address and capture new frame; If dvp\_frame\_ab is active, need to clear interrupt and FlexBUS will automatically continue to capture the next frame using buffer1 address; If don't want to receive new frame, Set FLEXBUS\_STOP[1]=1, and then disable FlexBUS;
- L. If want to receive new frame pixel, repeat J-K.

**QSPI Transfer Flow**

If want to support QSPI feature, the configuration is showing as below:

- A. Set modes, tx only, FLEXBUS\_COM\_CTL[3:0]=4'h1;
- B. Set Interrupt mask, FLEXBUS\_IMR;
- C. Set format of transmit data, FLEXBUS\_TX\_CTL.mult\_line =1;
- D. Set tx start water line, FLEXBUS\_TXWAT\_START;
- E. Set the length of data and command, FLEXBUS\_TX\_NUM, FLEXBUS\_TX\_CMD0/1, FLEXBUS\_TX\_CMD\_WIDTH, FLEXBUS\_TX\_CSN\_DUMMY, FLEXBUS\_TX\_WIDTH;
- F. Set DMA configuration;
- G. Set FlexBUS enable, FLEXBUS\_ENR[0]=1'b1;
- H. Wait tx\_done interrupt and clear interrupt, disable FlexBUS.

# Chapter 38 MAC Ethernet Interface (MAC)

## 38.1 Overview

The Ethernet Quality-of-Service controller (EQOS is commonly referred to as MAC in this document) provides a complete Ethernet interface from processor to a Reduced Media Independent Interface (RMII) compliant Ethernet PHY. The MAC includes a DMA controller. The DMA controller efficiently moves packet data from microprocessor's RAM, formats the data for an IEEE 802.3-2002 compliant packet and transmits the data to an Ethernet Physical Interface (PHY). It also efficiently moves packet data from RXFIFO to microprocessor's RAM.

The following features may or may not be present in the actual product. Please contact Rockchip for the actual feature configurations and the third-party licensing requirements.

### 38.1.1 MAC Features

#### 38.1.1.1 MAC Tx and Rx Common Features

- Supports 10/100-Mbps data transfer rates with the RMII interfaces
- Half-duplex operation:
  - CSMA/CD Protocol support
  - Flow control using back-pressure support (based on implementation-specific white papers and UNH Ethernet Clause 4 MAC Test Suite - Annex D)
- 64-bit data transfer interface on the application side
- Full-duplex flow control operations (IEEE 802.3x Pause packets and Priority flow control)
- network statistics with RMON or MIB Counters (RFC2819/RFC2665)
- Media clock generation and recovery
- MDIO (Clause 22 and Clause 45) master interface for PHY device configuration and management

#### 38.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 Inter Packet Gap (40–96 bit times in steps of 8)
- IEEE 802.3x Flow Control automatic transmission of zero-quanta Pause packet when flow control input transitions from assertion to de-assertion (in full-duplex mode)
- Source Address field insertion or replacement, and VLAN insertion, replacement, and deletion in transmitted packets with per-packet or static-global control
- Insertion, replacement, or deletion of up to two VLAN tags
- Frame Preemption for MAC Tx

#### 38.1.1.3 MAC Rx Features

- Automatic Pad and CRC Stripping options
- Option to disable Automatic CRC checking
- Preamble and SFD deletion
- Separate 112-bit or 128-bit status
- Programmable watchdog timeout limit
- Flexible address filtering modes:
  - Up to 31 additional 48-bit perfect (DA) address filters with masks for each byte
  - Up to 96 additional 48-bit perfect (DA) address filters that can be selected in blocks of 32 and 64 registers
  - Up to 31 48-bit SA address comparison check with masks for each byte
  - 32 bit, 64 bit, 128 bit, or 256 bit Hash filter (optional) for multicast and unicast (DA) addresses
  - Option to pass all multi-cast addressed packets
  - Promiscuous mode to pass all packets without any filtering for network monitoring
  - Pass all incoming packets (as per filter) with a status report

- Additional packet filtering:
  - VLAN tag-based: Perfect match and Hash-based (optional) filtering. Filtering based on either outer or inner VLAN tag is possible
  - Layer 3 and Layer 4-based: TCP or UDP over IPv4 or IPv6
  - Extended VLAN tag based filtering 4, 8, 16, or 32 filter selection
- IEEE 802.1Q VLAN tag detection and option to delete the VLAN tags in received packets
- Optional module to detect remote wake-up packets and AMD magic packets
- Optional forwarding of received Pause packets to the application (in full-duplex mode)
- Frame Preemption for MAC Rx

### **38.1.2 MTL Features**

#### **38.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)

#### **38.1.2.2 MTL Tx Features**

- TX FIFO sizes on transmission is 4 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 re-transmission of collision packets in half-duplex mode
- Discard packets on late collision, excessive collisions, excessive deferral, and under-run conditions with appropriate status
- Disabling of Data Memory RAM chip-select when inactive to reduce power consumption
- Optional module to calculate and insert IPv4 header checksum and TCP, UDP, or ICMP checksum
- Programmable interrupt options for different operational conditions
- Statistics by generating pulses for packets dropped (because of underflow) in the Tx FIFO
- Optional packet-level control for
  - VLAN tag insertion or replacement
  - Ethernet source address insertion
  - Layer3/Layer4 Checksum insertion control
  - Timestamp control
  - CRC and pad control

#### **38.1.2.3 MTL Rx Features**

- Rx queue sizes in the Receive path is 8 KB
- Insertion of Rx Status vectors into the Rx queue after the EOP transfer (in Threshold mode) and before SOP (in Store-and-Forward mode) in EQOS-MTL configuration
- Programmable Rx queue threshold (default fixed at 64 bytes) in Threshold (or cut-through) mode
- Option to filter all error packets on reception and not forward them to the application in the store-and-forward mode
- Option to forward the undersized good packets
- Statistics by generating pulses for packets dropped (because of overflow) in the Rx

**FIFO**

- Automatic generation of Pause packet control or backpressure signal to the MAC based on the Rx Queue fill level
- Arbitration among queues when multiple queues are present. The following arbitration schemes are supported:
  - Weighted Round Robin (WRR)
  - Weighted Strict priority (WSP)
  - Strict Priority (SP)
- Option to replicate received multicast packets for transfer by multiple Rx DMA channels
- Option to have a programmable lookup table based flexible Parser for filtering and steering the Rx packets

**38.1.3 DMA Block Features**

- 64-bit data transfers
- Separate DMA channel in the Transmit path for each queue in MTL
- Single or multiple DMA channels for any number of queues in MTL Receive path
- Fully synchronous design operating on a single application clock (except for CSR module, when a separate CSR clock is configured)
- Optimization for packet-oriented DMA transfers with packet delimiters
- Byte-aligned addressing for data buffer support
- Dual-buffer (ring) descriptor support
- Descriptor architecture to allow large blocks of data transfer with minimum CPU intervention (each descriptor can transfer up to 32 KB of data)
- Comprehensive status reporting for normal operation and transfers with errors
- Individual programmable burst length for Tx DMA and Rx DMA engines for optimal host bus utilization
- Programmable interrupt options for different operational conditions
- Per-packet Transmit or Receive Complete Interrupt control
- Round-robin or fixed-priority arbitration between the Receive and Transmit engines
- Start and Stop modes
- Separate ports for host CSR access and host data interface
- support for TCP Segmentation Offload (TSO) and UDP Segmentation Offload (USO)
- Selectable number of Tx DMA channels with TSO/USO feature enabled
- Routing of received packets to the DMA channels based on the DA or VLAN Priority in multi-channel DMA configurations
- Option to split the packet header (Layer 3 and Layer 4) and payload in a different buffers
- Programmable control for Transmit Descriptor posted writes to improve the throughput
- Sideband signals to control starting and stopping of DMA channels

## 38.2 Block Diagram



Fig. 38-1 MAC Block Diagram

The MAC is broken up into multiple separate functional units. These blocks are interconnected in the MAC module. The block diagram shows the general flow of data and control signals between these blocks.

The MAC transfers data to system memory through the AXI master interface. The host CPU uses the APB Slave interface to access the MAC subsystem's control and status registers (CSRs).

The MAC only supports the PHY interfaces of reduced MII (RMII).

The Transmit FIFO (Tx FIFO) buffers data read from system memory by the DMA before transmission by the MAC Core. Similarly, the Receive FIFO (Rx FIFO) stores the Ethernet frames received from the line until they are transferred to system memory by the DMA. These are asynchronous FIFOs, as they also transfer the data between the application clock and the MAC line clocks.



Fig. 38-2 MAC in SOC

MAC Supports 10/100-Mbps data transfer rates with the RMII interfaces.

## 38.3 Function Description

### 38.3.1 Frame Structure

Data frames transmitted shall have the frame format shown in figure below.



Fig. 38-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.

#### 38.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 MAC and the PHY. This helps translation of the MAC's MII into the RMII. The RMII block has the following characteristics:

Supports 10-Mbps and 100-Mbps operating rates. It does not support 1000-Mbps operation. Two clock references are sourced externally or CRU, providing independent, 2-bit wide transmit and receive paths.

#### 38.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. 38-4 RMII Transmission Bit Ordering

#### 38.3.1.3 RMII Transmit Timing Diagrams

The follow figures 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. 38-5 Start of MII and RMII Transmission in 100-Mbps Mode



Fig. 38-6 End of MII and RMII Transmission in 100-Mbps Mode



Fig. 38-7 Start of MII and RMII Transmission in 10-Mbps Mode



Fig. 38-8 End of MII and RMII Transmission in 10-Mbps Mode

### 38.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 figure below. The lower order bits (D0 and D1) are received first, followed by the higher order bits (D2 and D3).



Fig. 38-9 RMII Receive Bit Ordering

### 38.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 MAC 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 38-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</li> </ul> Where Z is the tri-state level                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 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 MAC 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 38-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</li></ul> Where Z is the tri-state level |
| DATA/ADDRESS | Any 16-bit value: <ul style="list-style-type: none"><li>■ In a write operation, the MAC 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.

### 38.3.3 TCP/IP Segmentation Offload (TSO) Engine

The TCP Segmentation Offload (TSO) engine is useful in offloading the TCP segmentation functions to the hardware.

It also supports UDP Segmentation Offload (USO) in which the UDP payload is segmented in the hardware. There are no sequencing/ordering controls available or updated in the segments, so it can be used in point to point applications in which out of order packets are not expected by the receiver. The description and flow of TSO mentioned in this section is same as USO, any deviation is provided as notes.

In the TCP segmentation offload (TSO) feature, the DMA splits a large TCP packet into multiple small packets and passes these packets to the MTL Tx Queue.

### 38.3.4 MAC Management Counters

The MAC 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.

## 38.4 Register Description

### 38.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

**Operational Base**

| Name | Base Address |
|------|--------------|
| MAC0 | 0xFF4C8000   |
| MAC1 | 0xFF4D0000   |

### 38.4.2 Registers Summary

| Name                              | Offset | Size | Reset Value | Description                                                                                                                                      |
|-----------------------------------|--------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>GMAC_MAC_CONFIGURATION</u>     | 0x0000 | W    | 0x00008000  | 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_VLAN_HASH_TABLE</u>   | 0x0058 | W    | 0x00000000  | When VTHM bit of the MAC_VLAN_Tag register is set, the 16-bit VLAN Hash Table register is used for group address filtering based on the VLAN tag |
| <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                                                                                  |
| <u>GMAC_MAC_INTERRUPT_ENABLE</u>  | 0x00B4 | W    | 0x00000000  | The Interrupt Enable Register contains the masks for generating the interrupts                                                                   |

| Name                               | Offset | Size | Reset Value | Description                                                                                                                                                                                                                                                                |
|------------------------------------|--------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>GMAC_MAC_RX_TX_STATUS</u>       | 0x00B8 | W    | 0x00000000  | The Receive Transmit Status Register contains the Receive and Transmit Error status                                                                                                                                                                                        |
| <u>GMAC_MAC_PMT_CONTROL_STATUS</u> | 0x00C0 | W    | 0x00000000  | The PMT Control and Status Register                                                                                                                                                                                                                                        |
| <u>GMAC_MAC_RWK_PACKET_FILTER</u>  | 0x00C4 | W    | 0x00000000  | The Remote Wakeup Filter Registers are implemented as 8, 16, or 32 indirect access registers (wkuppktfilter_reg#i) based on whether 4, 8, or 16 Remote Wakeup Filters are selected in the configuration and accessed by application through MAC_RWK_Packet_Filter register |
| <u>GMAC_RWK_FILTER0_BYTEMASK</u>   | 0x00C4 | W    | 0x00000000  | RWK Filter0 Byte Mask                                                                                                                                                                                                                                                      |
| <u>GMAC_RWK_FILTER1_BYTEMASK</u>   | 0x00C4 | W    | 0x00000000  | RWK Filter1 Byte Mask                                                                                                                                                                                                                                                      |
| <u>GMAC_RWK_FILTER2_BYTEMASK</u>   | 0x00C4 | W    | 0x00000000  | RWK Filter2 Byte Mask                                                                                                                                                                                                                                                      |
| <u>GMAC_RWK_FILTER3_BYTEMASK</u>   | 0x00C4 | W    | 0x00000000  | RWK Filter3 Byte Mask                                                                                                                                                                                                                                                      |
| <u>GMAC_RWK_FILTER01_CRC</u>       | 0x00C4 | W    | 0x00000000  | RWK Filter 0/1 CRC-16                                                                                                                                                                                                                                                      |
| <u>GMAC_RWK_FILTER23_CRC</u>       | 0x00C4 | W    | 0x00000000  | RWK Filter 2/3 CRC-16                                                                                                                                                                                                                                                      |
| <u>GMAC_RWK_FILTER_OFFSET</u>      | 0x00C4 | W    | 0x00000000  | RWK Filter Offset                                                                                                                                                                                                                                                          |
| <u>GMAC_RWK_FILTER_COMMAND</u>     | 0x00C4 | W    | 0x00000000  | RWK Filter Command                                                                                                                                                                                                                                                         |
| <u>GMAC_MAC_VERSION</u>            | 0x0110 | W    | 0x00003051  | The Version Register identifies the version of the DWC_ether_qos                                                                                                                                                                                                           |
| <u>GMAC_MAC_DEBUG</u>              | 0x0114 | W    | 0x00000000  | The Debug Register provides the debug status of various MAC blocks                                                                                                                                                                                                         |
| <u>GMAC_MAC_HW_FEATURE_0</u>       | 0x011C | W    | 0x400113E1  | This register indicates the presence of first set of the optional features or functions                                                                                                                                                                                    |
| <u>GMAC_MAC_HW_FEATURE_1</u>       | 0x0120 | W    | 0x010E4166  | This register indicates the presence of second set of the optional features or functions                                                                                                                                                                                   |
| <u>GMAC_MAC_HW_FEATURE_2</u>       | 0x0124 | W    | 0x11000000  | This register indicates the presence of third set of the optional features or functions                                                                                                                                                                                    |
| <u>GMAC_MAC_HW_FEATURE_3</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                                                                                                                                                                    |

| Name                         | Offset | Size | Reset Value | Description                                                                                                                                   |
|------------------------------|--------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| GMAC_MAC_MDIO_DATA           | 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           |
| GMAC_MAC_ARP_ADDRESS         | 0x0210 | W    | 0x00000000  | The ARP Address Register contains the IPv4 Destination Address of the MAC                                                                     |
| GMAC_MAC_CSR_SW_CTL          | 0x0230 | W    | 0x00000000  | This register contains SW programmable controls for changing the CSR access response and status bits clearing                                 |
| GMAC_MAC_EXT_CFG1            | 0x0238 | W    | 0x00000002  | This register contains Split mode control field and offset field for Split Header feature                                                     |
| GMAC_MAC_ADDRESS0_HIGH       | 0x0300 | W    | 0x0000FFFF  | The MAC Address0 High Register holds the upper 16 bits of the first 6-byte MAC address of the station                                         |
| GMAC_MAC_ADDRESS0_LOW        | 0x0304 | W    | 0xFFFFFFFF  | The MAC Address0 Low Register holds the lower 32 bits of the 6-byte first MAC address of the station                                          |
| GMAC_MMICONTROL              | 0x0700 | W    | 0x00000000  | This register establishes the operating mode of MMC                                                                                           |
| GMAC_MMICRINTERRUPT          | 0x0704 | W    | 0x00000000  | This register maintains the interrupts generated from all Receive statistics counters                                                         |
| GMAC_MMITXINTERRUPT          | 0x0708 | W    | 0x00000000  | This register maintains the interrupts generated from all Transmit statistics counters                                                        |
| GMAC_MMICRINTERRUPTMASK      | 0x070C | W    | 0x00000000  | This register maintains the masks for interrupts generated from all Receive statistics counters                                               |
| GMAC_MMITXINTERRUPTMASK      | 0x0710 | W    | 0x00000000  | This register maintains the masks for interrupts generated from all Transmit statistics counters                                              |
| GMAC_TX_OCTETCOUNT_GOOD_BAD  | 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 |
| GMAC_TXPACKETCOUNT_GOOD_BAD  | 0x0718 | W    | 0x00000000  | This register provides the number of good and bad packets, exclusive of retried packets                                                       |
| GMAC_TXUNDERFLOWERRORPACKETS | 0x0748 | W    | 0x00000000  | This register provides the number of packets aborted because of packets underflow error                                                       |
| GMAC_TXCARRIERERRPACKETS     | 0x0760 | W    | 0x00000000  | This register provides the number of packets aborted because of carrier sense error (no carrier or loss of carrier)                           |
| GMAC_TX_OCTETCOUNT_GOOD      | 0x0764 | W    | 0x00000000  | This register provides the number of bytes exclusive of preamble, only in good packets                                                        |

| Name                             | Offset | Size | Reset Value | Description                                                                                                                                                                    |
|----------------------------------|--------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GMAC TX PACKET COUNT GOOD        | 0x0768 | W    | 0x00000000  | This register provides the number of good packets transmitted by DWC_ether_qos                                                                                                 |
| GMAC TX PAUSE PACKETS            | 0x0770 | W    | 0x00000000  | This register provides the number of good Pause packets by DWC_ether_qos                                                                                                       |
| GMAC RX PACKETS COUNT GOOD BAD   | 0x0780 | W    | 0x00000000  | This register provides the number of good and bad packets received by DWC_ether_qos                                                                                            |
| GMAC RX OCTET COUNT GOOD BAD     | 0x0784 | W    | 0x00000000  | This register provides the number of bytes received by DWC_ether_qos, exclusive of preamble, in good and bad packets                                                           |
| GMAC RX OCTET COUNT GOOD         | 0x0788 | W    | 0x00000000  | This register provides the number of bytes received by DWC_ether_qos, exclusive of preamble, only in good packets                                                              |
| GMAC RX MULTICAST PACKETS GOOD   | 0x0790 | W    | 0x00000000  | This register provides the number of good multicast packets received by DWC_ether_qos                                                                                          |
| GMAC RX CRC ERROR PACKETS        | 0x0794 | W    | 0x00000000  | This register provides the number of packets received by DWC_ether_qos with CRC error                                                                                          |
| GMAC RX LENGTH ERROR PACKETS     | 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 |
| GMAC RX PAUSE PACKETS            | 0x07D0 | W    | 0x00000000  | This register provides the number of good and valid Pause packets received by DWC_ether_qos                                                                                    |
| GMAC RX FIFO OVERFLOW PACKETS    | 0x07D4 | W    | 0x00000000  | This register provides the number of missed received packets because of FIFO overflow                                                                                          |
| GMAC MMC IPC RX INT ERRUPT MASK  | 0x0800 | W    | 0x00000000  | This register maintains the mask for the interrupt generated from the receive IPC statistic counters                                                                           |
| GMAC MMC IPC RX INT ERRUPT       | 0x0808 | W    | 0x00000000  | This register maintains the interrupt that the receive IPC statistic counters generate                                                                                         |
| GMAC RXIPV4 GOOD PACKETS         | 0x0810 | W    | 0x00000000  | This register provides the number of good IPv4 datagrams received by DWC_ether_qos with the TCP, UDP, or ICMP payload                                                          |
| GMAC RXIPV4 HEADER ERROR PACKETS | 0x0814 | W    | 0x00000000  | This register provides the number of IPv4 datagrams received by DWC_ether_qos with header (checksum, length, or version mismatch) errors                                       |
| GMAC RXIPV6 GOOD PACKETS         | 0x0824 | W    | 0x00000000  | This register provides the number of good IPv6 datagrams received by DWC_ether_qos                                                                                             |

| Name                                    | Offset | Size | Reset Value | Description                                                                                                                                         |
|-----------------------------------------|--------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| <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                                      |
| <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    | 0x00000000  | 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  | This register 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 |

| Name                                 | Offset | Size | Reset Value | Description                                                                                                                                                              |
|--------------------------------------|--------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <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                                                         |
| <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                                                                                                                              |

| Name                              | Offset | Size | Reset Value | Description                                                                                                                                                                                                                        |
|-----------------------------------|--------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GMAC_MAC_TS_EGRESS_LATENCY        | 0x0B6C | W    | 0x00000000  | This register holds the Egress MAC latency                                                                                                                                                                                         |
| GMAC_MAC_PPS_CONTROL              | 0x0B70 | W    | 0x00000000  | PPS Control Register                                                                                                                                                                                                               |
| GMAC_MAC_PPS0_TARGET_TIME_SECONDS | 0x0B80 | W    | 0x00000000  | The PPS Target Time Seconds Register, along with PPS Target Time Nanoseconds Register, is used to schedule an interrupt event [Bit 1 of MAC_Timestamp_Status] when the system time exceeds the value programmed in these registers |
| GMAC_MAC_PPS0_TARGET_NS           | 0x0B84 | W    | 0x00000000  | PPS0 Target Time Nanoseconds Register                                                                                                                                                                                              |
| GMAC_MAC_PPS0_INTERVAL            | 0x0B88 | W    | 0x00000000  | The PPS0 Interval Register contains the number of units of sub-second increment value between the rising edges of PPS0 signal output (ptp_pps_o[0])                                                                                |
| GMAC_MAC_PPS0_WIDTH               | 0x0B8C | W    | 0x00000000  | The PPS0 Width Register contains the number of units of sub-second increment value                                                                                                                                                 |
| GMAC_MTL_OPERATION_MODE           | 0x0C00 | W    | 0x00000000  | The Operation Mode Register establishes the Transmit and Receive operating modes and commands                                                                                                                                      |
| GMAC_MTL_DBG_CTL                  | 0x0C08 | W    | 0x00000000  | The FIFO Debug Access Control and Status Register controls the operation mode of FIFO debug access                                                                                                                                 |
| GMAC_MTL_DBG_STS                  | 0x0C0C | W    | 0x01000000  | The FIFO Debug Status Register contains the status of FIFO debug access                                                                                                                                                            |
| GMAC_MTL_FIFO_DEBUG_DATA          | 0x0C10 | W    | 0x00000000  | The FIFO Debug Data Register contains the data to be written to or read from the FIFOs                                                                                                                                             |
| GMAC_MTL_INTERRUPT_STATUS         | 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                                                                      |
| GMAC_MTL_TXQ0_OPERATION_MODE      | 0x0D00 | W    | 0x00000000  | The Queue 0 Transmit Operation Mode Register establishes the Transmit queue operating modes and commands                                                                                                                           |
| 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                                                       |

| Name                                     | Offset | Size | Reset Value | Description                                                                                                                                                                                   |
|------------------------------------------|--------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>GMAC MTL TXQ0 DEBUG</u>               | 0x0D08 | W    | 0x00000000  | The Queue 0 Transmit Debug Register gives the debug status of various blocks related to the Transmit queue                                                                                    |
| <u>GMAC MTL Q0 INTERRUPT CTRL STATUS</u> | 0x0D2C | W    | 0x00000000  | This register contains the interrupt enable and status bits for the queue 0 interrupts                                                                                                        |
| <u>GMAC MTL RXQ0 OPERATION MODE</u>      | 0x0D30 | W    | 0x00000000  | The Queue 0 Receive Operation Mode Register establishes the Receive queue operating modes and command                                                                                         |
| <u>GMAC MTL RXQ0 MISS PKT OVF CNT</u>    | 0x0D34 | W    | 0x00000000  | The Queue 0 Missed Packet and Overflow Counter Register contains the counter for packets missed because of Receive queue packet flush and packets discarded because of Receive queue overflow |
| <u>GMAC MTL RXQ0 DEBUG</u>               | 0x0D38 | W    | 0x00000000  | The Queue 0 Receive Debug Register gives the debug status of various blocks related to the Receive queue                                                                                      |
| <u>GMAC DMA MODE</u>                     | 0x1000 | W    | 0x00000000  | The Bus Mode Register establishes the bus operating modes for the DMA                                                                                                                         |
| <u>GMAC DMA SYSBUS MODE</u>              | 0x1004 | W    | 0x00010000  | The System Bus mode Register controls the behavior of the AHB or AXI master                                                                                                                   |
| <u>GMAC DMA INTERRUPT STATUS</u>         | 0x1008 | W    | 0x00000000  | The application reads this Interrupt Status register during interrupt service routine or polling to determine the interrupt status of DMA channels, MTL queues, and the MAC                   |
| <u>GMAC DMA DEBUG STATUS0</u>            | 0x100C | W    | 0x00000000  | The Debug Status 0 Register gives the Receive and Transmit process status for DMA Channel 0-Channel 2 for debugging purpose                                                                   |
| <u>GMAC AXI LPI ENTRY INTERVAL</u>       | 0x1040 | W    | 0x00000000  | This register is used to control the AXI LPI entry interval                                                                                                                                   |
| <u>GMAC DMA CH0 CONTROL</u>              | 0x1100 | W    | 0x00000000  | The register specifies the MSS value for segmentation, length to skip between two descriptors, and 8xPBL mode                                                                                 |
| <u>GMAC DMA CH0 TX CONTROL</u>           | 0x1104 | W    | 0x00000000  | The register controls the Tx features such as PBL, TCP segmentation, and Tx Channel weights                                                                                                   |
| <u>GMAC DMA CH0 RX CONTROL</u>           | 0x1108 | W    | 0x00000000  | The DMA Channel0 Receive Control Register controls the Rx features such as PBL, buffer size, and extended status                                                                              |

| Name                                                        | Offset | Size | Reset Value | Description                                                                                                                                                              |
|-------------------------------------------------------------|--------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>GMAC DMA CH0 TXDESC LIST HADDRESS</u>                    | 0x1110 | W    | 0x00000000  | The Channel0 Tx Descriptor List HAddress Register has the higher 8 or 16 bits of the start address of the Transmit descriptor list                                       |
| <u>GMAC DMA CH0 TXDESC LIST ADDRESS</u>                     | 0x1114 | W    | 0x00000000  | The Channel0 Tx Descriptor List Address Register points the DMA to the start of Transmit descriptor list                                                                 |
| <u>GMAC DMA CH0 RXDESC LIST HAADDRESS</u>                   | 0x1118 | W    | 0x00000000  | The Channel0 Rx Descriptor List HAddress Register has the higher 8 or 16 bits of the start address of the Receive descriptor list                                        |
| <u>GMAC DMA CH0 RXDESC LIST ADDRESS</u>                     | 0x111C | W    | 0x00000000  | The Channel0 Rx Descriptor List Address Register points the DMA to the start of Receive descriptor list                                                                  |
| <u>GMAC DMA CH0 TXDESC TAIL POINTER</u>                     | 0x1120 | W    | 0x00000000  | The Channel0 Tx Descriptor Tail Pointer Register points to an offset from the base and indicates the location of the last valid descriptor                               |
| <u>GMAC DMA CH0 RXDESC TAIL POINTER</u>                     | 0x1128 | W    | 0x00000000  | The Channel0 Rx Descriptor Tail Pointer Register Points to an offset from the base and indicates the location of the last valid descriptor                               |
| <u>GMAC DMA CH0 TXDESC RING LENGTH</u>                      | 0x112C | W    | 0x00000000  | The Tx Descriptor Ring Length Register contains the length of the Transmit descriptor ring                                                                               |
| <u>GMAC DMA CH0 RXDESC RING LENGTH</u>                      | 0x1130 | W    | 0x00000000  | The Channel0 Rx Descriptor Ring Length Register contains the length of the Receive descriptor circular ring                                                              |
| <u>GMAC DMA CH0 INTERRUPT ENABLE</u>                        | 0x1134 | W    | 0x00000000  | The Channel0 Interrupt Enable Register enables the interrupts reported by the Status register                                                                            |
| <u>GMAC DMA CH0 RX INTERRUPT WATCHDOG TIMER</u>             | 0x1138 | W    | 0x00000000  | The Receive Interrupt Watchdog Timer Register indicates the watchdog timeout for Receive Interrupt (RI) from the DMA                                                     |
| <u>GMAC DMA CH0 CURRENT APPLICATION TRANSMIT DESCRIPTOR</u> | 0x1144 | W    | 0x00000000  | The Channel0 Current Application Transmit Descriptor Register points to the current Transmit descriptor read by the DMA                                                  |
| <u>GMAC DMA CH0 CURRENT APPLICATION RECEIVE DESCRIPTOR</u>  | 0x114C | W    | 0x00000000  | The Channel0 Current Application Receive Descriptor Register points to the current Receive descriptor read by the DMA                                                    |
| <u>GMAC DMA CH0 CURRENT APPLICATION TXBUFFER H</u>          | 0x1150 | W    | 0x00000000  | The Channel0 Current Application Transmit Buffer Address High register has the higher 8 or 16 bits of the current address of the Transmit buffer address read by the DMA |

| Name                                       | Offset | Size | Reset Value | Description                                                                                                                                                                |
|--------------------------------------------|--------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>GMAC DMA CH0 CURRENT APP TXBUFFER</u>   | 0x1154 | W    | 0x00000000  | The Channel0 Current Application Transmit Buffer Address Register points to the current Tx buffer address read by the DMA                                                  |
| <u>GMAC DMA CH0 CURRENT APP RXBUFFER H</u> | 0x1158 | W    | 0x00000000  | The Channeli Current Application Receive Buffer Address High Register has the higher 8 or 16 bits of the current address of the Receive buffer address read by the DMA     |
| <u>GMAC DMA CH0 CURRENT APP RXBUFFER</u>   | 0x115C | W    | 0x00000000  | The Channel0 Current Application Receive Buffer Address Register points to the current Rx buffer address read by the DMA                                                   |
| <u>GMAC DMA CH0 STATUS</u>                 | 0x1160 | W    | 0x00000000  | The software driver (application) reads the Status Register during interrupt service routine or polling to determine the status of the DMA                                 |
| <u>GMAC DMA CH0 MISS FRAME CNT</u>         | 0x1164 | W    | 0x00000000  | This register has the number of packet counter that got dropped by the DMA either due to Bus Error or due to programming RPF field in DMA_CH <i>i</i> _Rx_Control register |
| <u>GMAC DMA CH0 RX ERI CNT</u>             | 0x1168 | W    | 0x00000000  | The DMA_CH0_RX_ERI_Cnt Registers provides the count of the number of times ERI was asserted                                                                                |

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

### 38.4.3 Detail Registers Description

#### GMAC MAC CONFIGURATION

Address: **Operational Base** + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | RW   | 0x0         | ARPEN<br>ARP Offload Enable<br>When this bit is set, the MAC can recognize an incoming ARP request packet and schedules the ARP packet for transmission. It forwards the ARP packet to the application and also indicate the events in the RxStatus. When this bit is reset, the MAC receiver does not recognize any ARP packet and indicates them as Type frame in the RxStatus.<br>This bit is available only when the Enable IPv4 ARP Offload is selected.<br>Values:<br>1'b0: ARP Offload is disabled<br>1'b1: ARP Offload is enabled |
| 30:28 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27         | RW          | 0x0                | <p><b>IPC</b><br/> <b>Checksum Offload</b><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> <p>1'b0: IP header/payload checksum checking is disabled<br/> 1'b1: IP header/payload checksum checking is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 26:24      | RW          | 0x0                | <p><b>IPG</b><br/> <b>Inter-Packet Gap</b><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> <p>3'b000: 96 bit times IPG<br/> 3'b001: 88 bit times IPG<br/> 3'b010: 80 bit times IPG<br/> 3'b011: 72 bit times IPG<br/> 3'b100: 64 bit times IPG<br/> 3'b101: 56 bit times IPG<br/> 3'b110: 48 bit times IPG<br/> 3'b111: 40 bit times IPG</p>                                                                                                                                                                                        |
| 23         | RW          | 0x0                | <p><b>GPSLCE</b><br/> <b>Giant Packet Size Limit Control Enable</b><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> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22         | RW          | 0x0                | <p>S2KP<br/>IEEE 802.3as Support for 2K Packets<br/>When this bit is set, the MAC considers all packets with up to 2,000 bytes length as normal packets. When the JE bit is not set, the MAC considers all received packets of size more than 2K bytes as Giant packets. When this bit is reset and the JE bit is not set, the MAC considers all received packets of size more than 1,518 bytes (1,522 bytes for tagged) as giant packets.<br/>Note: When the JE bit is set, setting this bit has no effect on the giant packet status.</p> <p>Values:<br/>1'b0: Support up to 2K packet is disabled<br/>1'b1: Support up to 2K packet is Enabled</p>                                                                                                 |
| 21         | RW          | 0x0                | <p>CST<br/>CRC stripping for Type packets<br/>When this bit is set, the last four bytes (FCS) of all packets of Ether type (type field greater than 1,536) are stripped and dropped before forwarding the packet to the application.<br/>Note: For information about how the settings of the ACS bit and this bit impact the packet length, see the Table, Packet Length based on the CST and ACS Bits.</p> <p>Values:<br/>1'b0: CRC stripping for Type packets is disabled<br/>1'b1: CRC stripping for Type packets is enabled</p>                                                                                                                                                                                                                   |
| 20         | RW          | 0x0                | <p>ACS<br/>Automatic Pad or CRC Stripping<br/>When this bit is set, the MAC strips the Pad or FCS field on the incoming packets only if the value of the length field is less than 1,536 bytes. All received packets with length field greater than or equal to 1,536 bytes are passed to the application without stripping the Pad or FCS field. When this bit is reset, the MAC passes all incoming packets to the application, without any modification.<br/>Note: For information about how the settings of CST bit and this bit impact the packet length, see the Table, Packet Length based on the CST and ACS Bit.</p> <p>Values:<br/>1'b0: Automatic Pad or CRC Stripping is disabled<br/>1'b1: Automatic Pad or CRC Stripping is enabled</p> |
| 19         | RW          | 0x0                | <p>WD<br/>Watchdog Disable<br/>When this bit is set, the MAC disables the watchdog timer on the receiver. The MAC can receive packets of up to 16,383 bytes.<br/>When this bit is reset, the MAC does not allow more than 2,048 bytes (10,240 if JE is set high) of the packet being received. The MAC cuts off any bytes received after 2,048 bytes.</p> <p>Values:<br/>1'b0: Watchdog is enabled<br/>1'b1: Watchdog is disabled</p>                                                                                                                                                                                                                                                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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:<br/>0x0 (DISABLE): Packet Burst is disabled<br/>0x1 (ENABLE): Packet Burst is enabled<br/>Value After Reset: 0x0</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.<br/>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:<br/>0x0 (ENABLE): Jabber is enabled<br/>0x1 (DISABLE): Jabber is disabled<br/>Value After Reset: 0x0<br/>Exists: Always</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:<br/>1'b0: Jumbo packet is disabled<br/>1'b1: Jumbo packet is enabled</p>                                                                                                                                                                                                           |
| 15         | RW          | 0x1                | <p>PS<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>FES<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/>0x0 (10_1000M): 10 Mbps when PS bit is 1 and 1 Gbps when PS bit is 0<br/>0x1 (100_2500M): 100 Mbps when PS bit is 1 and 2.5 Gbps when PS bit is 0</p>                                                                                                                                                                                                                    |
| 13         | RW          | 0x0                | <p>DM<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>                                                                                                                                                                                                    |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12    | RW   | 0x0         | <p>LM<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:10 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 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:<br/>1'b0: Enable Carrier Sense During Transmission<br/>1'b1: Disable Carrier Sense During Transmission</p>                                 |
| 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:<br/>1'b0: Enable Retry<br/>1'b1: Disable Retry</p>                                                                                                  |
| 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:<br/>2'b00: k = min(n,10)<br/>2'b01: k = min(n,8)<br/>2'b10: k = min(n,4)<br/>2'b11: k = min(n,1)</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | RW          | 0x0                | <p>DC<br/>Deferral Check</p> <p>When this bit is set, the deferral check function is enabled in the MAC. The MAC issues a Packet Abort status, along with the excessive deferral error bit set in the Tx packet status, when the Tx state machine is deferred for more than 24,288 bit times in 10 or 100 Mbps mode. If the MAC is configured for 1000/2500 Mbps operation, the threshold for deferral is 155,680 bits times.</p> <p>Deferral begins when the transmitter is ready to transmit, but it is prevented because of an active carrier sense signal (CRS) on GMII or MII. The defer time is not cumulative. For example, if the transmitter defers for 10,000 bit times because the CRS signal is active and the CRS signal becomes inactive, the transmitter transmits and collision happens. Because of collision, the transmitter needs to back off and then defer again after back off completion. In such a scenario, the deferral timer is reset to 0, and it is restarted. When this bit is reset, the deferral check function is disabled and the MAC defers until the CRS signal goes inactive. This bit is applicable only in the half-duplex mode.</p> <p>Values:</p> <p>1'b0: Deferral check function is disabled<br/>1'b1: Deferral check function is enabled</p> |
| 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> <p>2'b00: 7 bytes of preamble<br/>2'b01: 5 bytes of preamble<br/>2'b10: 3 bytes of preamble<br/>2'b11: Reserved</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 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> <p>0x0 (DISABLE): Transmitter is disabled<br/>0x1 (ENABLE): Transmitter is enabled</p> <p>Value After Reset: 0x0</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 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> <p>1'b0: Receiver is disabled<br/>1'b1: Receiver is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

**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         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 22:20      | RW          | 0x0                | <p>HDSMS<br/>Maximum Size for Splitting the Header Data<br/>These bits indicate the maximum header size allowed for splitting the header data in the received packet.</p> <p>Values:<br/>0x0 (64BYTES): Maximum Size for Splitting the Header Data is 64 bytes<br/>0x1 (128BYTES): Maximum Size for Splitting the Header Data is 128 bytes<br/>0x2 (256BYTES): Maximum Size for Splitting the Header Data is 256 bytes<br/>0x3 (512BYTES): Maximum Size for Splitting the Header Data is 512 bytes<br/>0x4 (1024BYTES): Maximum Size for Splitting the Header Data is 1024 bytes<br/>0x5 (RSVD): Reserved</p>                                                                                                                                                            |
| 19         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 18         | RW          | 0x0                | <p>USP<br/>Unicast Slow Protocol Packet Detect<br/>When this bit is set, the MAC detects the Slow Protocol packets with unicast address of the station specified in the MAC_Address0_High and MAC_Address0_Low registers. The MAC also detects the Slow Protocol packets with the Slow Protocols multicast address (01-80-C2-00-00-02). When this bit is reset, the MAC detects only Slow Protocol packets with the Slow Protocol multicast address specified in the IEEE 802.3-2015, Section 5.</p>                                                                                                                                                                                                                                                                     |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      |             | Values:<br>1'b0: Unicast Slow Protocol Packet Detection is disabled<br>1'b1: Unicast Slow Protocol Packet Detection is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 17    | RW   | 0x0         | 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.<br>Values:<br>1'b0: Slow Protocol Detection is disabled<br>1'b1: Slow Protocol Detection is enabled                                                                                                                                                             |
| 16    | RW   | 0x0         | 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                                                                                                                                                                                                                                                                                                                      |
| 15:14 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 13:0  | RW   | 0x0000      | 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. |

**GMAC MAC PACKET FILTER**Address: Operational Base + offset (0x0008)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | RW   | 0x0         | RA<br>Receive All<br>When this bit is set, the MAC Receiver module passes all received packets to the application, irrespective of whether they pass the address filter or not. The result of the SA or DA filtering is updated (pass or fail) in the corresponding bit in the Rx Status Word.<br>When this bit is reset, the Receiver module passes only those packets to the application that pass the SA or DA address filter.<br>0x0 (DISABLE): Receive All is disabled<br>0x1 (ENABLE): Receive All is enabled |
| 30:17 | RO   | 0x0000      | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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.</p> <p>Values:<br/>1'b0: VLAN Tag Filter is disabled<br/>1'b1: VLAN Tag Filter is enabled</p>                                                                                                                                                                                                         |
| 15:11      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 10         | RW          | 0x0                | <p>HPF<br/>Hash or Perfect Filter<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.</p> <p>Values:<br/>1'b0: Hash or Perfect Filter is disabled<br/>2'b1: Hash or Perfect Filter is enabled</p>                                                                                                                            |
| 9:8        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 7:6        | RW          | 0x0                | <p>PCF<br/>Pass Control Packets<br/>These bits control the forwarding of all control packets (including unicast and multicast Pause packets).</p> <p>Values:<br/>2'b00: MAC filters all control packets from reaching the application<br/>2'b01: MAC forwards all control packets except Pause packets to the application even if they fail the Address filter<br/>2'b10: MAC forwards all control packets to the application even if they fail the Address filter<br/>2'b11: MAC forwards the control packets that pass the Address filter</p> |
| 5          | RW          | 0x0                | <p>DBF<br/>Disable Broadcast Packets<br/>When this bit is set, the AFM module blocks all incoming broadcast packets. In addition, it overrides all other filter settings. When this bit is reset, the AFM module passes all received broadcast packets.</p> <p>Values:<br/>1'b0: Enable Broadcast Packets<br/>1'b1: Disable Broadcast Packets</p>                                                                                                                                                                                               |
| 4          | RW          | 0x0                | <p>PM<br/>Pass All Multicast<br/>When this bit is set, it indicates that all received packets with a multicast destination address (first bit in the destination address field is '1') are passed. When this bit is reset, filtering of multicast packet depends on HMC bit.</p> <p>Values:<br/>1'b0: Pass All Multicast is disabled<br/>1'b1: Pass All Multicast is enabled</p>                                                                                                                                                                |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | RW   | 0x0         | <p>DAIF<br/>DA Inverse Filtering<br/>When this bit is set, the Address Check block operates in inverse filtering mode for the DA address comparison for both unicast and multicast packets. When this bit is reset, normal filtering of packets is performed.</p> <p>Values:<br/>1'b0: DA Inverse Filtering is disabled<br/>1'b1: DA Inverse Filtering is enabled</p>                                                                                 |
| 2   | RW   | 0x0         | <p>HMC<br/>Hash Multicast<br/>When this bit is set, the MAC performs the destination address filtering of received multicast packets according to the hash table. When this bit is reset, the MAC performs the perfect destination address filtering for multicast packets, that is, it compares the DA field with the values programmed in DA registers.</p> <p>Values:<br/>1'b0: Hash Multicast is disabled<br/>1'b1: Hash Multicast is enabled</p> |
| 1:0 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                              |

**GMAC MAC WATCHDOG TIMEOUT**Address: **Operational Base** + offset (0x000C)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9 | RO   | 0x0000000   | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 8    | RW   | 0x0         | <p>PWE<br/>Programmable Watchdog Enable<br/>When this bit is set and the WD bit of the MAC_Configuration register is reset, the WTO field is used as watchdog timeout for a received packet. When this bit is cleared, the watchdog timeout for a received packet is controlled by setting of WD and JE bits in MAC_Configuration register.</p> <p>Values:<br/>1'b0: Programmable Watchdog is disabled<br/>1'b1: Programmable Watchdog is enabled</p>                                                                                                                                                                                                                                         |
| 7:4  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 3:0  | RW   | 0x0         | <p>WTO<br/>Watchdog Timeout<br/>When the PWE bit is set and the WD bit of the MAC_Configuration register is reset, this field is used as watchdog timeout for a received packet. If the length of a received packet exceeds the value of this field, such packet is terminated and declared as an error packet.</p> <p>Note: When the PWE bit is set, the value in this field should be more than 1,522 (0x05F2). Otherwise, the IEEE 802.3-specified valid tagged packets are declared as error packets and then dropped.</p> <p>Values:<br/>4'b0000: 2 KB<br/>4'b0001: 3 KB<br/>4'b0010: 4 KB<br/>4'b0011: 5 KB<br/>4'b0100: 6 KB<br/>4'b0101: 7 KB<br/>4'b0110: 8 KB<br/>4'b0111: 9 KB</p> |

| Bit | Attr | Reset Value | Description                                                                                                                                           |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 4'b1000: 10 KB<br>4'b1001: 11 KB<br>4'b1010: 12 KB<br>4'b1011: 13 KB<br>4'b1100: 14 KB<br>4'b1101: 15 KB<br>4'b1110: 16383 Bytes<br>4'b1111: Reserved |

**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  | HT63T32<br>MAC Hash Table Second 32 Bits<br>This field contains the second 32 Bits [63:32] of the Hash table. |

**GMAC MAC VLAN TAG**Address: **Operational Base** + offset (0x0050)

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:25 | RO   | 0x00        | reserved    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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.</p> <p>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                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 22:21      | RW          | 0x0                | <p>EVLS<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:<br/>2'b00: Do not strip<br/>2'b01: Strip if VLAN filter passes<br/>2'b10: Strip if VLAN filter fails<br/>2'b11: Always strip</p>                                                                                                                                                                     |
| 20         | RW          | 0x0                | <p>DOVLTC<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:<br/>1'b0: VLAN Type Check is enabled<br/>1'b1: VLAN Type Check is disabled</p>                   |
| 19         | RW          | 0x0                | <p>ERSVLM<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:<br/>1'b0: Receive S-VLAN Match is disabled<br/>1'b1: Receive S-VLAN Match is enabled</p> |
| 18         | RW          | 0x0                | <p>ESVL<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:<br/>1'b0: S-VLAN is disabled<br/>1'b1: S-VLAN is enabled</p>                                                                                                                                                                                                                      |
| 17         | RW          | 0x0                | <p>VTIM<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:<br/>1'b0: VLAN Tag Inverse Match is disabled<br/>1'b1: VLAN Tag Inverse Match is enabled</p>                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16         | RW          | 0x0                | <p>ETV<br/>Enable 12-Bit VLAN Tag Comparison<br/>When this bit is set, a 12-bit VLAN identifier is used for comparing and filtering instead of the complete 16-bit VLAN tag. Bits[11:0] of VLAN tag are compared with the corresponding field in the received VLAN-tagged packet. Similarly, when enabled, only 12 bits of the VLAN tag in the received packet are used for hash-based VLAN filtering. When this bit is reset, all 16 bits of the 15th and 16th bytes of the received VLAN packet are used for comparison and VLAN hash filtering.</p> <p>Values:<br/>1'b0: 12-Bit VLAN Tag Comparison is disabled<br/>1'b1: 12-Bit VLAN Tag Comparison is enabled</p>                                                                                                                                                         |
| 15:0       | RW          | 0x0000             | <p>VL<br/>VLAN Tag Identifier for Receive Packets<br/>This field contains the 802.1Q VLAN tag to identify the VLAN packets. This VLAN tag identifier is compared to the 15th and 16th bytes of the packets being received for VLAN packets.<br/>The following list describes the bits of this field:</p> <ol style="list-style-type: none"> <li>1. Bits[15:13]: User Priority</li> <li>2. Bit 12: Canonical Format Indicator (CFI) or Drop Eligible Indicator (DEI)</li> <li>3. Bits[11:0]: VLAN Identifier (VID) field of VLAN tag<br/>When the ETV bit is set, only the VID is used for comparison. If this field ([11:0] if ETV is set) is all zeros, the MAC does not check the 15th and 16th bytes for VLAN tag comparison and declares all packets with Type field value of 0x8100 or 0x88a8 as VLAN packets.</li> </ol> |

**GMAC MAC VLAN HASH TABLE**Address: **Operational Base** + offset (0x0058)

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

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0 | RW   | 0x0000      | <p>VLHT<br/>VLAN Hash Table<br/>This field contains the 16-bit VLAN Hash Table.<br/>For hash filtering, the content of the 16-bit VLAN tag or 12-bit VLAN ID (based on the ETV bit of MAC_VLAN_Tag Register) in the incoming packet is passed through the CRC logic. When ETV bit of MAC_VLAN_Tag register is set, the upper four bits of the calculated CRC are used to index the contents of the VLAN Hash table. When ETV bit of MAC_VLAN_Tag register is reset, the ones-complement of upper four bits of the calculated CRC are used to index the contents of the VLAN Hash table. For example, when ETV bit is set a hash value of 4b'1000 selects Bit 8 of the VLAN Hash table, whereas when ETV bit is reset a hash value of 4b'1000 selects Bit 7 of the VLAN Hash table.</p> <p>The hash value of the destination address is calculated in the following way:</p> <ol style="list-style-type: none"> <li>1. Calculate the 32-bit CRC for the VLAN tag or ID (For steps to calculate CRC32, see Section 3.2.8 of IEEE 802.3).</li> <li>2. Perform bitwise reversal for the value obtained in step 1.</li> <li>3. Take the upper four bits from the value obtained in step 2.</li> </ol> <p>If the VLAN hash Table register is configured to be double-synchronized to the (G)MII clock domain, the synchronization is triggered only when Bits[15:8] (in little-endian mode) or Bits[7:0] (in big-endian mode) of this register are written.</p> <p>If double-synchronization is enabled, consecutive writes to this register should be performed after at least four clock cycles in the destination clock domain.</p> |

**GMAC MAC Q0 TX FLOW CTRL**Address: **Operational Base + offset (0x0070)**

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | <p>PT<br/>Pause Time<br/>This field holds the value to be used in the Pause Time field in the Tx control packet. If the Pause Time bits are configured to be double-synchronized to the (G)MII clock domain, consecutive writes to this register should be performed only after at least four clock cycles in the destination clock domain.</p>                                                                                                                                                                                      |
| 15:8  | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 7     | RW   | 0x0         | <p>DZPQ<br/>Disable Zero-Quanta Pause<br/>When this bit is set, it disables the automatic generation of the zero-quanta Pause packets on de-assertion of the flow-control signal from the FIFO layer (MTL or external sideband flow control signal sbd_flowctrl_i or mtl_flowctrl_i).<br/>When this bit is reset, normal operation with automatic zero-quanta Pause packet generation is enabled.<br/>Values:<br/>1'b0: Zero-Quanta Pause packet generation is enabled<br/>1'b1: Zero-Quanta Pause packet generation is disabled</p> |
| 6:2   | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | RW   | 0x0         | <p>TFE<br/>Transmit Flow Control Enable<br/>Full-Duplex Mode:<br/>In the full-duplex mode, when this bit is set, the MAC enables the flow control operation to Tx Pause packets. When this bit is reset, the flow control operation in the MAC is disabled, and the MAC does not transmit any Pause packets.</p> <p>Half-Duplex Mode:<br/>In the half-duplex mode, when this bit is set, the MAC enables the backpressure operation. When this bit is reset, the backpressure feature is disabled.</p> <p>Values:<br/>1'b0: Transmit Flow Control is disabled<br/>1'b1: Transmit Flow Control is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0   | RW   | 0x0         | <p>FCB_BPA<br/>Flow Control Busy or Backpressure Activate<br/>This bit initiates a Pause packet in the full-duplex mode and activates the backpressure function in the half-duplex mode if the TFE bit is set.</p> <p>Full-Duplex Mode:<br/>In the full-duplex mode, this bit should be read as 1'b0 before writing to this register. To initiate a Pause packet, the application must set this bit to 1'b1. During Control packet transfer, this bit continues to be set to indicate that a packet transmission is in progress. When Pause packet transmission is complete, the MAC resets this bit to 1'b0. You should not write to this register until this bit is cleared.</p> <p>Half-Duplex Mode:<br/>When this bit is set (and TFE bit is set) in the half-duplex mode, the MAC asserts the backpressure. During backpressure, when the MAC receives a new packet, the transmitter starts sending a JAM pattern resulting in a collision. This control register bit is logically ORed with the mti_flowctrl_i input signal for the backpressure function. When the MAC is configured for the full-duplex mode, the BPA is automatically disabled. Access restriction applies. Setting 1 sets. Self-cleared. Setting 0 has no effect.</p> <p>Values:<br/>1'b0: Flow Control Busy or Backpressure Activate is disabled<br/>1'b1: Flow Control Busy or Backpressure Activate is enabled</p> |

**GMAC\_MAC\_RX\_FLOW\_CTRL**Address: **Operational Base** + offset (0x0090)

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

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | <p>Control (PFC) is enabled. The unique multicast address (0x01_80_C2_00_00_01) is as specified in IEEE 802.1 Qbb-2011.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Unicast Pause Packet Detect disabled</li> <li>1'b1: Unicast Pause Packet Detect enabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 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)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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/> <b>Transmit Status Interrupt</b><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:<br/> 1'b0: Transmit Interrupt status not active<br/> 1'b1: Transmit Interrupt status active</p> |
| 12  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 11  | RO   | 0x0         | <p><b>MMCRXIPIS</b><br/> <b>MMC Receive Checksum Offload Interrupt Status</b><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:<br/> 1'b0: MMC Receive Checksum Offload Interrupt status not active<br/> 1'b1: MMC Receive Checksum Offload Interrupt status active</p>                                                                                                                                                                                                                                                 |
| 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>                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:5        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 4          | RO          | 0x0                | <p>PMTIS<br/>PMT Interrupt Status<br/>This bit is set when a Magic packet or Wake-on-LAN packet is received in the power-down mode (RWKPRCVD and MGKPRCVD bits in MAC_PMT_Control_Status register). This bit is cleared when corresponding interrupt source bit are cleared because of a Read operation to the MAC_PMT_Control_Status register (or corresponding interrupt source bit of MAC_PMT_Control_Status register is written to 1 when RCWE bit of MAC_CSR_SW_Ctrl register is set).<br/>This bit is valid only when you select the Enable Power Management option.<br/>Values:<br/>1'b0: PMT Interrupt status not active<br/>1'b1: PMT Interrupt status active</p> |
| 3          | RO          | 0x0                | <p>PHYIS<br/>PHY Interrupt<br/>This bit is set when rising edge is detected on the phy_intr_i input. This bit is cleared when this register is read (or this bit is written to 1 when RCWE bit of MAC_CSR_SW_Ctrl register is set).<br/>Values:<br/>1'b0: PHY Interrupt not detected<br/>1'b1: PHY Interrupt detected</p>                                                                                                                                                                                                                                                                                                                                                  |
| 2:0        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

**GMAC\_MAC\_INTERRUPT\_ENABLE**Address: **Operational Base** + offset (0x00B4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                |
| 18         | RW          | 0x0                | <p>MDIOIE<br/>MDIO Interrupt Enable<br/>When this bit is set, it enables the assertion of the interrupt when MDIOIS field is set in the MAC_Interrupt_Status register.<br/>Values:<br/>1'b0: MDIO Interrupt is disabled<br/>1'b1: MDIO Interrupt is enabled</p>                                                         |
| 17:15      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                |
| 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> |
| 12:5       | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                  |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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.</p> <p>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.</p> <p>Values:<br/>1'b0: PHY Interrupt is disabled<br/>1'b1: PHY Interrupt is enabled</p> |
| 2:0 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                     |

**GMAC MAC RX TX STATUS**Address: Operational Base + offset (0x00B8)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9 | RO   | 0x0000000   | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 8    | RO   | 0x0         | <p>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. Access restriction applies. Clears on read (or write of 1 when RCWE bit in MAC_CSR_SW_Ctrl register is set). Self-set to 1 on internal event.</p> <p>Values:<br/>1'b0: No receive watchdog timeout<br/>1'b1: Receive watchdog timed out</p> |
| 7:5  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 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:<br/>1'b0: No collision<br/>1'b1: Late collision is sensed</p>        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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).<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: No Excessive deferral<br/>1'b1: Excessive deferral</p>                                                                |
| 2          | RO          | 0x0                | <p>LCARR<br/>Loss of Carrier<br/>When the DTXSTS bit is set in the MTL_Operation_Mode register, this bit indicates that the loss of carrier occurred during packet transmission, that is, the phy_crs_i signal was inactive for one or more transmission clock periods during packet transmission. This bit is valid only for packets transmitted without collision.<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: Carrier is present<br/>1'b1: Loss of carrier</p>                                    |
| 1          | RO          | 0x0                | <p>NCARR<br/>No Carrier<br/>When the DTXSTS bit is set in the MTL_Operation_Mode register, this bit indicates that the carrier signal from the PHY is not present at the end of preamble transmission.<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: Carrier is present<br/>1'b1: No carrier</p>                                                                                                                                                                                                       |
| 0          | RO          | 0x0                | <p>TJT<br/>Transmit Jabber Timeout<br/>This bit indicates that the Transmit Jabber Timer expired which happens when the packet size exceeds 2,048 bytes (10,240 bytes when the Jumbo packet is enabled) and JD bit is reset in the MAC_Configuration register. This bit is set when the packet size exceeds 16,383 bytes and the JD bit is set in the MAC_Configuration register.<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: No Transmit Jabber Timeout<br/>1'b1: Transmit Jabber Timeout occur</p> |

**GMAC MAC PMT CONTROL STATUS**Address: **Operational Base** + offset (0x00C0)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | RW   | 0x0         | <p><b>RWKFLTRST</b><br/>           Remote Wake-Up Packet Filter Register Pointer Reset<br/>           When this bit is set, the remote wake-up packet filter register pointer is reset to 3'b000. It is automatically cleared after 1 clock cycle.</p> <p>Access restriction applies. Setting 1 sets. Self-cleared. Setting 0 has no effect.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Remote Wake-Up Packet Filter Register Pointer is not Reset</li> <li>1'b1: Remote Wake-Up Packet Filter Register Pointer is Reset</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 30:29 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 28:24 | RO   | 0x00        | <p><b>RWKPTR</b><br/>           Remote Wake-up FIFO Pointer<br/>           This field gives the current value (0 to 7, 15, or 31 when 4, 8, or 16 Remote Wake-up Packet Filters are selected) of the Remote Wake-up Packet Filter register pointer. When the value of this pointer is equal to maximum for the selected number of Remote Wake-up Packet Filters, the contents of the Remote Wake-up Packet Filter Register are transferred to the clk_rx_i domain when a Write occurs to that register.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 23:11 | RO   | 0x0000      | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 10    | RW   | 0x0         | <p><b>RWKPFE</b><br/>           Remote Wake-up Packet Forwarding Enable<br/>           When this bit is set along with RWKPKTEN, the MAC receiver drops all received frames until it receives the expected Wake-up frame. All frames after that event including the received wake-up frame are forwarded to application. This bit is then self-cleared on receiving the wake-up packet. The application can also clear this bit before the expected wake-up frame is received. In such cases, the MAC reverts to the default behavior where packets received are forwarded to the application. This bit must only be set when RWKPKTEN is set high and PWRDWN is set low. The setting of this bit has no effect when PWRDWN is set high.</p> <p>Note: If Magic Packet Enable and Wake-Up Frame Enable are both set along with setting of this bit and Magic Packet is received prior to wake-up frame, this bit is self-cleared on receiving Magic Packet, the received Magic packet is dropped, and all frames after received Magic Packet are forwarded to application.</p> <p>Access restriction applies. Setting 1 sets. Self-cleared. Setting 0 has no effect.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Remote Wake-up Packet Forwarding is disabled</li> <li>1'b1: Remote Wake-up Packet Forwarding is enabled</li> </ul> |
| 9     | RW   | 0x0         | <p><b>GLBLUCAST</b><br/>           Global Unicast<br/>           When this bit set, any unicast packet filtered by the MAC (DAF) address recognition is detected as a remote wake-up packet.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Global unicast is disabled</li> <li>1'b1: Global unicast is enabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 8:7   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6   | RO   | 0x0         | <p>RWKPRCVD<br/>Remote Wake-Up Packet Received<br/>When this bit is set, it indicates that the power management event is generated because of the reception of a remote wake-up packet. This bit is cleared when this register is read.<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.</p> <p>Values:<br/>1'b0: Remote wake-up packet is received<br/>1'b1: Remote wake-up packet is received</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 5   | RO   | 0x0         | <p>MGKPRCVD<br/>Magic Packet Received<br/>When this bit is set, it indicates that the power management event is generated because of the reception of a magic packet. This bit is cleared when this register is read.<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.</p> <p>Values:<br/>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:<br/>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:<br/>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:<br/>1'b0: Power down is disabled<br/>1'b1: Power down is enabled</p> |

**GMAC MAC RWK PACKET FILTER**Address: **Operational Base** + offset (0x00C4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | WKUPFRMFTR<br>RWK Packet Filter<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.<br>The MAC updates the wkuppkfilter_reg register current pointer value in RWPTR field of MAC_PMT_Status register.<br>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. |

**GMAC RWK FILTER0 BYTE MASK**Address: **Operational Base** + offset (0x00C4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | Filter0[Byte_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 (0x00C4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | Filter1[Byte_Mask]<br>Filter1 32-bit Mask<br>Each bit in this mask corresponds to one byte in the detected packet. If the bit is 1, the corresponding byte is taken into the CRC16 calculation. |

**GMAC RWK FILTER2 BYTE MASK**Address: **Operational Base** + offset (0x00C4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | Filter2[Byte_Mask]<br>Filter2 32-bit Mask<br>Each bit in this mask corresponds to one byte in the detected packet. If the bit is 1, the corresponding byte is taken into the CRC16 calculation. |

**GMAC RWK FILTER3 BYTE MASK**Address: **Operational Base** + offset (0x00C4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | Filter3[Byte_Mask]<br>Filter3 32-bit Mask<br>Each bit in this mask corresponds to one byte in the detected packet. If the bit is 1, the corresponding byte is taken into the CRC16 calculation. |

**GMAC RWK FILTER01\_CRC**Address: **Operational Base** + offset (0x00C4)

| <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 (0x00C4)

| <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 (0x00C4)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8       | RW          | 0x00               | <p>Filter1_Offset<br/>Filter1 Offset<br/>This filter offset defines the offset (within the packet) from which the filter examines the packets.</p> <ol style="list-style-type: none"> <li>1. This 8-bit pattern-offset is the offset for the filter first byte to be examined.</li> <li>2. The minimum allowed offset is 12, which refers to the 13th byte of the packet.</li> <li>3. The offset value 0 refers to the first byte of the packet.</li> </ol> |
| 7:0        | RW          | 0x00               | <p>Filter0_Offset<br/>Filter0 Offset<br/>This filter offset defines the offset (within the packet) from which the filter examines the packets.</p> <ol style="list-style-type: none"> <li>1. This 8-bit pattern-offset is the offset for the filter first byte to be examined.</li> <li>2. The minimum allowed offset is 12, which refers to the 13th byte of the packet.</li> <li>3. The offset value 0 refers to the first byte of the packet.</li> </ol> |

**GMAC RWK FILTER COMMAND**Address: **Operational Base** + offset (0x00C4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 19:16      | RW          | 0x0                | <p>Filter2_Command<br/>Filter2 Command<br/>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_Previos) 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_Previos bit set.</li> <li>5. Bit 0 is the enable for filter. If Bit 0 is not set, filter is disabled.</li> </ol> |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 11:8       | RW          | 0x0                | <p>Filter1_Command<br/>Filter1 Command<br/>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</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | <p>AND NOT Pattern 2".</p> <p>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.</p> <p>5. Bit 0 is the enable for filter. If Bit 0 is not set, filter is disabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 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> <p>1. Bit 3 specifies the address type, defining the destination address type of the pattern. When the bit is set, the pattern applies to only multicast packets; when the bit is reset, the pattern applies only to unicast packet.</p> <p>2. Bit 2 (Inverse Mode), when set, reverses the logic of the CRC16 hash function signal, to reject a packet with matching CRC_16 value.</p> <p>3. Bit 2, along with Bit 1, allows a MAC to reject a subset of remote wake-up packets by creating filter logic such as "Pattern 1 AND NOT Pattern 2".</p> <p>4. Bit 1 (And_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.</p> <p>5. Bit 0 is the enable for filter. If Bit 0 is not set, filter is disabled.</p> |

**GMAC MAC VERSION**Address: **Operational Base** + offset (0x0110)

| Bit   | Attr | Reset Value | Description                       |
|-------|------|-------------|-----------------------------------|
| 31:16 | RO   | 0x0000      | reserved                          |
| 15:8  | RW   | 0x30        | USERVER<br>User-defined Version   |
| 7:0   | RW   | 0x51        | RKVER<br>Rockchip-defined Version |

**GMAC MAC DEBUG**Address: **Operational Base** + offset (0x0114)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19 | RO   | 0x0000      | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 18:17 | RO   | 0x0         | <p>TFCSTS<br/>MAC Transmit Packet Controller Status</p> <p>This field indicates the state of the MAC Transmit Packet Controller module.</p> <p>Values:</p> <p>2'b00: Idle state</p> <p>2'b01: Waiting for one of the following: Status of the previous packet OR IPG or back off period to be over</p> <p>2'b10: Generating and transmitting a Pause control packet (in full-duplex mode)</p> <p>2'b11: Transferring input packet for transmission</p> |

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                    |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16   | RO   | 0x0         | <p>TPESTS<br/>MAC GMII or MII Transmit Protocol Engine Status<br/>When this bit is set, it indicates that the MAC GMII or MII transmit protocol engine is actively transmitting data, and it is not in the Idle state.</p> <p>Values:<br/>1'b0: MAC GMII or MII Transmit Protocol Engine Status not detected<br/>1'b1: MAC GMII or MII Transmit Protocol Engine Status detected</p>            |
| 15:3 | RO   | 0x0000      | reserved                                                                                                                                                                                                                                                                                                                                                                                       |
| 2:1  | RO   | 0x0         | <p>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.</p>                                                                                                                                                                        |
| 0    | RO   | 0x0         | <p>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.</p> <p>Values:<br/>0x0 (INACTIVE): MAC GMII or MII Receive Protocol Engine Status not detected<br/>0x1 (ACTIVE): MAC GMII or MII Receive Protocol Engine Status detected</p> |

**GMAC MAC HW FEATURE0**Address: **Operational Base** + offset (0x011C)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                            |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | RO   | 0x4         | <p>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.</p> <p>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</p> |
| 27    | RO   | 0x0         | <p>SAVLANINS<br/>Source Address or VLAN Insertion Enable<br/>This bit is set to 1 when the Enable SA and VLAN Insertion on Tx option is selected.</p> <p>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>                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 26:25      | RO          | 0x0                | <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                | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 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:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 13         | RO          | 0x0                | <p><b>EEESEL</b><br/>         Energy Efficient Ethernet Enabled<br/>         This bit is set to 1 when the Enable Energy Efficient Ethernet (EEE) option is selected.<br/>         Values:<br/>         1'b0: Energy Efficient Ethernet Enable option is not selected<br/>         1'b1: Energy Efficient Ethernet Enable option is selected</p>                                 |
| 12         | RO          | 0x1                | <p><b>TSSEL</b><br/>         IEEE 1588-2008 Timestamp Enabled<br/>         This bit is set to 1 when the Enable IEEE 1588 Timestamp Support option is selected.<br/>         Values:<br/>         1'b0: IEEE 1588-2008 Timestamp Enable option is not selected.<br/>         1'b1: IEEE 1588-2008 Timestamp Enable option is selected.</p>                                       |
| 11:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 9          | RO          | 0x1                | <p><b>ARPOFFSEL</b><br/>         ARP Offload Enabled<br/>         This bit is set to 1 when the Enable IPv4 ARP Offload option is selected.<br/>         Values:<br/>         1'b0: ARP Offload Enable option is not selected<br/>         1'b1: ARP Offload Enable option is selected</p>                                                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8          | RO          | 0x1                | <p><b>MMCSEL</b><br/> <b>RMON Module Enable</b><br/>           This bit is set to 1 when the Enable MAC Management Counters (MMC) option is selected.<br/>           Values:<br/>           1'b0: RMON Module Enable option is not selected<br/>           1'b1: RMON Module Enable option is selected</p>                                                    |
| 7          | RO          | 0x1                | <p><b>MGKSEL</b><br/> <b>PMT Magic Packet Enable</b><br/>           This bit is set to 1 when the Enable Magic Packet Detection option is selected.<br/>           Values:<br/>           1'b0: PMT Magic Packet Enable option is not selected<br/>           1'b1: PMT Magic Packet Enable option is selected</p>                                            |
| 6          | RO          | 0x1                | <p><b>RWKSEL</b><br/> <b>PMT Remote Wake-up Packet Enable</b><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><b>SMASEL</b><br/> <b>SMA (MDIO) Interface</b><br/>           This bit is set to 1 when the Enable Station Management (MDIO Interface) option is selected.<br/>           Values:<br/>           1'b0: SMA (MDIO) Interface not selected<br/>           1'b1: SMA (MDIO) Interface selected</p>                                                            |
| 4          | RO          | 0x0                | <p><b>VLHASH</b><br/> <b>VLAN Hash Filter Selected</b><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><b>PCSSEL</b><br/> <b>PCS Registers (TBI, SGMII, or RTBI PHY interface)</b><br/>           This bit is set to 1 when the TBI, SGMII, or RTBI PHY interface option is selected.<br/>           Values:<br/>           1'b0: No PCS Registers (TBI, SGMII, or RTBI PHY interface)<br/>           1'b1: PCS Registers (TBI, SGMII, or RTBI PHY interface)</p> |
| 2          | RO          | 0x0                | <p><b>HDSEL</b><br/> <b>Half-duplex Support</b><br/>           This bit is set to 1 when the half-duplex mode is selected.<br/>           Values:<br/>           1'b0: No Half-duplex support<br/>           1'b1: Half-duplex support</p>                                                                                                                    |
| 1          | RO          | 0x0                | <p><b>GMIISEL</b><br/> <b>1000 Mbps Support</b><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>                                                                                                          |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                               |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | RO   | 0x1         | <p>MIISEL<br/>10 or 100 Mbps Support<br/>This bit is set to 1 when 10/100 Mbps is selected as the Mode of Operation.<br/>Values:<br/>1'b0: No 10 or 100 Mbps support<br/>1'b1: 10 or 100 Mbps support</p> |

**GMAC MAC HW FEATURE1**Address: **Operational Base** + offset (0x0120)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 25:24 | RO   | 0x1         | <p>HASHTBLSZ<br/>Hash Table Size<br/>This field indicates the size of the hash table:<br/>Values:<br/>2'b00: No hash table<br/>2'b01: 64<br/>2'b10: 128<br/>2'b11: 256</p>                                                                                                                                                                                                                                                     |
| 23    | RO   | 0x0         | <p>POUOST<br/>One Step for PTP over UDP/IP Feature Enable<br/>This bit is set to 1 when the Enable One step timestamp for PTP over UDP/IP feature is selected.<br/>Values:<br/>1'b0: One Step for PTP over UDP/IP Feature is not selected<br/>1'b1: One Step for PTP over UDP/IP Feature is selected</p>                                                                                                                       |
| 22    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 21    | RO   | 0x0         | <p>RAVSEL<br/>Rx Side Only AV Feature Enable<br/>This bit is set to 1 when the Enable Audio Video Bridging option on Rx Side Only is selected.<br/>Values:<br/>1'b0: Rx Side Only AV Feature is not selected<br/>1'b1: Rx Side Only AV Feature is selected</p>                                                                                                                                                                 |
| 20    | RO   | 0x0         | <p>AVSEL<br/>AV Feature Enable<br/>This bit is set to 1 when the Enable Audio Video Bridging option is selected.<br/>Values:<br/>1'b0: AV Feature is not selected<br/>1'b1: AV Feature is selected</p>                                                                                                                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19         | RO          | 0x1                | <p>DBGMEMA<br/>DMA Debug Registers Enable<br/>This bit is set to 1 when the Debug Mode Enable option is selected.<br/>Values:<br/>1'b0: DMA Debug Registers option is not selected<br/>1'b1: DMA Debug Registers option is selected</p>                                                    |
| 18         | RO          | 0x1                | <p>TSOEN<br/>TCP Segmentation Offload Enable<br/>This bit is set to 1 when the Enable TCP Segmentation Offloading for TCP/IP Packets option is selected.<br/>Values:<br/>1'b0: TCP Segmentation Offload Feature is not selected<br/>1'b1: TCP Segmentation Offload Feature is selected</p> |
| 17         | RO          | 0x1                | <p>SPHEN<br/>Split Header Feature Enable<br/>This bit is set to 1 when the Enable Split Header Structure option is selected.<br/>Values:<br/>1'b0: Split Header Feature is not selected<br/>1'b1: Split Header Feature is selected</p>                                                     |
| 16         | RO          | 0x0                | <p>DCBEN<br/>DCB Feature Enable<br/>This bit is set to 1 when the Enable Data Center Bridging option is selected.<br/>Values:<br/>1'b0: DCB Feature is not selected<br/>1'b1: DCB Feature is selected</p>                                                                                  |
| 15:14      | RO          | 0x1                | <p>ADDR64<br/>Address Width<br/>This field indicates the configured address width:<br/>Values:<br/>2'b00: 32<br/>2'b01: 40<br/>2'b10: 48<br/>2'b11: Reserved</p>                                                                                                                           |
| 13         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                   |
| 12         | RO          | 0x0                | <p>PTOEN<br/>PTP Offload Enable<br/>This bit is set to 1 when the Enable PTP Timestamp Offload Feature is selected.<br/>Values:<br/>1'b0: PTP Offload feature is not selected<br/>1'b1: PTP Offload feature is selected</p>                                                                |
| 11         | RO          | 0x0                | <p>OSTEN<br/>One-Step Timestamping Enable<br/>This bit is set to 1 when the Enable One-Step Timestamp Feature is selected.<br/>Values:<br/>1'b0: One-Step Timestamping feature is not selected<br/>1'b1: One-Step Timestamping feature is selected</p>                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:6       | RO          | 0x05               | <p><b>TXFIFOSIZE</b><br/>           MTL Transmit FIFO Size<br/>           This field contains the configured value of MTL Tx FIFO in bytes expressed as Log to base 2 minus 7, that is, <math>\text{Log}_2(\text{TXFIFO\_SIZE}) - 7</math>:<br/>           Values:<br/>           0x0 (128B): 128 bytes<br/>           0x1 (256B): 256 bytes<br/>           0x2 (512B): 512 bytes<br/>           0x3 (1024B): 1024 bytes<br/>           0x4 (2048B): 2048 bytes<br/>           0x5 (4096B): 4096 bytes<br/>           0x6 (8192B): 8192 bytes<br/>           0x7 (16384B): 16384 bytes<br/>           0x8 (32KB): 32 KB<br/>           0x9 (64KB): 64 KB<br/>           0xa (128KB): 128 KB<br/>           0xb (RSVD): Reserved</p> |
| 5          | RO          | 0x1                | <p><b>SPRAM</b><br/>           Single Port RAM Enable<br/>           This bit is set to 1 when the Use single port RAM Feature is selected.<br/>           Values:<br/>           1'b0: Single Port RAM feature is not selected<br/>           1'b1: Single Port RAM feature is selected</p>                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 4:0        | RO          | 0x06               | <p><b>RXFIFOSIZE</b><br/>           MTL Receive FIFO Size<br/>           This field contains the configured value of MTL Rx FIFO in bytes expressed as Log to base 2 minus 7, that is, <math>\text{Log}_2(\text{RXFIFO\_SIZE}) - 7</math>:<br/>           Values:<br/>           5'b00000: 128 bytes<br/>           5'b00001: 256 bytes<br/>           5'b00010: 512 bytes<br/>           5'b00011: 1024 bytes<br/>           5'b00100: 2048 bytes<br/>           5'b00101: 4096 bytes<br/>           5'b00110: 8192 bytes<br/>           5'b00111: 16384 bytes<br/>           5'b01000: 32 KB<br/>           5'b01001: 64 KB<br/>           5'b01010: 128 KB<br/>           5'b01011: 256 KB<br/>           5'b01100: Reserved</p> |

**GMAC MAC HW FEATURE2**Address: **Operational Base + offset (0x0124)**

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30:28      | RO          | 0x1                | AUXSNAPNUM<br>Number of Auxiliary Snapshot Inputs<br>This field indicates the number of auxiliary snapshot inputs:<br>Values:<br>3'b000: No auxiliary input<br>3'b001: 1 auxiliary input<br>3'b010: 2 auxiliary input<br>3'b011: 3 auxiliary input<br>3'b100: 4 auxiliary input<br>3'b101: Reserved                                                               |
| 27         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                          |
| 26:24      | RO          | 0x1                | PPSOUTNUM<br>Number of PPS Outputs<br>This field indicates the number of PPS outputs:<br>Values:<br>3'b000: No PPS output<br>3'b001: 1 PPS output<br>3'b010: 2 PPS output<br>3'b011: 3 PPS output<br>3'b100: 4 PPS output<br>3'b101: Reserved                                                                                                                     |
| 23:22      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                          |
| 21:18      | RO          | 0x0                | TXCHCNT<br>Number of DMA Transmit Channels<br>This field indicates the number of DMA Transmit channels:<br>Values:<br>4'b0000: 1 MTL Tx Channel<br>4'b0001: 2 MTL Tx Channels<br>4'b0010: 3 MTL Tx Channels<br>4'b0011: 4 MTL Tx Channels<br>4'b0100: 5 MTL Tx Channels<br>4'b0101: 6 MTL Tx Channels<br>4'b0110: 7 MTL Tx Channels<br>4'b0111: 8 MTL Tx Channels |
| 17:16      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                          |
| 15:12      | RO          | 0x0                | RXCHCNT<br>Number of DMA Receive Channels<br>This field indicates the number of DMA Receive channels:<br>Values:<br>4'b0000: 1 MTL Rx Channel<br>4'b0001: 2 MTL Rx Channels<br>4'b0010: 3 MTL Rx Channels<br>4'b0011: 4 MTL Rx Channels<br>4'b0100: 5 MTL Rx Channels<br>4'b0101: 6 MTL Rx Channels<br>4'b0110: 7 MTL Rx Channels<br>4'b0111: 8 MTL Rx Channels   |
| 11:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                          |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                    |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:6 | RO   | 0x0         | <p>TXQCNT<br/>Number of MTL Transmit Queues<br/>This field indicates the number of MTL Transmit queues:<br/>Values:<br/>4'b0000: 1 MTL Tx Queue<br/>4'b0001: 2 MTL Tx Queues<br/>4'b0010: 3 MTL Tx Queues<br/>4'b0011: 4 MTL Tx Queues<br/>4'b0100: 5 MTL Tx Queues<br/>4'b0101: 6 MTL Tx Queues<br/>4'b0110: 7 MTL Tx Queues<br/>4'b0111: 8 MTL Tx Queues</p> |
| 5:4 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                       |
| 3:0 | RO   | 0x0         | <p>RXQCNT<br/>Number of MTL Receive Queues<br/>This field indicates the number of MTL Receive queues:<br/>Values:<br/>4'b0000: 1 MTL Rx Queue<br/>4'b0001: 2 MTL Rx Queues<br/>4'b0010: 3 MTL Rx Queues<br/>4'b0011: 4 MTL Rx Queues<br/>4'b0100: 5 MTL Rx Queues<br/>4'b0101: 6 MTL Rx Queues<br/>4'b0110: 7 MTL Rx Queues<br/>4'b0111: 8 MTL Rx Queues</p>   |

**GMAC MAC HW FEATURE3**Address: **Operational Base + offset (0x0128)**

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 29:28 | RO   | 0x0         | <p>ASP<br/>Automotive Safety Package<br/>Following are the encoding for the different Safety features.<br/>Values:<br/>2'b00: No Safety features selected<br/>2'b01: Only "ECC protection for external memory" feature is selected<br/>2'b10: All the Automotive Safety features are selected without the "Parity Port Enable for external interface" feature<br/>2'b11: All the Automotive Safety features are selected with the "Parity Port Enable for external interface" feature</p> |
| 27    | RO   | 0x0         | <p>TBSSEL<br/>Time Based Scheduling Enable<br/>This bit is set to 1 when the Time Based Scheduling feature is selected.<br/>Values:<br/>1'b0: Time Based Scheduling Enable feature is not selected<br/>1'b1: Time Based Scheduling Enable feature is selected</p>                                                                                                                                                                                                                         |
| 26    | RO   | 0x0         | <p>FPESEL<br/>Frame Preemption Enable<br/>This bit is set to 1 when the Enable Frame preemption feature is selected.<br/>Values:<br/>1'b0: Frame Preemption Enable feature is not selected<br/>1'b1: Frame Preemption Enable feature is selected</p>                                                                                                                                                                                                                                      |
| 25:22 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21:20      | RO          | 0x0                | <p><b>ESTWID</b><br/> Width of the Time Interval field in the Gate Control List<br/> This field indicates the width of the Configured Time Interval Field.<br/> Values:<br/> 2'b00: Width not configured<br/> 2'b01: 16<br/> 2'b10: 20<br/> 2'b11: 24</p>                                                                                |
| 19:17      | RW          | 0x0                | <p><b>ESTDEP</b><br/> Depth of the Gate Control List<br/> This field indicates the depth of Gate Control list expressed as Log2(DWC_EQOS_EST_DEP)-5.<br/> Values:<br/> 3'b000: No Depth configured<br/> 3'b001: 64<br/> 3'b010: 128<br/> 3'b011: 256<br/> 3'b100: 512<br/> 3'b101: 1024<br/> 3'b110: Reserved</p>                        |
| 16         | RO          | 0x0                | <p><b>ESTSEL</b><br/> Enhancements to Scheduling Traffic Enable<br/> This bit is set to 1 when the Enable Enhancements to Scheduling Traffic feature is selected.<br/> Values:<br/> 1'b0: Enable Enhancements to Scheduling Traffic feature is not selected<br/> 1'b1: Enable Enhancements to Scheduling Traffic feature is selected</p> |
| 15         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                 |
| 14:13      | RO          | 0x0                | <p><b>FRPES</b><br/> Flexible Receive Parser Table Entries size<br/> This field indicates the Max Number of Parser Entries supported by Flexible Receive Parser.<br/> Values:<br/> 2'b00: 64 Entries<br/> 2'b01: 128 Entries<br/> 2'b10: 256 Entries<br/> 2'b11: Reserved</p>                                                            |
| 12:11      | RO          | 0x0                | <p><b>FRPBS</b><br/> Flexible Receive Parser Buffer size<br/> This field indicates the supported Max Number of bytes of the packet data to be Parsed by Flexible Receive Parser.<br/> Values:<br/> 2'b00: 64 Bytes<br/> 2'b01: 128 Bytes<br/> 2'b10: 256 Bytes<br/> 2'b11: Reserved</p>                                                  |
| 10:6       | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | RO          | 0x0                | DVLAN<br>Double VLAN Tag Processing Selected<br>This bit is set to 1 when the Enable Double VLAN Processing Feature is selected.<br>Values:<br>1'b0: Double VLAN option is not selected<br>1'b1: Double VLAN option is selected                                                                                                                                                                      |
| 4          | RO          | 0x0                | CBTISEL<br>Queue/Channel based VLAN tag insertion on Tx Enable<br>This bit is set to 1 when the Enable Queue/Channel based VLAN tag insertion on Tx Feature is selected.<br>Values:<br>1'b0: Enable Queue/Channel based VLAN tag insertion on Tx feature is not selected<br>1'b1: Enable Queue/Channel based VLAN tag insertion on Tx feature is selected                                            |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                             |
| 2:0        | RO          | 0x0                | NRVF<br>Number of Extended VLAN Tag Filters Enabled<br>This field indicates the Number of Extended VLAN Tag Filters selected:<br>Values:<br>3'b000: No Extended Rx VLAN Filters<br>3'b001: 4 Extended Rx VLAN Filters<br>3'b010: 8 Extended Rx VLAN Filters<br>3'b011: 16 Extended Rx VLAN Filters<br>3'b100: 24 Extended Rx VLAN Filters<br>3'b101: 32 Extended Rx VLAN Filters<br>3'b110: Reserved |

**GMAC\_MAC\_MDIO\_ADDRESS**Address: **Operational Base** + offset (0x0200)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 27         | RW          | 0x0                | PSE<br>Preamble Suppression Enable<br>When this bit is set, the SMA suppresses the 32-bit preamble and transmits MDIO frames with only 1 preamble bit. When this bit is 0, the MDIO frame always has 32 bits of preamble as defined in the IEEE specifications.<br>Values:<br>1'b0: Preamble Suppression disabled<br>1'b1: Preamble Suppression enabled                                                                                                                                                                                                                                                                                                         |
| 26         | RW          | 0x0                | 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: |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      |             | 1'b0: Back to Back transactions disabled<br>1'b1: Back to Back transactions enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 25:21 | RW   | 0x00        | 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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 20:16 | RW   | 0x00        | 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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 15    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 14:12 | RW   | 0x0         | 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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 11:8  | RW   | 0x0         | 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. 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 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |             |                    | interface.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 7:5        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 4          | RW          | 0x0                | <p><b>SKAP</b><br/> <b>Skip Address Packet</b><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><b>GOC_1</b><br/> <b>GMII Operation Command 1</b><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><b>GOC_0</b><br/> <b>GMII Operation Command 0</b><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><b>C45E</b><br/> <b>Clause 45 PHY Enable</b><br/> When this bit is set, Clause 45 capable PHY is connected to MDIO. When this bit is reset, Clause 22 capable PHY is connected to MDIO.<br/> Values:<br/> 1'b0: Clause 45 PHY is disabled<br/> 1'b1: Clause 45 PHY is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0          | RW          | 0x0                | <p><b>GB</b><br/> <b>GMII Busy</b><br/> The application sets this bit to instruct the SMA to initiate a Read or Write access to the MDIO slave. The MAC clears this bit after the MDIO frame transfer is completed. Hence the software must not write or change any of the fields in MAC_MDIO_Address and MAC_MDIO_Data registers as long as this bit is set.<br/> For write transfers, the application must first write 16-bit data in the GDI field (and also RA field when C45E is set) in MAC_MDIO_Data register before setting this bit. When C45E is set, it should also write into the RA field of MAC_MDIO_Data register before initiating a read transfer. When a read transfer is completed (GB=0), the data read from the PHY register is valid in the GD field of the MAC_MDIO_Data register.<br/> Note: Even if the addressed PHY is not present, there is no</p> |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                            |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | change in the functionality of this bit. Access restriction applies.<br>Setting 1 sets. Self-cleared. Setting 0 has no effect.<br>Values:<br>1'b0: GMII Busy is disabled<br>1'b1: GMII Busy is enabled |

**GMAC MAC MDIO DATA**Address: Operational Base + offset (0x0204)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                 |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17 | RO   | 0x0000      | reserved                                                                                                                                                                                                                    |
| 16    | RW   | 0x0         | RA<br>Register Address<br>This field is valid only when C45E is set. It contains the Register Address in the PHY to which the MDIO frame is intended for.                                                                   |
| 15:0  | RW   | 0x0000      | GD<br>GMII Data<br>This field contains the 16-bit data value read from the PHY or RevMII after a Management Read operation or the 16-bit data value to be written to the PHY or RevMII before a Management Write operation. |

**GMAC MAC ARP ADDRESS**Address: Operational Base + offset (0x0210)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                        |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | ARPPA<br>ARP Protocol Address<br>This field contains the IPv4 Destination Address of the MAC.<br>This address is used for perfect match with the Protocol Address of Target field in the received ARP packet.<br>This field is available only when the Enable IPv4 ARP Offload option is selected. |

**GMAC MAC CSR SW CTRL**Address: Operational Base + offset (0x0230)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x00000000  | reserved                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0    | RW   | 0x0         | RCWE<br>Register Clear on Write 1 Enable<br>When this bit is set, the access mode of some register fields changes to Clear on Write 1, the application needs to set that respective bit to 1 to clear it. When this bit is reset, the access mode of these register fields remain as Clear on Read.<br>Values:<br>1'b0: Register Clear on Write 1 is disabled<br>1'b1: Register Clear on Write 1 is enabled |

**GMAC MAC EXT CFG1**Address: Operational Base + offset (0x0238)

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:10 | RO   | 0x000000    | reserved    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:8        | RW          | 0x0                | SPLM<br>Split Mode<br>These bits indicate the mode of splitting the incoming Rx packets.<br>They are<br>Values:<br>0x0 (L3L4): Split at L3/L4 header<br>0x1 (L2OFST): Split at L2 header with an offset. Always Split at SPLOFST bytes from the beginning of Length/Type field of the Frame<br>0x2 (COMBN): Combination mode: Split similar to SPLM=00 for IP packets that are untagged or tagged and VLAN stripped<br>0x3 (RSVD): Reserved |
| 7          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 6:0        | RW          | 0x02               | SPLOFST<br>Split Offset<br>These bits indicate the value of offset from the beginning of Length/Type field at which header split should take place when the appropriate SPLM is selected. The reset value of this field is 2 bytes indicating a split at L2 header. Value is in terms of bytes.                                                                                                                                             |

**GMAC MAC ADDRESS0 HIGH**Address: **Operational Base** + offset (0x0300)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | AE<br>Address Enable<br>This bit is always set to 1.<br>Values:<br>1'b0: This bit must be always set to 1<br>1'b1: This bit is always set to 1                                                                                                         |
| 30:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                               |
| 15:0       | RW          | 0xffff             | ADDRHI<br>MAC Address0[47:32]<br>This field contains the upper 16 bits [47:32] of the first 6-byte MAC address. The MAC uses this field for filtering the received packets and inserting the MAC address in the Transmit Flow Control (Pause) Packets. |

**GMAC MAC ADDRESS0 LOW**Address: **Operational Base** + offset (0x0304)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0xffffffff         | ADDRLO<br>MAC Address0[31:0]<br>This field contains the lower 32 bits of the first 6-byte MAC address. The MAC uses this field for filtering the received packets and inserting the MAC address in the Transmit Flow Control (Pause) Packets. |

**GMAC MMC CONTROL**Address: **Operational Base** + offset (0x0700)

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

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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.</p> <p>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.</p> <p>When reset, the MMC Counters are not updated for dropped Broadcast packets.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Update MMC Counters for Dropped Broadcast Packets is disabled</li> <li>1'b1: Update MMC Counters for Dropped Broadcast Packets is enabled</li> </ul>                                                                                                           |
| 7:6 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 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 0xFFFF0.<br/>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Full-Half Preset is disabled</li> <li>1'b1: Full-Half Preset is enabled</li> </ul> |
| 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.<br/>Access restriction applies. Self-cleared. Setting 0 clears. Setting 1 sets.<br/>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Counters Preset is disabled</li> <li>1'b1: Counters Preset is enabled</li> </ul>                                                                                                                                                                                                                                                   |
| 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:</p> <ul style="list-style-type: none"> <li>1'b0: MMC Counter Freeze is disabled</li> <li>1'b1: MMC Counter Freeze is enabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                                            |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                    |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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.</p> <p>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.</p> <p>Values:<br/>1'b0: Counter Stop Rollover is disabled<br/>1'b1: Counter Stop Rollover is enabled</p>                                                            |
| 0   | RW   | 0x0         | <p>CNTRST<br/>Counters Reset<br/>When this bit is set, all counters are reset. This bit is cleared automatically after 1 clock cycle.</p> <p>Access restriction applies. Self-cleared. Setting 0 clears. Setting 1 sets.</p> <p>Values:<br/>1'b0: Counters are not reset<br/>1'b1: All counters are reset</p>  |

**GMAC MMC RX INTERRUPT**Address: Operational Base + offset (0x0704)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | RO   | 0x000       | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 21    | RO   | 0x0         | <p>RXFOVPIS<br/>MMC Receive FIFO Overflow Packet Counter Interrupt Status<br/>This bit is set when the rxfifooverflow counter reaches half of the maximum value or the maximum value.</p> <p>Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/>1'b0: MMC Receive FIFO Overflow Packet Counter Interrupt Status not detected<br/>1'b1: MMC Receive FIFO Overflow Packet Counter Interrupt Status detected</p> |
| 20    | RO   | 0x0         | <p>RXPAUSPIS<br/>MMC Receive Pause Packet Counter Interrupt Status<br/>This bit is set when the rxpausepackets counter reaches half of the maximum value or the maximum value.</p> <p>Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/>0x0 (INACTIVE): MMC Receive Pause Packet Counter Interrupt Status not detected<br/>0x1 (ACTIVE): MMC Receive Pause Packet Counter Interrupt Status detected</p>      |
| 19    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18         | RO          | 0x0                | <p><b>RXLENERPIS</b><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><b>RXCRCERPI</b><br/>           MMC Receive CRC Error Packet Counter Interrupt Status<br/>           This bit is set when the rxcrcerror counter reaches half of the maximum value or the maximum value.<br/>           Access restriction applies. Clears on read. Self-set to 1 on internal event.<br/>           Values:<br/>           1'b0: MMC Receive CRC Error Packet Counter Interrupt Status not detected<br/>           1'b1: MMC Receive CRC Error Packet Counter Interrupt Status detected</p>                         |
| 4          | RO          | 0x0                | <p><b>RXMCGPIS</b><br/>           MMC Receive Multicast Good Packet Counter Interrupt Status<br/>           This bit is set when the rxmulticastpackets_g counter reaches half of the maximum value or the maximum value.<br/>           Access restriction applies. Clears on read. Self-set to 1 on internal event.<br/>           Values:<br/>           1'b0: MMC Receive Multicast Good Packet Counter Interrupt Status not detected<br/>           1'b1: MMC Receive Multicast Good Packet Counter Interrupt Status detected</p> |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2          | RO          | 0x0                | <p><b>RXGOCTIS</b><br/>           MMC Receive Good Octet Counter Interrupt Status<br/>           This bit is set when the rxoctetcount_g counter reaches half of the maximum value or the maximum value.<br/>           Access restriction applies. Clears on read. Self-set to 1 on internal event.<br/>           Values:<br/>           1'b0: MMC Receive Good Octet Counter Interrupt Status not detected<br/>           1'b1: MMC Receive Good Octet Counter Interrupt Status detected</p>                                        |
| 1          | RO          | 0x0                | <p><b>RXGBOCTIS</b><br/>           MMC Receive Good Bad Octet Counter Interrupt Status<br/>           This bit is set when the rxoctetcount_gb counter reaches half of the maximum value or the maximum value.<br/>           Access restriction applies. Clears on read. Self-set to 1 on internal event.<br/>           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>                          |

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

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 23    | RO   | 0x0         | <p>TXPAUSPIS<br/>MMC Transmit Pause Packet Counter Interrupt Status<br/>This bit is set when the txpausepacketerror counter reaches half of the maximum value or the maximum value.<br/>Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/>0x0 (INACTIVE): MMC Transmit Pause Packet Counter Interrupt Status not detected<br/>0x1 (ACTIVE): MMC Transmit Pause Packet Counter Interrupt Status detected</p> |
| 22    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 21    | RO   | 0x0         | <p>TXGPKTIS<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:<br/>1'b0: MMC Transmit Good Packet Counter Interrupt Status not detected<br/>1'b1: MMC Transmit Good Packet Counter Interrupt Status detected</p>                          |
| 20    | RO   | 0x0         | <p>TXGOCTIS<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:<br/>1'b0: MMC Transmit Good Octet Counter Interrupt Status not detected<br/>1'b1: MMC Transmit Good Octet Counter Interrupt Status detected</p>                              |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19    | RO   | 0x0         | <p><b>TXCARERPIS</b><br/> MMC Transmit Carrier Error Packet Counter Interrupt Status<br/> This bit is set when the txcarriererror counter reaches half of the maximum value or the maximum value.<br/> Access restriction applies. Clears on read. Self-set to 1 on internal event.<br/> Values:<br/> 1'b0: MMC Transmit Carrier Error Packet Counter Interrupt Status not detected<br/> 1'b1: MMC Transmit Carrier Error Packet Counter Interrupt Status detected</p>           |
| 18:14 | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 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.<br/> Values:<br/> 1'b0: MMC Transmit Underflow Error Packet Counter Interrupt Status not detected<br/> 1'b1: MMC Transmit Underflow Error Packet Counter Interrupt Status detected</p> |
| 12:2  | RO   | 0x000       | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 1     | RO   | 0x0         | <p><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.<br/> 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.<br/> Values:<br/> 1'b0: MMC Transmit Good Bad Octet Counter Interrupt Status not detected<br/> 1'b1: MMC Transmit Good Bad Octet Counter Interrupt Status detected</p>                             |

**GMAC MMC RX INTERRUPT MASK**

Address: Operational Base + offset (0x070C)

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:22 | RO   | 0x000       | reserved    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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.<br/>           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>RXLENERPIM</b><br/>           MMC Receive Length Error Packet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the rxlengtherror counter reaches half of the maximum value or the maximum value.<br/>           Values:<br/>           1'b0: MMC Receive Length Error Packet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Receive Length Error Packet Counter Interrupt Mask is enabled</p>            |
| 17:11      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 10         | RW          | 0x0                | <p><b>RXPAUSPIM</b><br/>           MMC Receive Pause Packet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the rxpausepackets counter reaches half of the maximum value or the maximum value.<br/>           Values:<br/>           0x0 (DISABLE): MMC Receive Pause Packet Counter Interrupt Mask is disabled<br/>           0x1 (ENABLE): MMC Receive Pause Packet Counter Interrupt Mask is enabled</p>                |
| 9:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 5          | RW          | 0x0                | <p><b>RXCRCERPM</b><br/>           MMC Receive CRC Error Packet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the rxcrcerror 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                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

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

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 23    | RW   | 0x0         | <p><b>TXPAUSPIM</b><br/>           MMC Transmit Pause Packet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the txpausepackets counter reaches half of the maximum value or the maximum value.<br/>           Values:<br/>           0x0 (DISABLE): MMC Transmit Pause Packet Counter Interrupt Mask is disabled<br/>           0x1 (ENABLE): MMC Transmit Pause Packet Counter Interrupt Mask is enabled</p> |
| 22    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 21    | RW   | 0x0         | <p><b>TXGPKTIM</b><br/>           MMC Transmit Good Packet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the txpacketcount_g counter reaches half of the maximum value or the maximum value.<br/>           Values:<br/>           1'b0: MMC Transmit Good Packet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Transmit Good Packet Counter Interrupt Mask is enabled</p>                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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>TXCARERPIM</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>TXUFLWERPIM</b><br/>           MMC Transmit Underflow Error Packet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the txunderflowerror counter reaches half of the maximum value or the maximum value.<br/>           Values:<br/>           1'b0: MMC Transmit Underflow Error Packet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Transmit Underflow Error Packet Counter Interrupt Mask is enabled</p> |
| 12:2       | RO          | 0x000              | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1          | RW          | 0x0                | <p><b>TXGBPKTIM</b><br/>           MMC Transmit Good Bad Packet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the txpacketcount_gb counter reaches half of the maximum value or the maximum value.<br/>           Values:<br/>           1'b0: MMC Transmit Good Bad Packet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Transmit Good Bad Packet Counter Interrupt Mask is enabled</p>                        |
| 0          | RW          | 0x0                | <p><b>TXGBOCTIM</b><br/>           MMC Transmit Good Bad Octet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the txoctetcount_gb counter reaches half of the maximum value or the maximum value.<br/>           Values:<br/>           1'b0: MMC Transmit Good Bad Octet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Transmit Good Bad Octet Counter Interrupt Mask is enabled</p>                            |

**GMAC TX OCTET COUNT GOOD BAD**Address: **Operational Base** + offset (0x0714)

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

**GMAC TX PACKET COUNT GOOD BAD**Address: Operational Base + offset (0x0718)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | TXPKTGB<br>Tx Packet Count Good Bad<br>This field indicates the number of good and bad packets transmitted, exclusive of retried packets. |

**GMAC TX UNDERFLOW ERROR PACKETS**Address: Operational Base + offset (0x0748)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | TXUNDRFLW<br>Tx Underflow Error Packets<br>This field indicates the number of packets aborted because of packets underflow error. |

**GMAC TX CARRIER ERROR PACKETS**Address: Operational Base + offset (0x0760)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | TXCARR<br>Tx Carrier Error Packets<br>This field indicates the number of packets aborted because of carrier sense error (no carrier or loss of carrier). |

**GMAC TX OCTET COUNT GOOD**Address: Operational Base + offset (0x0764)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | TXOCTG<br>Tx Octet Count Good<br>This field indicates the number of bytes transmitted, exclusive of preamble, only in good packets. |

**GMAC TX PACKET COUNT GOOD**Address: Operational Base + offset (0x0768)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | TXPKTG<br>Tx Packet Count Good<br>This field indicates the number of good packets transmitted. |

**GMAC TX PAUSE PACKETS**Address: Operational Base + offset (0x0770)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | TXPAUSE<br>Tx Pause Packets<br>This field indicates the number of good Pause packets transmitted. |

**GMAC RX PACKETS COUNT GOOD BAD**Address: Operational Base + offset (0x0780)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | RXPKTGB<br>Rx Packets Count Good Bad<br>This field indicates the number of good and bad packets received. |

**GMAC RX OCTET COUNT GOOD BAD**Address: **Operational Base** + offset (0x0784)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | RXOCTGB<br>Rx Octet Count Good Bad<br>This field indicates the number of bytes received, exclusive of preamble, in good and bad packets. |

**GMAC RX OCTET COUNT GOOD**Address: **Operational Base** + offset (0x0788)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | RXOCTG<br>Rx Octet Count Good<br>This field indicates the number of bytes received, exclusive of preamble, only in good packets. |

**GMAC RX MULTICAST PACKETS GOOD**Address: **Operational Base** + offset (0x0790)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | RXMCASTG<br>Rx Multicast Packets Good<br>This field indicates the number of good multicast packets received. |

**GMAC RX CRC ERROR PACKETS**Address: **Operational Base** + offset (0x0794)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | RXCRCERR<br>Rx CRC Error Packets<br>This field indicates the number of packets received with CRC error. |

**GMAC RX LENGTH ERROR PACKETS**Address: **Operational Base** + offset (0x07C8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | RXLENERR<br>Rx Length Error Packets<br>This field indicates the number of packets received with length error (Length Type field not equal to packet size), for all packets with valid length field. |

**GMAC RX PAUSE PACKETS**Address: **Operational Base** + offset (0x07D0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | RXPAUSEPKT<br>Rx Pause Packets<br>This field indicates the number of good and valid Pause packets received. |

**GMAC RX FIFO OVERFLOW PACKETS**Address: **Operational Base** + offset (0x07D4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | RXFIFOVFL<br>Rx FIFO Overflow Packets<br>This field indicates the number of missed received packets because of FIFO overflow. |

**GMAC MMC IPC RX INTERRUPT MASK**Address: **Operational Base** + offset (0x0800)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                 |
| 29         | RW          | 0x0                | 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>RXIPV6GPIM<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>RXIPV4GPIM<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                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27    | RO   | 0x0         | <p>RXTCPEROIS<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>RXUDPEROIS<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>RXIPV6HEROIS<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>RXIPV4HEROIS<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                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13  | RO   | 0x0         | <p>RXICMPERPIS<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> <p>1'b0: MMC Receive ICMP Error Packet Counter Interrupt Status not detected<br/>1'b1: MMC Receive ICMP Error Packet Counter Interrupt Status detected</p>                          |
| 12  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 11  | RO   | 0x0         | <p>RXTCPERPIS<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> <p>1'b0: MMC Receive TCP Error Packet Counter Interrupt Status not detected<br/>1'b1: MMC Receive TCP Error Packet Counter Interrupt Status detected</p>                               |
| 10  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 9   | RO   | 0x0         | <p>RXUDPERPIS<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> <p>1'b0: MMC Receive UDP Error Packet Counter Interrupt Status not detected<br/>1'b1: MMC Receive UDP Error Packet Counter Interrupt Status detected</p>                               |
| 8:7 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 6   | RO   | 0x0         | <p>RXIPV6HERPIS<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> <p>1'b0: MMC Receive IPV6 Header Error Packet Counter Interrupt Status not detected<br/>1'b1: MMC Receive IPV6 Header Error Packet Counter Interrupt Status detected</p> |
| 5   | RO   | 0x0         | <p>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:</p> <p>1'b0: MMC Receive IPV6 Good Packet Counter Interrupt Status not detected</p>                                                                                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |             |                    | 1'b1: MMC Receive IPV6 Good Packet Counter Interrupt Status detected                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 4:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1          | RO          | 0x0                | <p><b>RXIPV4HERPIS</b><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.<br/>           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><b>RXIPV4GPIS</b><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.<br/>           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><b>RXIPV4GDPKT</b><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><b>RXIPV4HDRERRPKT</b><br/>           RxIPv4 Header Error Packets<br/>           This field indicates the number of IPv4 datagrams received with header (checksum, length, or version mismatch) errors.</p> |

#### **GMAC\_RXIPV6\_GOOD\_PACKETS**

Address: **Operational Base** + offset (0x0824)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p><b>RXIPV6GDPKT</b><br/>           RxIPv6 Good Packets<br/>           This field indicates the number of good IPv6 datagrams received with the TCP, UDP, or ICMP payload.</p> |

#### **GMAC\_RXIPV6\_HEADER\_ERROR\_PACKETS**

Address: **Operational Base** + offset (0x0828)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | 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         | RXUDPPERPKT<br>RxUDP Error Packets<br>This field indicates the number of good IP datagrams received whose UDP payload has a checksum error. |

**GMAC\_RXTCP\_ERROR\_PACKETS**Address: **Operational Base** + offset (0x083C)

| <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         | RXTCPERRORT<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         | RXICMPERRORT<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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 24         | RW          | 0x0                | TXTSSTSM<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.<br>Values:<br>1'b0: Transmit Timestamp Status Mode is disabled<br>1'b1: Transmit Timestamp Status Mode is enabled |
| 23:19      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 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>TSEVNNTENA</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   | 0x0         | <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>                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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'.<br/>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>                                                                                                                           |
| 9   | RW   | 0x0         | <p><b>TSCTRLSSR</b><br/>Timestamp Digital or Binary Rollover Control<br/>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.<br/>Values:<br/>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><b>TSENALL</b><br/>Enable Timestamp for All Packets<br/>When this bit is set, the timestamp snapshot is enabled for all packets received by the MAC.<br/>Values:<br/>1'b0: Timestamp for All Packets disabled<br/>1'b1: Timestamp for All Packets enabled</p>                                                                                                                                                                                                                                                                                                                                                  |
| 7   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 6   | RW   | 0x0         | <p><b>PTGE</b><br/>Presentation Time Generation Enable<br/>When this bit is set the Presentation Time generation will be enabled.<br/>Values:<br/>0x0 (DISABLE): Presentation Time Generation is disabled<br/>0x1 (ENABLE): Presentation Time Generation is enabled</p>                                                                                                                                                                                                                                                                                                                                           |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5   | RW   | 0x0         | <p>TSADDREG<br/>Update Addend Register<br/>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.<br/>Access restriction applies. Setting 1 sets. Self-cleared. Setting 0 has no effect.<br/>Values:<br/>1'b0: Addend Register is not updated<br/>1'b1: Addend Register is updated</p>                                                                                                                                                                                                                                                                                                                                           |
| 4   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 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.<br/>Access restriction applies. Setting 1 sets. Self-cleared. Setting 0 has no effect.<br/>Values:<br/>1'b0: Timestamp is not updated<br/>1'b1: Timestamp is updated</p>                    |
| 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.<br/>Access restriction applies. Setting 1 sets. Self-cleared. Setting 0 has no effect.<br/>Values:<br/>1'b0: Timestamp is not initialized<br/>1'b1: Timestamp is initialized</p> |
| 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.<br/>Values:<br/>1'b0: Coarse method is used to update system timestamp<br/>1'b1: Fine method is used to update system timestamp</p>                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | RW   | 0x0         | <p>TSENA<br/>Enable Timestamp</p> <p>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        | <p>SSINC<br/>Sub-second Increment Value</p> <p>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.</p> |
| 15:0  | RO   | 0x0000      | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

**GMAC MAC SYSTEM TIME SECS**Address: Operational Base + offset (0x0B08)

| Bit  | Attr | Reset Value | Description                                                                                                                                     |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | <p>TSS<br/>Timestamp Second</p> <p>The value in this field indicates the current value in seconds of the System Time maintained by the MAC.</p> |

**GMAC MAC SYSTEM TIME NS**Address: Operational Base + offset (0x0B0C)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                            |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                               |
| 30:0 | RW   | 0x00000000  | <p>TSSS<br/>Timestamp Sub Seconds</p> <p>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.</p> |

**GMAC MAC SYS TIME SECS UPDATE**Address: Operational Base + offset (0x0B10)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | <p>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.</p> <p>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, <math>2^{32} - 2</math>).</p> |

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 29:25      | RO          | 0x00               | <p>ATsns<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>                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 24         | RO          | 0x0                | <p>ATsstm<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.<br/>Values:<br/>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).<br/>Values:<br/>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.<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.<br/>Values:<br/>1'b0: Timestamp Target Time Error status not detected<br/>1'b1: Timestamp Target Time Error status detected</p>                                                                                                                                                                                                                                                                                                                        |

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

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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.</p> <p>Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:</p> <p>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         | TXTSHI<br>Transmit Timestamp Status High<br>This field contains the lower 32 bits of the Seconds field of Transmit packet's captured timestamp. |

**GMAC MAC AUXILIARY CONTROL**Address: **Operational Base** + offset (0x0B40)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 4          | RW          | 0x0                | ATSEN0<br>Auxiliary Snapshot 0 Enable<br>This bit controls the capturing of Auxiliary Snapshot Trigger 0. When this bit is set, the auxiliary snapshot of the event on ptp_aux_trig_i[0] input is enabled. When this bit is reset, the events on this input are ignored.<br>Values:<br>0x0 (DISABLE): Auxiliary Snapshot 0 is disabled<br>0x1 (ENABLE): Auxiliary Snapshot 0 is enabled                                                                              |
| 3:1        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0          | RW          | 0x0                | ATSFC<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.<br>Access restriction applies. Setting 1 sets. Self-cleared. Setting 0 has no effect.<br>Values:<br>1'b0: Auxiliary Snapshot FIFO Clear is disabled<br>1'b1: Auxiliary Snapshot FIFO Clear is enabled |

**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         | AUXTSLO<br>Auxiliary Timestamp<br>Contains the lower 31 bits (nanoseconds field) of the auxiliary timestamp. |

**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       | RO          | 0x00000000         | AUXTSHI<br>Auxiliary Timestamp<br>Contains the lower 32 bits of the Seconds field of the auxiliary timestamp. |

**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         | TSIC<br>Timestamp Ingress Correction<br>This field contains the ingress path correction value as defined by the Ingress Correction expression. |

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

**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               | 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. |
| 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_rxd_i) of MAC and the actual point (GMII/MII) where the ingress timestamp is taken.        |
| 7:0        | RO          | 0x00               | reserved                                                                                                                                                                                                                              |

**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_txd_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_txd_o) of the MAC. |
| 7:0        | RO          | 0x00               | reserved                                                                                                                                                                                                                                  |

**GMAC MAC PPS CONTROL**Address: Operational Base + offset (0x0B70)

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

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | RW   | 0x0         | <p>MCGREN0<br/>MCGR Mode Enable for PPS0 Output<br/>This field enables the 0th PPS instance to operate in PPS or MCGR mode. When set it operates in MCGR mode and on reset it operates in PPS mode.</p> <p>Values:</p> <p>0x0 (PPS): 0th PPS instance is enabled to operate in PPS mode<br/>0x1 (MCGR): 0th PPS instance is enabled to operate in MCGR mode</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 6:5 | RW   | 0x0         | <p>TRGTMODSEL0<br/>Target Time Register Mode for PPS0 Output<br/>This field indicates the Target Time registers (MAC_PPS0_Target_Time_Seconds and MAC_PPS0_Target_Time_Nanoseconds) mode for PPS0 output signal:</p> <p>Values:</p> <p>0x0 (ONLY_INT): Target Time registers are programmed only for generating the interrupt event. The Flexible PPS function must not be enabled in this mode, otherwise spurious transitions may be observed on the corresponding ptp_pps_o output port<br/>0x1 (RSVD): Reserved<br/>0x2 (INT_ST): Target Time registers are programmed for generating the interrupt event and starting or stopping the PPS0 output signal generation<br/>0x3 (ONLY_ST): Target Time registers are programmed only for starting or stopping the PPS0 output signal generation. No interrupt is asserted</p>                                                                                                                                                |
| 4   | RW   | 0x0         | <p>PPSEN0<br/>Flexible PPS Output Mode Enable<br/>When this bit is set, Bits[3:0] function as PPSCMD. When this bit is reset, Bits[3:0] function as PPSCTRL (Fixed PPS mode).</p> <p>Values:</p> <p>0x0 (DISABLE): Flexible PPS Output Mode is disabled<br/>0x1 (ENABLE): Flexible PPS Output Mode is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 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:<br/>4'b0001: The binary rollover is 2 Hz, and the digital rollover is 1 Hz.<br/>4'b0010: The binary rollover is 4 Hz, and the digital rollover is 2 Hz.<br/>4'b0011: The binary rollover is 8 Hz, and the digital rollover is 4 Hz.<br/>4'b0100: The binary rollover is 16 Hz, and the digital rollover is 8 Hz.<br/>...<br/>4'b1111: The binary rollover is 32.768 KHz and the digital rollover is 16.384 KHz.</p> <p>Note:</p> <p>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.</p> |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | <p>The actual clock is of different frequency that gets synchronized every second. For example:</p> <ol style="list-style-type: none"> <li>When PPSCTRL = 0001, the PPS (1 Hz) has a low period of 537 ms and a high period of 463 ms.</li> <li>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>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 MAC PPS0 TARGET TIME SECONDS**Address: **Operational Base** + offset (0x0B80)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | <p>TSTRH0<br/>PPS Target Time Seconds Register<br/>This field stores the time in seconds. When the timestamp value matches or exceeds both Target Timestamp registers, the MAC starts or stops the PPS signal output and generates an interrupt (if enabled) based on Target Time mode selected for the corresponding PPS output in the MAC_PPS_Control register. If DWC_EQOS_FLEXI_PPS_OUT_EN is enabled in the configuration and PTGE field of MAC_Timestamp_Control Register is set with Presentation time control set in recovery mode, then these bits indicate the TPT being programmed by the application and in generation mode it indicates the CPT generated at the sampled trigger.</p> |

**GMAC MAC PPS0 TARGET TIME NS**Address: **Operational Base** + offset (0x0B84)

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31  | RW   | 0x0         | <p>TRGTTBUSY0<br/>PPS Target Time Register Busy<br/>The MAC sets this bit when the PPSCMD0 field in the MAC_PPS_Control register is programmed to 010 or 011. Programming the PPSCMD0 field to 010 or 011 instructs the MAC to synchronize the Target Time Registers to the PTP clock domain. The MAC clears this bit after synchronizing the Target Time Registers to the PTP clock domain. The application must not update the Target Time Registers when this bit is read as 1. Otherwise, the synchronization of the previous programmed time gets corrupted.<br/>Values:<br/>0x0 (INACTIVE): PPS Target Time Register Busy status is not detected<br/>0x1 (ACTIVE): PPS Target Time Register Busy is detected</p> |

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30:0 | RW   | 0x00000000  | <p>TTSL0<br/>Target Time Low for PPS Register<br/>This register stores the time in (signed) nanoseconds. When the value of the timestamp matches the value in both Target Timestamp registers, the MAC starts or stops the PPS signal output and generates an interrupt (if enabled) based on the TRGTMODSEL0 field (Bits [6:5]) in MAC_PPS_Control.</p> <p>When the TSCTRLSSR bit is reset in the MAC_Timestamp_Control register, this value should be (time in ns / 0.465). The actual start or stop time of the PPS signal output may have an error margin up to one unit of sub-second increment value.</p> <p>When the TSCTRLSSR bit is set in the MAC_Timestamp_Control register, this value should not exceed 0x3B9A_C9FF. The actual start or stop time of the PPS signal output may have an error margin up to one unit of sub-second increment value.</p> <p>Access restriction applies. Setting 1 sets. Self-cleared. Setting 0 has no effect.</p> |

**GMAC MAC PPS0 INTERVAL**Address: **Operational Base** + offset (0x0B88)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | <p>PPSINT0<br/>PPS Output Signal Interval<br/>These bits store the interval between the rising edges of PPS0 signal output. The interval is stored in terms of number of units of sub-second increment value.<br/>You need to program one value less than the required interval. For example, if the PTP reference clock is 50 MHz (period of 20 ns), and desired interval between the rising edges of PPS0 signal output is 100 ns (that is, 5 units of sub-second increment value), you should program value 4 (5-1) in this register.</p> |

**GMAC MAC PPS0 WIDTH**Address: **Operational Base** + offset (0x0B8C)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | <p>PPSWIDTH0<br/>PPS Output Signal Width<br/>These bits store the width between the rising edge and corresponding falling edge of PPS0 signal output. The width is stored in terms of number of units of sub-second increment value.<br/>You need to program one value less than the required interval. For example, if PTP reference clock is 50 MHz (period of 20 ns), and width between the rising and corresponding falling edges of PPS0 signal output is 80 ns (that is, four units of sub-second increment value), you should program value 3 (4-1) in this register.<br/>Note: The value programmed in this register must be lesser than the value programmed in MAC_PPS0_Interval.</p> |

**GMAC MTL OPERATION MODE**Address: **Operational Base** + offset (0x0C00)

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:10 | RO   | 0x00000000  | reserved    |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9   | RW   | 0x0         | <p>CNTCLR<br/>Counters Reset<br/>When this bit is set, all counters are reset. This bit is cleared automatically after 1 clock cycle.<br/>If this bit is set along with CNT_PRESET bit, CNT_PRESET has precedence.<br/>Access restriction applies. Setting 1 sets. Self-cleared. Setting 0 has no effect.<br/>Values:<br/>0x0 (DISABLE): Counters are not reset<br/>0x1 (ENABLE): All counters are reset</p>  |
| 8   | RW   | 0x0         | <p>CNTPRST<br/>Counters Reset<br/>When this bit is set, all counters are reset. This bit is cleared automatically after 1 clock cycle.<br/>If this bit is set along with CNT_PRESET bit, CNT_PRESET has precedence.<br/>Access restriction applies. Setting 1 sets. Self-cleared. Setting 0 has no effect.<br/>Values:<br/>0x0 (DISABLE): Counters are not reset<br/>0x1 (ENABLE): All counters are reset</p> |
| 7:2 | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1   | RW   | 0x0         | <p>DTXSTS<br/>Drop Transmit Status<br/>When this bit is set, the Tx packet status received from the MAC is dropped in the MTL. When this bit is reset, the Tx packet status received from the MAC is forwarded to the application.<br/>Values:<br/>0x0 (DISABLE): Drop Transmit Status is disabled<br/>0x1 (ENABLE): Drop Transmit Status is enabled</p>                                                      |
| 0   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                      |

**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><b>FIFOSEL</b><br/> <b>FIFO Selected for Access</b><br/> This field indicates the FIFO selected for debug access:<br/> Values:<br/> 2'b00: Tx FIFO<br/> 2'b01: Tx Status FIFO (only read access when SLVMOD is set)<br/> 2'b10: TSO FIFO (cannot be accessed when SLVMOD is set)<br/> 2'b11: Rx FIFO</p>                                                                                                                                                                                       |
| 11         | RW          | 0x0                | <p><b>FIFOWREN</b><br/> <b>FIFO Write Enable</b><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 FDBGEN bit is 0.<br/> Access restriction applies. Self-cleared. Setting 0 clears. Setting 1 sets.<br/> Values:<br/> 1'b0: FIFO Write is disabled<br/> 1'b1: FIFO Write is enabled</p>                                                             |
| 10         | RW          | 0x0                | <p><b>FIFORDEN</b><br/> <b>FIFO Read Enable</b><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 FDBGEN bit is 0.<br/> Access restriction applies. Self-cleared. Setting 0 clears. Setting 1 sets.<br/> Values:<br/> 1'b0: FIFO Read is disabled<br/> 1'b1: FIFO Read is enabled</p>                                                                 |
| 9          | RW          | 0x0                | <p><b>RSTSEL</b><br/> <b>Reset Pointers of Selected FIFO</b><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 FDBGEN 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><b>RSTALL</b><br/> <b>Reset All Pointers</b><br/> When this bit is set, the pointers of all FIFOs are reset when FIFO Debug Access is enabled. This bit must not be written to 1 when FIFO Debug Access is not enabled, that is FDBGEN bit is 0.<br/> Access restriction applies. Self-cleared. Setting 0 clears. Setting 1 sets.<br/> Values:<br/> 1'b0: Reset All Pointers is disabled<br/> 1'b1: Reset All Pointers is enabled</p>                                                          |
| 7          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:5        | RW          | 0x0                | <p>PKTSTATE<br/>Encoded Packet State<br/>This field is used to write the control information to the Tx FIFO or Rx FIFO.</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>BYTEEN<br/>Byte Enables<br/>This field indicates the number of data bytes valid in the data register during Write operation. This is valid only when PKTSTATE is 2'b10 (EOP) and Tx FIFO or Rx FIFO is selected.</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>DBGMOD<br/>Debug Mode Access to FIFO<br/>When this bit is set, it indicates that the current access to the FIFO is read, write, and debug access. In this mode, the following access types are allowed:</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>FDBGGEN<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:15      | RO          | 0x00200            | <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          | 0x0                | <p>BYTEEN<br/>Byte Enables<br/>This field indicates the number of data bytes valid in the data register during Read operation. This is valid only when PKTSTATE is 2'b10 (EOP) and Tx FIFO or Rx FIFO is selected.<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>                                                                     |
| 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.<br/>Tx FIFO:<br/>2'b00: Packet Data<br/>2'b01: Control Word<br/>2'b10: SOP Data<br/>2'b11: EOP Data<br/>Rx FIFO:<br/>2'b00: Packet Data<br/>2'b01: Normal Status<br/>2'b10: Last Status<br/>2'b11: EOP<br/>This field is applicable only for Tx FIFO and Rx FIFO during Read operation.<br/>Values:<br/>2'b00: Packet Data</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |             |                    | 2'b01: Control Word/Normal Status<br>2'b10: SOP Data/Last Status<br>2'b11: EOP Data/EOP                                                                                                                                                                                                                                     |
| 0          | RO          | 0x0                | 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:<br>1. All other fields of this register<br>2. All fields of the MTL_FIFO_Debug_Data register<br>Values:<br>1'b0: FIFO Busy not detected<br>1'b1: FIFO Busy detected |

**GMAC MTL FIFO DEBUG DATA**Address: **Operational Base** + offset (0x0C10)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | 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. |

**GMAC MTL INTERRUPT STATUS**Address: **Operational Base** + offset (0x0C20)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                      |
| 17         | RO          | 0x0                | 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.<br>Values:<br>1'b0: Debug Interrupt status not detected<br>1'b1: Debug Interrupt status detected           |
| 16:1       | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                      |
| 0          | RO          | 0x0                | 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.<br>Values:<br>1'b0: Queue 0 Interrupt status not detected<br>1'b1: Queue 0 Interrupt status detected |

**GMAC MTL TXQ0 OPERATION MODE**Address: **Operational Base** + offset (0x0D00)

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

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:4 | RW   | 0x0         | <p>TTC<br/>Transmit Threshold Control<br/>These bits control the threshold level of the MTL Tx Queue. The transmission starts when the packet size within the MTL Tx Queue is larger than the threshold. In addition, full packets with length less than the threshold are also transmitted. These bits are used only when the TSF bit is reset.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>3'b000: 32 bytes</li> <li>3'b001: 64 bytes</li> <li>3'b010: 96 bytes</li> <li>3'b011: 128 bytes</li> <li>3'b100: 192 bytes</li> <li>3'b101: 256 bytes</li> <li>3'b110: 384 bytes</li> <li>3'b111: 512 bytes</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                       |
| 3:2 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 1   | RW   | 0x0         | <p>TSF<br/>Transmit Store and Forward<br/>When this bit is set, the transmission starts when a full packet resides in the MTL Tx queue. When this bit is set, the TTC values specified in Bits[6:4] of this register are ignored. This bit should be changed only when the transmission is stopped.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Transmit Store and Forward is disabled</li> <li>1'b1: Transmit Store and Forward is enabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0   | RW   | 0x0         | <p>FTQ<br/>Flush Transmit Queue<br/>When this bit is set, the Tx queue controller logic is reset to its default values. Therefore, all the data in the Tx queue is lost or flushed. This bit is internally reset when the flushing operation is complete. Until this bit is reset, you should not write to the MTL_TxQ1_Operation_Mode register. The data which is already accepted by the MAC transmitter is not flushed. It is scheduled for transmission and results in underflow and runt packet transmission.</p> <p>Note: The flush operation is complete only when the Tx queue is empty and the application has accepted the pending Tx Status of all transmitted packets. To complete this flush operation, the PHY Tx clock (clk_tx_i) should be active.</p> <p>Access restriction applies. Setting 1 sets. Self-cleared. Setting 0 has no effect.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Flush Transmit Queue is disabled</li> <li>1'b1: Flush Transmit Queue is enabled</li> </ul> |

**GMAC MTL TXQ0 UNDERFLOW**Address: **Operational Base** + offset (0x0D04)

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:12 | RO   | 0x00000     | reserved    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11         | RO          | 0x0                | <p>UFCNTOVF<br/>Overflow Bit for Underflow Packet Counter<br/>This bit is set every time the Tx queue Underflow Packet Counter field overflows, that is, it has crossed the maximum count. In such a scenario, the overflow packet counter is reset to all-zeros and this bit indicates that the rollover happened.</p> <p>Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:</p> <p>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                | <p>STXSTS<br/>Number of Status Words in Tx Status FIFO of Queue<br/>This field indicates the current number of status in the Tx Status FIFO of this queue. When the DTXSTS bit of MTL_Operation_Mode register is set to 1, this field does not reflect the number of status words in Tx Status FIFO.</p>                       |
| 19         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                       |
| 18:16      | RO          | 0x0                | <p>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.</p>                                                       |
| 15:6       | RO          | 0x000              | reserved                                                                                                                                                                                                                                                                                                                       |
| 5          | RO          | 0x0                | <p>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.</p> <p>Values:</p> <p>1'b0: MTL Tx Status FIFO Full status is not detected<br/>1'b1: MTL Tx Status FIFO Full status is detected</p> |
| 4          | RO          | 0x0                | <p>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.</p> <p>Values:</p> <p>1'b0: MTL Tx Queue Not Empty status is not detected<br/>1'b1: MTL Tx Queue Not Empty status is detected</p>                               |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | RO   | 0x0         | <p>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</p>                                                                                                                                                                                      |
| 2:1 | RO   | 0x0         | <p>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</p>                                                                                                                                       |
| 0   | RO   | 0x0         | <p>TXQPAUSED<br/>Transmit Queue in Pause<br/>When this bit is high and the Rx flow control is enabled, it indicates that the Tx Queue is in the Pause condition (in the full-duplex only mode) because of the following:<br/>1. Reception of the PFC packet for the priorities assigned to the Tx Queue when PFC is enabled<br/>2. Reception of 802.3x Pause packet when PFC is disabled<br/>Values:<br/>1'b0: Transmit Queue in Pause status is not detected<br/>1'b1: Transmit Queue in Pause status is detected</p> |

**GMAC MTL Q0 INTERRUPT CTRL STATUS**Address: **Operational Base** + offset (0x0D2C)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25 | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 24    | RW   | 0x0         | <p>RXOIE<br/>Receive Queue Overflow Interrupt Enable<br/>When this bit is set, the Receive Queue Overflow interrupt is enabled. When this bit is reset, the Receive Queue Overflow interrupt is disabled.<br/>Values:<br/>1'b0: Receive Queue Overflow Interrupt is disabled<br/>1'b1: Receive Queue Overflow Interrupt is enabled</p>                                                                                                                                                                                                                                |
| 23:17 | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 16    | RW   | 0x0         | <p>RXOVFIS<br/>Receive Queue Overflow Interrupt Status<br/>This bit indicates that the Receive Queue had an overflow while receiving the packet. If a partial packet is transferred to the application, the overflow status is set in RDES3[21]. This bit is cleared when the application writes 1 to this bit.<br/>Access restriction applies. Self-set to 1 on internal event. Setting 1 clears. Setting 0 has no effect.<br/>Values:<br/>1'b0: Receive Queue Overflow Interrupt Status not detected<br/>1'b1: Receive Queue Overflow Interrupt Status detected</p> |
| 15:9  | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0   | RW   | 0x0         | <p><b>TXUNFIS</b><br/>Transmit Queue Underflow Interrupt Status<br/>This bit indicates that the Transmit Queue had an underflow while transmitting the packet. Transmission is suspended and an Underflow Error TDES3[2] is set. This bit is cleared when the application writes 1 to this bit.</p> <p>Access restriction applies. Self-set to 1 on internal event. Setting 1 clears. Setting 0 has no effect.</p> <p>Values:<br/>1'b0: Transmit Queue Underflow Interrupt Status not detected<br/>1'b1: Transmit Queue Underflow Interrupt Status detected</p> |

**GMAC MTL RXQ0 OPERATION MODE**Address: **Operational Base** + offset (0x0D30)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18 | RO   | 0x0000      | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 17:14 | RW   | 0x0         | <p><b>RFD</b><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:</p> <p>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</p> <p>The de-assertion is effective only after flow control is asserted. Note: The value must be programmed in such a way to make sure that the threshold is a positive number. When the EHFC is set high, these values are applicable only when the Rx queue size determined by the RQS field of this register, is equal to or greater than 4 KB. For a given queue size, the values ranges between 0 and the encoding for FULL minus (QSIZE - 0.5 KB) and all other values are illegal. Here the term FULL and QSIZE refers to the queue size determined by the RQS field of this register. The width of this field depends on RX FIFO size selected during the configuration. Remaining bits are reserved and read only.</p> |
| 13:12 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 11:8  | RW   | 0x0         | <p><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>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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> |
| 3   | RW   | 0x0         | <p><b>FUP</b><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.<br/>Values:<br/>1'b0: Forward Undersized Good Packets is disabled</p>                                                                                                                                                                                                                                                                                                                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |             |                    | 1'b1: Forward Undersized Good Packets is enabled                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 1:0        | RW          | 0x0                | 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. |

**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                | MISCNTOVF<br>Missed Packet Counter Overflow Bit<br>When set, this bit indicates that the Rx Queue Missed Packet Counter crossed the maximum limit.<br>Access restriction applies. Clears on read. Self-set to 1 on internal event.<br>Values:<br>1'b0: Missed Packet Counter overflow not detected<br>1'b1: Missed Packet Counter overflow detected                                                                                                                                                                                                                                              |
| 26:16      | RO          | 0x000              | MISPKTCNT<br>Missed Packet Counter<br>This field indicates the number of packets missed by the 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. |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 11         | RO          | 0x0                | OVFCNTOVF<br>Overflow Counter Overflow Bit<br>When set, this bit indicates that the Rx Queue Overflow Packet Counter field crossed the maximum limit.<br>Access restriction applies. Clears on read. Self-set to 1 on internal event.<br>Values:<br>1'b0: Overflow Counter overflow not detected<br>1'b1: Overflow Counter overflow detected                                                                                                                                                                                                                                                     |
| 10:0       | RO          | 0x000              | OVPKTCNT<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.<br>Access restriction applies. Clears on read. Self-set to 1 on internal event.                                                                                                                                                                          |

**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                | PRXQ<br>Number of Packets in Receive Queue<br>This field indicates the current number of packets in the Rx Queue. The theoretical maximum value for this field is 256KB/16B = 16K Packets, that is, Max_Queue_Size/Min_Packet_Size.                                                                                                           |
| 15:6       | RO          | 0x000              | reserved                                                                                                                                                                                                                                                                                                                                      |
| 5:4        | RO          | 0x0                | 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                              |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                      |
| 2:1        | RO          | 0x0                | 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                                                                        |
| 0          | RO          | 0x0                | 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 |

**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                | 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:<br>1. sdb_perch_tx_intr_o[] (Transmit Per Channel Interrupt)<br>2. sdb_perch_rx_intr_o[] (Receive Per Channel Interrupt)<br>3. sdb_intr_o (Common Interrupt)<br>It also changes the behavior of the RI/TI bits in the DMA_CH0_Status.<br>2'b00: sdb_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. sdb_intr_o is also asserted when corresponding interrupts are enabled and cleared only when software clears the |

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |             | <p>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</p> <p>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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0    | RW   | 0x0         | <p>SWR<br/>Software Reset</p> <p>When this bit is set, the MAC and the DMA controller reset the logic and all internal registers of the DMA, MTL, and MAC. This bit is automatically cleared after the reset operation is complete in all 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.</p> <p>Note: The reset operation is complete only when all resets in all active clock domains are de-asserted. Therefore, it is essential that all PHY inputs clocks (applicable for the selected PHY interface) are present for software reset completion. The time to complete the software reset operation depends on the frequency of the slowest active clock.</p> <p>Access restriction applies. Setting 1 sets. Self-cleared. Setting 0 has no effect.</p> <p>Values:</p> <p>1'b0: Software Reset is disabled</p> <p>1'b1: Software Reset is enabled</p> |

**GMAC DMA SYSBUS MODE**Address: Operational Base + offset (0x1004)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | RW   | 0x0         | <p>EN_LPI<br/>Enable Low Power Interface (LPI)<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.</p> <p>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.</p> <p>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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 25:24 | RW   | 0x0         | <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:<br/>1'b0: Address-Aligned Beats is disabled<br/>1'b1: Address-Aligned Beats is enabled</p>                                                                                                                                                                                                           |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11  | RW   | 0x0         | <p>EAME<br/>Enhanced Address Mode Enable.<br/>When this bit is set to 1, the DMA master enables the enhanced address mode (40-bit or 48-bit addressing mode). In this mode, the DMA engine uses either the 40- or 48-bit address, depending on the configuration.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>0x0 (DISABLE): Enhanced Address Mode is disabled</li> <li>0x1 (ENABLE): Enhanced Address Mode is enabled</li> </ul>                                                                                                                                                                                                           |
| 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> <ul style="list-style-type: none"> <li>1'b0: Automatic AXI LPI is disabled</li> <li>1'b1: Automatic AXI LPI is enabled</li> </ul>                                                                                                                                                                                                                                            |
| 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. When the FB bit is set to 0, setting this bit has no effect.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: No effect</li> <li>1'b1: AXI Burst Length 16</li> </ul>                                                                                                                                                                                                                                                                                                 |
| 2   | RW   | 0x0         | <p>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.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: No effect</li> <li>1'b1: AXI Burst Length 8</li> </ul>                                                                                                                                                                                                                                                                                                     |
| 1   | RW   | 0x0         | <p>BLEN4<br/>AXI Burst Length 4<br/>When this bit is set to 1 or the FB bit is set to 0, the EQOS-AXI master can select a burst length of 4 on the AXI interface. When the FB bit is set to 0, setting this bit has no effect.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: No effect</li> <li>1'b1: AXI Burst Length 4</li> </ul>                                                                                                                                                                                                                                                                                                     |
| 0   | RW   | 0x0         | <p>FB<br/>Fixed Burst Length<br/>When this bit is set to 1, the EQOS-AXI master initiates burst transfers of specified lengths as given below.</p> <ol style="list-style-type: none"> <li>1. Burst transfers of fixed burst lengths as indicated by the BLEN256, BLEN128, BLEN64, BLEN32, BLEN16, BLEN8, or BLEN4 field</li> <li>2. Burst transfers of length 1</li> </ol> <p>When this bit is set to 0, the EQOS-AXI master initiates burst transfers that are equal to or less than the maximum allowed burst length programmed in Bits[7:1].</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Fixed Burst Length is disabled</li> </ul> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                  |
|------------|-------------|--------------------|-------------------------------------|
|            |             |                    | 1'b1: Fixed Burst Length is enabled |

**GMAC DMA INTERRUPT STATUS**Address: **Operational Base** + offset (0x1008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                             |
| 17         | RO          | 0x0                | <p>MACIS<br/>MAC Interrupt Status</p> <p>This bit indicates an interrupt event in the MAC. To reset this bit to 1'b0, the software must read the corresponding register in the MAC to get the exact cause of the interrupt and clear its source.</p> <p>Values:</p> <p>1'b0: MAC Interrupt Status not detected<br/>1'b1: MAC Interrupt Status detected</p>                                           |
| 16         | RO          | 0x0                | <p>MTLIS<br/>MTL Interrupt Status</p> <p>This bit indicates an interrupt event in the MTL. To reset this bit to 1'b0, the software must read the corresponding register in the MTL to get the exact cause of the interrupt and clear its source.</p> <p>Values:</p> <p>1'b0: MTL Interrupt Status not detected<br/>1'b1: MTL Interrupt Status detected</p>                                           |
| 15:1       | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                             |
| 0          | RO          | 0x0                | <p>DC0IS<br/>DMA Channel 0 Interrupt Status</p> <p>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> <p>1'b0: DMA Channel 0 Interrupt Status not detected<br/>1'b1: DMA Channel 0 Interrupt Status detected</p> |

**GMAC DMA DEBUG STATUS0**Address: **Operational Base** + offset (0x100C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 15:12      | RO          | 0x0                | <p>TPS0<br/>DMA Channel 0 Transmit Process State</p> <p>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> <p>4'b0000: Stopped (Reset or Stop Transmit Command issued)<br/>4'b0001: Running (Fetching Tx Transfer Descriptor)<br/>4'b0010: Running (Waiting for status)<br/>4'b0011: Running (Reading Data from system memory buffer and queuing it to the Tx buffer (Tx FIFO))<br/>4'b0100: Timestamp write state<br/>4'b0101: Reserved for future use<br/>4'b0110: Suspended (Tx Descriptor Unavailable or Tx Buffer Underflow)<br/>4'b0111: Running (Closing Tx Descriptor)</p> |

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:8 | RO   | 0x0         | <p>RPS0<br/>DMA Channel 0 Receive Process State<br/>This field indicates the Rx DMA FSM state for Channel 0. The MSB of this field always returns 0. This field does not generate an interrupt.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>4'b0000: Stopped (Reset or Stop Receive Command issued)</li> <li>4'b0001: Running (Fetching Rx Transfer Descriptor)</li> <li>4'b0010: Reserved for future use</li> <li>4'b0011: Running (Waiting for Rx packet)</li> <li>4'b0100: Suspended (Rx Descriptor Unavailable)</li> <li>4'b0101: Running (Closing the Rx Descriptor)</li> <li>4'b0110: Timestamp write state</li> <li>4'b0111: Running (Transferring the received packet data from the Rx buffer to the system memory)</li> </ul> |
| 7:2  | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 1    | RO   | 0x0         | <p>AXRHSTS<br/>AXI Master Read Channel Status<br/>When high, this bit indicates that the read channel of the AXI master is active, and it is transferring the data.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: AXI Master Read Channel Status not detected</li> <li>1'b1: AXI Master Read Channel Status detected</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0    | RO   | 0x0         | <p>AXWHSTS<br/>AXI Master Write Channel or AHB Master Status<br/>EQOS-AXI Configuration:<br/>When high, this bit indicates that the write channel of the AXI master is active, and it is transferring data.<br/>EQOS-AHB Configuration:<br/>When high, this bit indicates that the AHB master FSMs are in the non-idle state.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: AXI Master Write Channel or AHB Master Status not detected</li> <li>1'b1: AXI Master Write Channel or AHB Master Status detected</li> </ul>                                                                                                                                                                                                            |

**GMAC AXI LPI ENTRY INTERVAL**Address: **Operational Base** + offset (0x1040)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                            |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | RO   | 0x00000000  | reserved                                                                                                                                                                                                               |
| 3:0  | RW   | 0x0         | <p>LPIEI<br/>LPI Entry Interval<br/>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> |

**GMAC DMA CH0 CONTROL**Address: **Operational Base** + offset (0x1100)

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:25 | RO   | 0x00        | reserved    |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24    | RW   | 0x0         | <p>SPH<br/>Split Headers</p> <p>When this bit is set, the DMA splits the header and payload in the Receive path. The DMA writes the header to the Buffer Address1 of RDES0. The DMA writes the payload to the buffer to which the Buffer Address2 is pointing.</p> <p>The software must ensure that the header fits into the Receive buffers. If the header length exceeds the receive buffer size, the DMA does not split the header and payload.</p> <p>This bit is available only if Enable Split Header Structure option is selected.</p> <p>Values:</p> <p>0x0 (DISABLE): Split Headers feature is disabled</p> <p>0x1 (ENABLE): Split Headers feature is enabled</p> |
| 23:21 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 20:18 | RW   | 0x0         | <p>DSL<br/>Descriptor Skip Length</p> <p>This bit specifies the Word, Dword, or Lword number (depending on the 32-bit, 64-bit, or 128-bit bus) to skip between two unchained descriptors. The address skipping starts from the end of the current descriptor to the start of the next descriptor.</p> <p>When the DSL value is equal to zero, the DMA takes the descriptor table as contiguous.</p>                                                                                                                                                                                                                                                                        |
| 17    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 16    | RW   | 0x0         | <p>PBLx8<br/>8xPBL mode</p> <p>When this bit is set, the PBL value programmed in Bits[21:16] in DMA_CH0_Tx_Control and Bits[21:16] in DMA_CH0_Rx_Control is multiplied by eight times. Therefore, the DMA transfers the data in 8, 16, 32, 64, 128, and 256 beats depending on the PBL value.</p> <p>0x0 (DISABLE): 8xPBL mode is disabled</p> <p>0x1 (ENABLE): 8xPBL mode is enabled</p>                                                                                                                                                                                                                                                                                  |
| 15:14 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 13:0  | RW   | 0x0000      | <p>MSS<br/>Maximum Segment Size</p> <p>This field specifies the maximum segment size that should be used while segmenting the packet. This field is valid only if the TSE bit of DMA_CH0_Tx_Control register is set.</p> <p>The value programmed in this field must be more than the configured Datawidth in bytes. It is recommended to use a MSS value of 64 bytes or more.</p>                                                                                                                                                                                                                                                                                          |

**GMAC DMA CH0 TX CONTROL**Address: **Operational Base** + offset (0x1104)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | RO   | 0x000       | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 21:16 | RW   | 0x00        | <p>TxPBL<br/>Transmit Programmable Burst Length</p> <p>These bits indicate the maximum number of beats to be transferred in one DMA block data transfer. The DMA always attempts max burst as specified in PBL each time it starts a burst transfer on the application bus. You can program PBL with any of the following values: 1, 2, 4, 8, 16, or 32. Any other value results in undefined behavior.</p> <p>To transfer more than 32 beats, perform the following steps:</p> |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      |             | <p>1. Set the 8xPBL mode in DMA_CH0_Control register.<br/>2. Set the TxPBL.</p> <p>Note: The maximum value of TxPBL must be less than or equal to half the Tx Queue size (TQS field of MTL_TxQ[n]_Operation_Mode register) in terms of beats. This is required so that the Tx Queue has space to store at least another Tx PBL worth of data while the MTL Tx Queue Controller is transferring data to MAC. For example, in 64-bit data width configurations the total locations in Tx Queue of size 512 bytes is 64, TxPBL and 8xPBL needs to be programmed to less than or equal to 32.</p>                                                                                                                        |
| 15    | RW   | 0x0         | <p>IPBL<br/>Ignore PBL Requirement<br/>When this bit is set, the DMA does not check for PBL number of locations in the MTL before initiating a transfer. If space is not available, the MTL may use handshaking to slow the DMA.<br/>Note: This bit/mode must not be used when multiple Transmit DMA Channels are enabled as it may block other Transmit and Receive DMA Channels from accessing the Read Data Channel of AXI bus until space is available in Transmit Queue for current transfer.<br/>0x0 (DISABLE): Ignore PBL Requirement is disabled<br/>0x1 (ENABLE): Ignore PBL Requirement is enabled</p>                                                                                                     |
| 14:13 | RW   | 0x0         | <p>TSE_MODE<br/>TSE Mode<br/>00: TSO/USO (segmentation functionality is enabled). In this mode, the setting of TSE bit enables the TSO/USO segmentation.<br/>01: UFO with Checksum (UDP Fragmentation over IPv4 with Checksum). In this mode, the setting of TSE bit enables the UDP fragmentation functionality with Checksum for all the UDP packets.<br/>10: UFO without Checksum (UDP Fragmentation over IPv4 with Checksum). In this mode, the setting of TSE bit enables the UDP fragmentation functionality without Checksum for all the UDP packets.<br/>11: Reserved<br/><br/>0x0 (TSO_USO): TSO/USO<br/>0x1 (UFOWC): UFO with Checksum<br/>0x2 (UFOWOC): UFO without Checksum<br/>0x3 (RSVD): Reserved</p> |
| 12    | RW   | 0x0         | <p>TSE<br/>TCP Segmentation Enabled<br/>When this bit is set, the DMA performs the TCP segmentation or UDP Segmentation/Fragmentation for packets in this channel.<br/>The TCP segmentation or UDP packet's segmentation/Fragmentation is done only for those packets for which the TSE bit (TDES0[19]) is set in the Tx Normal descriptor. When this bit is set, the TxPBL value must be greater than 4.<br/>0x0 (DISABLE): TCP Segmentation is disabled<br/>0x1 (ENABLE): TCP Segmentation is enabled</p>                                                                                                                                                                                                          |
| 11:5  | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4   | RW   | 0x0         | <p>OSF<br/>Operate on Second Packet<br/>When this bit is set, it instructs the DMA to process the second packet of the Transmit data even before the status for the first packet is obtained.<br/>0x0 (DISABLE): Operate on Second Packet disabled<br/>0x1 (ENABLE): Operate on Second Packet enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 3:1 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0   | RW   | 0x0         | <p>ST<br/>Start or Stop Transmission Command<br/>When this bit is set, transmission is placed in the Running state. The DMA checks the Transmit list at the current position for a packet to be transmitted.<br/>The DMA tries to acquire descriptor from either of the following positions:<br/>1.The current position in the list<br/>This is the base address of the Transmit list set by the DMA_CH0_TxDesc_List_Address register.<br/>2.The position at which the transmission was previously stopped<br/><br/>If the DMA does not own the current descriptor, the transmission enters the Suspended state and the TBU bit of the DMA_CH0_Status register is set. The Start Transmission command is effective only when the transmission is stopped. If the command is issued before setting the DMA_CH0_TxDesc_List_Address register, the DMA behavior is unpredictable.<br/>When this bit is reset, the transmission process is placed in the Stopped state after completing the transmission of the current packet. The Next Descriptor position in the Transmit list is saved, and it becomes the current position when the transmission is restarted. To change the list address, you need to program DMA_CH0_TxDesc_List_Address register with a new value when this bit is reset. The new value is considered when this bit is set again. The stop transmission command is effective only when the transmission of the current packet is complete or the transmission is in the Suspended state.<br/>0x0 (STOP): Stop Transmission Command<br/>0x1 (START): Start Transmission Command</p> |

**GMAC DMA CH0 RX CONTROL**

Address: Operational Base + offset (0x1108)

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31  | RW   | 0x0         | <p>RPF<br/>Rx Packet Flush<br/>When this bit is set to 1, then DWC_ether_qos automatically flushes the packet from the Rx Queues destined to this DMA Rx Channel, when it is stopped. When this bit remains set and the DMA is re-started by the software driver, the packets residing in the Rx Queues that were received when this RxDMA was stopped, get flushed out. The packets that are received by the MAC after the RxDMA is re-started are routed to the RxDMA. The flushing happens on the Read side of the Rx Queue.<br/>When this bit is set to 0, the DWC_ether_qos not flush the packet in the Rx Queue destined to this RxDMA Channel when it is STOP state. This may in turn cause head-of-line blocking in the</p> |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      |             | corresponding RxQueue.<br>0x0 (DISABLE): Rx Packet Flush is disabled<br>0x1 (ENABLE): Rx Packet Flush is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 30:22 | RO   | 0x000       | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 21:16 | RW   | 0x00        | <p>RxPBL<br/>Receive Programmable Burst Length<br/>These bits indicate the maximum number of beats to be transferred in one DMA block data transfer. The DMA always attempts max burst as specified in PBL each time it starts a burst transfer on the application bus. You can program PBL with any of the following values: 1, 2, 4, 8, 16, or 32. Any other value results in undefined behavior.</p> <p>To transfer more than 32 beats, perform the following steps:</p> <ol style="list-style-type: none"> <li>1. Set the 8xPBL mode in the DMA_CH0_Control register.</li> <li>2. Set the RxPBL.</li> </ol> <p>Note: The maximum value of RxPBL must be less than or equal to half the Rx Queue size (RQS field of MTL_RxQ[n]_Operation_Mode register) in terms of beats. This is required so that the Rx Queue has space to store at least another Rx PBL worth of data while the Rx DMA is transferring a block of data. For example, in 64-bit data width configurations the total locations in Rx Queue of size 512 bytes is 64, so RxPBL and 8xPBL needs to be programmed to less than or equal to 32.</p> |
| 15    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 14:4  | RW   | 0x000       | <p>RBSZ_13_y<br/>Receive Buffer size High<br/>RBSZ[13:0] is split into two fields higher RBSZ_13_y and lower RBSZ_3_0. The RBSZ[13:0] field indicates the size of the Rx buffers specified in bytes. The maximum buffer size is limited to 16K bytes. The buffer size is applicable to payload buffers when split headers are enabled.</p> <p>Note: The buffer size must be a multiple of 4, 8, or 16 depending on the data bus widths (32-bit, 64-bit, or 128-bit respectively). This is required even if the value of buffer address pointer is not aligned to data bus width. Hence the lower RBSZ_3_0 bits are read-only and the value is considered as all-zero. Thus the RBSZ_13_y indicates the buffer size in terms of locations (with the width same as bus-width).</p>                                                                                                                                                                                                                                                                                                                                    |
| 3:1   | RO   | 0x0         | <p>RBSZ_3_0<br/>Receive Buffer size Low<br/>RBSZ[13:0] is split into two fields RBSZ_13_y and RBSZ_3_0. The RBSZ_3_0 is the lower field whose width is based on data bus width of the configuration.</p> <p>This field is of width 2, 3, or 4 bits for 32-bit, 64-bit, or 128-bit data bus width respectively. This field is read-only (RO)</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | RW   | 0x0         | <p>SR<br/>Start or Stop Receive<br/>When this bit is set, the DMA tries to acquire the descriptor from the Receive list and processes the incoming packets. The DMA tries to acquire descriptor from either of the following positions:<br/>1.The current position in the list<br/>This is the address set by the DMA_CH0_RxDesc_List_Address register.<br/>2.The position at which the Rx process was previously stopped<br/>If the DMA does not own the current descriptor, the reception is suspended and the RBU bit of the DMA_CH0_Status register is set. The Start Receive command is effective only when the reception is stopped. If the command is issued before setting the DMA_CH0_RxDesc_List_Address register, the DMA behavior is unpredictable.</p> <p>When this bit is reset, the Rx DMA operation is stopped after the transfer of the current packet. The next descriptor position in the Receive list is saved, and it becomes the current position after the Rx process is restarted. The Stop Receive command is effective only when the Rx process is in the Running (waiting for Rx packet) or Suspended state.</p> <p>0x0 (STOP): Stop Receive<br/>0x1 (START): Start Receive</p> |

**GMAC DMA CH0 TXDESC LIST ADDRESS**Address: **Operational Base** + offset (0x1110)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                   |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0000000   | reserved                                                                                                                                                                                      |
| 7:0  | RW   | 0x00        | <p>TDESNA<br/>Start of Transmit List<br/>This field contains the most-significant 8 or 16 bits of the 40- or 48-bit base address of the first descriptor in the Transmit descriptor list.</p> |

**GMAC DMA CH0 TXDESC LIST ADDRESS**Address: **Operational Base** + offset (0x1114)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | RW   | 0x000000000 | <p>TDESLA<br/>Start of Transmit List<br/>This field contains the base address of the first descriptor in the Transmit descriptor list. The DMA ignores the LSB bits (1:0, 2:0, or 3:0) for 32-bit, 64-bit, or 128-bit bus width and internally takes these bits as all-zero. Therefore, these LSB bits are read-only (RO).<br/>The width of this field depends on the configuration:<br/>31:2 for 32-bit configuration<br/>31:3 for 64-bit configuration<br/>31:4 for 128-bit configuration</p> |
| 2:0  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

**GMAC DMA CH0 RXDESC LIST HAADDRESS**Address: **Operational Base** + offset (0x1118)

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:8 | RO   | 0x0000000   | reserved    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0        | RW          | 0x00               | RDESHA<br>Start of Receive List<br>This field contains the most-significant 8 or 16 bits of the 40-bit or 48-bit base address of the first descriptor in the Rx Descriptor list. |

**GMAC DMA CH0 RXDESC LIST ADDRESS**Address: Operational Base + offset (0x111C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RW          | 0x00000000         | RDESLA<br>Start of Receive List<br>This field contains the base address of the first descriptor in the Rx Descriptor list. The DMA ignores the LSB bits (1:0, 2:0, or 3:0) for 32-bit, 64-bit, or 128-bit bus width and internally takes these bits as all-zero. Therefore, these LSB bits are read-only (RO).<br>The width of this field depends on the configuration:<br>31:2 for 32-bit configuration<br>31:3 for 64-bit configuration<br>31:4 for 128-bit configuration |
| 2:0        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

**GMAC DMA CH0 TXDESC TAIL POINTER**Address: Operational Base + offset (0x1120)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RW          | 0x00000000         | TDTP<br>Transmit Descriptor Tail Pointer<br>This field contains the tail pointer for the Tx descriptor ring. The software writes the tail pointer to add more descriptors to the Tx channel. The hardware tries to transmit all packets referenced by the descriptors between the head and the tail pointer registers.<br>The width of this field depends on the configuration:<br>31:2 for 32-bit configuration<br>31:3 for 64-bit configuration<br>31:4 for 128-bit configuration |
| 2:0        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

**GMAC DMA CH0 RXDESC TAIL POINTER**Address: Operational Base + offset (0x1128)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RW          | 0x00000000         | RDRT<br>Receive Descriptor Tail Pointer<br>This field contains the tail pointer for the Rx descriptor ring. The software writes the tail pointer to add more descriptors to the Rx channel. The hardware tries to write all received packets to the descriptors referenced between the head and the tail pointer registers.<br>The width of this field depends on the configuration:<br>31:2 for 32-bit configuration<br>31:3 for 64-bit configuration<br>31:4 for 128-bit configuration |
| 2:0        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

**GMAC DMA CH0 TXDESC RING LENGTH**Address: Operational Base + offset (0x112C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x000000           | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 9:0        | RW          | 0x000              | <p><b>TDRL</b><br/>Transmit Descriptor Ring Length<br/>This field sets the maximum number of Tx descriptors in the circular descriptor ring. The maximum number of descriptors is limited to 1K descriptors. We recommends a minimum ring descriptor length of 4. For example, You can program any value up to 0x3FF in this field. This field is 10 bits wide, if you program 0x3FF, you can have 1024 descriptors. If you want to have 10 descriptors, program it to a value of 0x9.</p> |

**GMAC DMA CH0 RXDESC RING LENGTH**Address: Operational Base + offset (0x1130)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x000000           | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 9:0        | RW          | 0x000              | <p><b>RDRL</b><br/>Receive Descriptor Ring Length<br/>This register sets the maximum number of Rx descriptors in the circular descriptor ring. The maximum number of descriptors is limited to 1K descriptors. For example, You can program any value up to 0x3FF in this field. This field is 10 bits wide, if you program 0x3FF, you can have 1024 descriptors. If you want to have 10 descriptors, program it to a value of 0x9.</p> |

**GMAC DMA CH0 INTERRUPT ENABLE**Address: Operational Base + offset (0x1134)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 15         | RW          | 0x0                | <p><b>NIE</b><br/>Normal Interrupt Summary Enable<br/>When this bit is set, the normal interrupt summary is enabled. This bit enables the following interrupts in the DMA_CH0_Status register:<br/>Bit 0: Transmit Interrupt<br/>Bit 2: Transmit Buffer Unavailable<br/>Bit 6: Receive Interrupt<br/>Bit 11: Early Receive Interrupt<br/>When this bit is reset, the normal interrupt summary is disabled.<br/>0x0 (DISABLE): Normal Interrupt Summary is disabled<br/>0x1 (ENABLE): Normal Interrupt Summary is enabled</p>                                                                                                                       |
| 14         | RW          | 0x0                | <p><b>AIE</b><br/>Abnormal Interrupt Summary Enable<br/>When this bit is set, the abnormal interrupt summary is enabled. This bit enables the following interrupts in the DMA_CH0_Status register:<br/>Bit 1: Transmit Process Stopped<br/>Bit 7: Rx Buffer Unavailable<br/>Bit 8: Receive Process Stopped<br/>Bit 9: Receive Watchdog Timeout<br/>Bit 10: Early Transmit Interrupt<br/>Bit 12: Fatal Bus Error<br/>Bit 13: Context Descriptor Error<br/>When this bit is reset, the abnormal interrupt summary is disabled.<br/>0x0 (DISABLE): Abnormal Interrupt Summary is disabled<br/>0x1 (ENABLE): Abnormal Interrupt Summary is enabled</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13         | RW          | 0x0                | CDEE<br>Context Descriptor Error Enable<br>When this bit is set along with the AIE bit, the Descriptor error interrupt is enabled. When this bit is reset, the Descriptor error interrupt is disabled.<br>0x0 (DISABLE): Context Descriptor Error is disabled<br>0x1 (ENABLE): Context Descriptor Error is enabled                           |
| 12         | RW          | 0x0                | FBEE<br>Fatal Bus Error Enable<br>When this bit is set along with the AIE bit, the Fatal Bus error interrupt is enabled. When this bit is reset, the Fatal Bus Error error interrupt is disabled.<br>0x0 (DISABLE): Fatal Bus Error is disabled<br>0x1 (ENABLE): Fatal Bus Error is enabled                                                  |
| 11         | RW          | 0x0                | ERIE<br>Early Receive Interrupt Enable<br>When this bit is set along with the NIE bit, the Early Receive interrupt is enabled. When this bit is reset, the Early Receive interrupt is disabled.<br>0x0 (DISABLE): Early Receive Interrupt is disabled<br>0x1 (ENABLE): Early Receive Interrupt is enabled                                    |
| 10         | RW          | 0x0                | ETIE<br>Early Transmit Interrupt Enable<br>When this bit is set along with the AIE bit, the Early Transmit interrupt is enabled. When this bit is reset, the Early Transmit interrupt is disabled.<br>0x0 (DISABLE): Early Transmit Interrupt is disabled<br>0x1 (ENABLE): Early Transmit Interrupt is enabled                               |
| 9          | RW          | 0x0                | RWTE<br>Receive Watchdog Timeout Enable<br>When this bit is set along with the AIE bit, the Receive Watchdog Timeout interrupt is enabled. When this bit is reset, the Receive Watchdog Timeout interrupt is disabled.<br>0x0 (DISABLE): Receive Watchdog Timeout is disabled<br>0x1 (ENABLE): Receive Watchdog Timeout is enabled           |
| 8          | RW          | 0x0                | RSE<br>Receive Stopped Enable<br>When this bit is set along with the AIE bit, the Receive Stopped Interrupt is enabled. When this bit is reset, the Receive Stopped interrupt is disabled.                                                                                                                                                   |
| 7          | RW          | 0x0                | RBUE<br>Receive Buffer Unavailable Enable<br>When this bit is set along with the AIE bit, the Receive Buffer Unavailable interrupt is enabled. When this bit is reset, the Receive Buffer Unavailable interrupt is disabled.<br>0x0 (DISABLE): Receive Buffer Unavailable is disabled<br>0x1 (ENABLE): Receive Buffer Unavailable is enabled |
| 6          | RW          | 0x0                | RIE<br>Receive Interrupt Enable<br>When this bit is set along with the NIE bit, the Receive Interrupt is enabled. When this bit is reset, the Receive Interrupt is disabled.<br>0x0 (DISABLE): Receive Interrupt is disabled<br>0x1 (ENABLE): Receive Interrupt is enabled                                                                   |
| 5:3        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                     |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                       |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | RW   | 0x0         | TBUE<br>Transmit Buffer Unavailable Enable<br>When this bit is set along with the NIE bit, the Transmit Buffer Unavailable interrupt is enabled. When this bit is reset, the Transmit Buffer Unavailable interrupt is disabled.<br>0x0 (DISABLE): Transmit Buffer Unavailable is disabled<br>0x1 (ENABLE): Transmit Buffer Unavailable is enabled |
| 1   | RW   | 0x0         | TXSE<br>Transmit Stopped Enable<br>When this bit is set along with the AIE bit, the Transmission Stopped interrupt is enabled. When this bit is reset, the Transmission Stopped interrupt is disabled.<br>0x0 (DISABLE): Transmit Stopped is disabled<br>0x1 (ENABLE): Transmit Stopped is enabled                                                |
| 0   | RW   | 0x0         | TIE<br>Transmit Interrupt Enable<br>When this bit is set along with the NIE bit, the Transmit Interrupt is enabled. When this bit is reset, the Transmit Interrupt is disabled.<br>0x0 (DISABLE): Transmit Interrupt is disabled<br>0x1 (ENABLE): Transmit Interrupt is enabled                                                                   |

**GMAC DMA CH0 RX INTERRUPT WATCHDOG TIMER**Address: Operational Base + offset (0x1138)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18 | RO   | 0x0000      | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 17:16 | RW   | 0x0         | RWTU<br>Receive Interrupt Watchdog Timer Count Units<br>This field indicates the number of system clock cycles corresponding to one unit in RWT field.<br>2'b00: 256<br>2'b01: 512<br>2'b10: 1024<br>2'b11: 2048<br>For example, when RWT=2 and RWTU=1, the watchdog timer is set for $2 * 512 = 1024$ system clock cycles.                                                                                                                                                                                                                                                                                                                                                                                          |
| 15:8  | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 7:0   | RW   | 0x00        | RWT<br>Receive Interrupt Watchdog Timer Count<br>This field indicates the number of system clock cycles, multiplied by factor indicated in RWTU field, for which the watchdog timer is set.<br>The watchdog timer is triggered with the programmed value after the Rx DMA completes the transfer of a packet for which the RI bit is not set in the DMA_CH0_Status register, because of the setting of Interrupt Enable bit in the corresponding descriptor RDES3[30].<br>When the watchdog timer runs out, the RI bit is set and the timer is stopped. The watchdog timer is reset when the RI bit is set high because of automatic setting of RI as per the Interrupt Enable bit RDES3[30] of any received packet. |

**GMAC DMA CH0 CURRENT APP TXDESC**Address: Operational Base + offset (0x1144)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | CURTDESAPTR<br>Application Transmit Descriptor Address Pointer<br>The DMA updates this pointer during Tx operation. This pointer is cleared on reset. |

**GMAC DMA CH0 CURRENT APP RXDESC**Address: Operational Base + offset (0x114C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | CURRDESAPTR<br>Application Receive Descriptor Address Pointer<br>The DMA updates this pointer during Rx operation. This pointer is cleared on reset. |

**GMAC DMA CH0 CURREN APP TXBUFFER H**Address: Operational Base + offset (0x1150)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                           |
| 7:0        | RO          | 0x00               | CURTBUFAPTRH<br>Application Transmit Buffer Address Pointer<br>The DMA updates this pointer during Tx operation. This pointer is cleared on reset. |

**GMAC DMA CH0 CURRENT APP TXBUFFER**Address: Operational Base + offset (0x1154)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | CURTBUFAPTR<br>Application Transmit Buffer Address Pointer<br>The DMA updates this pointer during Tx operation. This pointer is cleared on reset. |

**GMAC DMA CH0 CURRENT APP RXBUFFER H**Address: Operational Base + offset (0x1158)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                          |
| 7:0        | RO          | 0x00               | CURRBUFAPTRH<br>Application Receive Buffer Address Pointer<br>The DMA updates this pointer during Rx operation. This pointer is cleared on reset. |

**GMAC DMA CH0 CURRENT APP RXBUFFER**Address: Operational Base + offset (0x115C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | CURRBUFAPTR<br>Application Receive Buffer Address Pointer<br>The DMA updates this pointer during Rx operation. This pointer is cleared on reset. |

**GMAC DMA CH0 STATUS**Address: Operational Base + offset (0x1160)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21:19      | RO          | 0x0                | <p>REB<br/>Rx DMA Error Bits<br/>This field indicates the type of error that caused a Bus Error.<br/>For example, error response on the AHB or AXI interface.</p> <p>1.Bit 21<br/>1'b1: Error during data transfer by Rx DMA<br/>1'b0: No Error during data transfer by Rx DMA</p> <p>2.Bit 20<br/>1'b1: Error during descriptor access<br/>1'b0: Error during data buffer access</p> <p>3.Bit 19<br/>1'b1: Error during read transfer<br/>1'b0: Error during write transfer</p> <p>This field is valid only when the FBE bit is set. This field does not generate an interrupt.</p>                                                                                                                                                                                                                                                                                                                                      |
| 18:16      | RO          | 0x0                | <p>TEB<br/>Tx DMA Error Bits<br/>This field indicates the type of error that caused a Bus Error.<br/>For example, error response on the AHB or AXI interface.</p> <p>1.Bit 18<br/>1'b1: Error during data transfer by Tx DMA<br/>1'b0: No Error during data transfer by Tx DMA</p> <p>2.Bit 17<br/>1'b1: Error during descriptor access<br/>1'b0: Error during data buffer access</p> <p>3.Bit 16<br/>1'b1: Error during read transfer<br/>1'b0: Error during write transfer</p> <p>This field is valid only when the FBE bit is set. This field does not generate an interrupt.</p>                                                                                                                                                                                                                                                                                                                                      |
| 15         | RW          | 0x0                | <p>NIS<br/>Normal Interrupt Summary<br/>Normal Interrupt Summary bit value is the logical OR of the following bits when the corresponding interrupt bits are enabled in the DMA_CH0_Interrupt_Enable register:</p> <p>Bit 0: Transmit Interrupt<br/>Bit 2: Transmit Buffer Unavailable<br/>Bit 6: Receive Interrupt<br/>Bit 11: Early Receive Interrupt</p> <p>Only unmasked bits (interrupts for which interrupt enable is set in DMA_CH0_Interrupt_Enable register) affect the Normal Interrupt Summary bit.</p> <p>This is a sticky bit. You must clear this bit (by writing 1 to this bit) each time a corresponding bit which causes NIS to be set is cleared.</p> <p>Access restriction applies. Self-set to 1 on internal event.<br/>Setting 1 clears. Setting 0 has no effect.</p> <p>0x0 (INACTIVE): Normal Interrupt Summary status not detected<br/>0x1 (ACTIVE): Normal Interrupt Summary status detected</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14         | RW          | 0x0                | <p>AIS<br/>Abnormal Interrupt Summary<br/>Abnormal Interrupt Summary bit value is the logical OR of the following when the corresponding interrupt bits are enabled in the DMA_CH0 Interrupt_Enable register:</p> <ul style="list-style-type: none"> <li>Bit 1: Transmit Process Stopped</li> <li>Bit 7: Receive Buffer Unavailable</li> <li>Bit 8: Receive Process Stopped</li> <li>Bit 10: Early Transmit Interrupt</li> <li>Bit 12: Fatal Bus Error</li> <li>Bit 13: Context Descriptor Error</li> </ul> <p>Only unmasked bits affect the Abnormal Interrupt Summary bit. This is a sticky bit. You must clear this bit (by writing 1 to this bit) each time a corresponding bit, which causes AIS to be set, is cleared.</p> <p>Access restriction applies. Self-set to 1 on internal event. Setting 1 clears. Setting 0 has no effect.</p> <p>0x0 (INACTIVE): Abnormal Interrupt Summary status not detected<br/>0x1 (ACTIVE): Abnormal Interrupt Summary status</p> |
| 13         | RW          | 0x0                | <p>CDE<br/>Context Descriptor Error<br/>This bit indicates that the DMA Tx/Rx engine received a descriptor error, which indicates invalid context in the middle of packet flow (intermediate descriptor) or all one's descriptor in Tx case and on Rx side it indicates DMA has read a descriptor with either of the buffer address as ones which is considered to be invalid.</p> <p>Access restriction applies. Self-set to 1 on internal event. Setting 1 clears. Setting 0 has no effect.</p> <p>0x0 (INACTIVE): Context Descriptor Error status not detected<br/>0x1 (ACTIVE): Context Descriptor Error status detected</p>                                                                                                                                                                                                                                                                                                                                          |
| 12         | RW          | 0x0                | <p>FBE<br/>Fatal Bus Error<br/>This bit indicates that a bus error occurred (as described in the EB field). When this bit is set, the corresponding DMA channel engine disables all bus accesses.</p> <p>Access restriction applies. Self-set to 1 on internal event. Setting 1 clears. Setting 0 has no effect.</p> <p>0x0 (INACTIVE): Fatal Bus Error status not detected<br/>0x1 (ACTIVE): Fatal Bus Error status detected</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 11         | RW          | 0x0                | <p>ERI<br/>Early Receive Interrupt<br/>This bit when set indicates that the RxDMA has completed the transfer of packet data to the memory. In configs supporting ERIC, When ERIC=0, this bit is set only after the Rx DMA has filled up a complete receive buffer with packet data. When ERIC=1, this bit is set after every burst transfer of data from the Rx DMA to the buffer. The setting of RI bit automatically clears this bit.</p> <p>Access restriction applies. Self-set to 1 on internal event. Setting 1 clears. Setting 0 has no effect.</p> <p>0x0 (INACTIVE): Early Receive Interrupt status not detected<br/>0x1 (ACTIVE): Early Receive Interrupt status detected</p>                                                                                                                                                                                                                                                                                   |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10  | RW   | 0x0         | <p><b>ETI</b><br/> <b>Early Transmit Interrupt</b><br/>           This bit when set indicates that the TxDMA has completed the transfer of packet data to the MTL TXFIFO memory. In configs supporting ERIC: When ETIC=0, this bit is set only after the Tx DMA has transferred a complete packet to MTL.<br/>           When ETIC=1, this bit is set after completion of (partial) packet data transfer from buffers in the Transmit descriptor in which IOC=1.<br/>           Access restriction applies. Self-set to 1 on internal event.<br/>           Setting 1 clears. Setting 0 has no effect.<br/>           0x0 (INACTIVE): Early Transmit Interrupt status not detected<br/>           0x1 (ACTIVE): Early Transmit Interrupt status detected</p>                                                                                                                                                                                             |
| 9   | RW   | 0x0         | <p><b>RWT</b><br/> <b>Receive Watchdog Timeout</b><br/>           This bit is asserted when a packet with length greater than 2,048 bytes (10,240 bytes when Jumbo Packet mode is enabled) is received.<br/>           Values:<br/>           0x0 (INACTIVE): Receive Watchdog Timeout status not detected<br/>           0x1 (ACTIVE): Receive Watchdog Timeout status detected<br/>           Value After Reset: 0x0<br/>           Exists: Always<br/>           Testable: untestable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 8   | RW   | 0x0         | <p><b>RPS</b><br/> <b>Receive Process Stopped</b><br/>           This bit is asserted when the Rx process enters the Stopped state.<br/>           Access restriction applies. Self-set to 1 on internal event.<br/>           Setting 1 clears. Setting 0 has no effect.<br/>           0x0 (INACTIVE): Receive Process Stopped status not detected<br/>           0x1 (ACTIVE): Receive Process Stopped status detected</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 7   | RW   | 0x0         | <p><b>RBU</b><br/> <b>Receive Buffer Unavailable</b><br/>           This bit indicates that the application owns the next descriptor in the Receive list, and the DMA cannot acquire it. The Rx process is suspended. To resume processing Rx descriptors, the application should change the ownership of the descriptor and issue a Receive Poll Demand command. If this command is not issued, the Rx process resumes when the next recognized incoming packet is received. In ring mode, the application should advance the Receive Descriptor Tail Pointer register of a channel. This bit is set only when the DMA owns the previous Rx descriptor.<br/>           Access restriction applies. Self-set to 1 on internal event.<br/>           Setting 1 clears. Setting 0 has no effect.<br/>           0x0 (INACTIVE): Receive Buffer Unavailable status not detected<br/>           0x1 (ACTIVE): Receive Buffer Unavailable status detected</p> |
| 6   | RW   | 0x0         | <p><b>RI</b><br/> <b>Receive Interrupt</b><br/>           This bit indicates that the packet reception is complete. When packet reception is complete, Bit 31 of RDES3 is reset in the last descriptor, and the specific packet status information is updated in the descriptor.<br/>           The reception remains in the Running state.<br/>           Access restriction applies. Self-set to 1 on internal event.<br/>           Setting 1 clears. Setting 0 has no effect.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | 0x0 (INACTIVE): Receive Interrupt status not detected<br>0x1 (ACTIVE): Receive Interrupt status detected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 5:3 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 2   | RW   | 0x0         | TBU<br>Transmit Buffer Unavailable<br>This bit indicates that the application owns the next descriptor in the Transmit list, and the DMA cannot acquire it.<br>Transmission is suspended. The TPS0 field of the DMA_Debug_Status0 register explains the Transmit Process state transitions.<br>To resume processing the Transmit descriptors, the application should do the following:<br>1. Change the ownership of the descriptor by setting Bit 31 of TDES3.<br>2. Issue a Transmit Poll Demand command.<br>For ring mode, the application should advance the Transmit Descriptor Tail Pointer register of a channel. Access restriction applies. Self-set to 1 on internal event.<br>Setting 1 clears. Setting 0 has no effect.<br>0x0 (INACTIVE): Transmit Buffer Unavailable status not detected<br>0x1 (ACTIVE): Transmit Buffer Unavailable status |
| 1   | RW   | 0x0         | TPS<br>Transmit Process Stopped<br>This bit is set when the transmission is stopped.<br>Access restriction applies. Self-set to 1 on internal event.<br>Setting 1 clears. Setting 0 has no effect.<br>0x0 (INACTIVE): Transmit Process Stopped status not detected<br>0x1 (ACTIVE): Transmit Process Stopped status detected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0   | RW   | 0x0         | TI<br>Transmit Interrupt<br>This bit indicates that the packet transmission is complete.<br>When transmission is complete, Bit 31 of TDES3 is reset in the last descriptor, and the specific packet status information is updated in the descriptor.<br>Access restriction applies. Self-set to 1 on internal event.<br>Setting 1 clears. Setting 0 has no effect.<br>0x0 (INACTIVE): Transmit Interrupt status not detected<br>0x1 (ACTIVE): Transmit Interrupt status detected                                                                                                                                                                                                                                                                                                                                                                           |

**GMAC DMA CH0 MISS FRAME CNT**Address: Operational Base + offset (0x1164)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                  |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0000      | reserved                                                                                                                                                                                                                                                                                                                                                                     |
| 15    | RO   | 0x0         | MFC0<br>Overflow status of the MFC Counter<br>When this bit is set then the MFC counter does not get incremented further. The bit gets cleared when this register is read.<br>Access restriction applies. Clears on read. Self-set to 1 on internal event.<br>0x0 (INACTIVE): Miss Frame Counter overflow not occurred<br>0x1 (ACTIVE): Miss Frame Counter overflow occurred |
| 14:11 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                     |

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:0 | RO   | 0x000       | MFC<br>Dropped Packet Counters<br>This counter indicates the number of packet counters that are dropped by the DMA either because of bus error or because of programming RPF field in DMA_CH0_Rx_Control register.<br>The counter gets cleared when this register is read.<br>Access restriction applies. Clears on read. Self-set to 1 on internal event. |

**GMAC DMA CH0 RX ERI CNT**Address: **Operational Base** + offset (0x1168)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                               |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x00000000  | reserved                                                                                                                                                                                                                                  |
| 0    | RO   | 0x0         | ECNT<br>ERI Counter<br>When ERIC bit of DMA_CH0_RX_Control register is set, this counter increments for burst transfer completed by the Rx DMA from the start of packet transfer. This counter will get reset at the start of new packet. |

**38.5 Interface Description**

There are two MAC Controllers in RK3506, and each has one set of IO interface, but some pins are also connected with Rockchip Matrix IO, as shown below tables. In addition, the schmitt trigger of mac0\_rxd0/1 and mac1\_rxd0/1 IO must be disabled.

Table 38-3 MAC Interface

| Module Pin       | Direction | Pad Name | IOMUX Setting                            |
|------------------|-----------|----------|------------------------------------------|
| mac0_clk         | I/O       | GPIO2_B2 | GPIO2_IOC_GPIO2B_IOMUX_SEL_0[11:8]=4'h1  |
| mac0_txen        | O         | GPIO2_B5 | GPIO2_IOC_GPIO2B_IOMUX_SEL_1[7:4]=4'h1   |
| mac0_txd1        | O         | GPIO2_B4 | GPIO2_IOC_GPIO2B_IOMUX_SEL_1[3:0]=4'h1   |
| mac0_txd0        | O         | GPIO2_B3 | GPIO2_IOC_GPIO2B_IOMUX_SEL_0[15:12]=4'h1 |
| mac0_rxdv        | I         | GPIO2_C0 | GPIO2_IOC_GPIO2C_IOMUX_SEL_0[3:0]=4'h1   |
| mac0_rxd1        | I         | GPIO2_B1 | GPIO2_IOC_GPIO2B_IOMUX_SEL_0[7:4]=4'h1   |
| mac0_rxd0        | I         | GPIO2_B0 | GPIO2_IOC_GPIO2B_IOMUX_SEL_0[3:0]=4'h1   |
| eth0_refclk_o25m | O         | GPIO0_C4 | GPIO0_IOC_GPIO0C_IOMUX_SEL_1[3:0]=4'h1   |
| mac0_mdio        | I/O       | GPIO2_B7 | GPIO2_IOC_GPIO2B_IOMUX_SEL_1[15:12]=4'h1 |
| mac0_mdc         | O         | GPIO2_B6 | GPIO2_IOC_GPIO2B_IOMUX_SEL_1[11:8]=4'h1  |
| mac1_clk         | I/O       | GPIO3_B0 | GPIO3_IOC_GPIO3B_IOMUX_SEL_0[3:0]=4'h2   |
| mac1_txen        | O         | GPIO3_B3 | GPIO3_IOC_GPIO3B_IOMUX_SEL_0[15:12]=4'h2 |
| mac1_txd1        | O         | GPIO3_B2 | GPIO3_IOC_GPIO3B_IOMUX_SEL_0[11:8]=4'h2  |

|                  |     |          |                                          |
|------------------|-----|----------|------------------------------------------|
| mac1_txd0        | O   | GPIO3_B1 | GPIO3_IOC_GPIO3B_IOMUX_SEL_0[7:4]=4'h2   |
| mac1_rxdv        | I   | GPIO3_B6 | GPIO3_IOC_GPIO3B_IOMUX_SEL_1[11:8]=4'h2  |
| mac1_rxd1        | I   | GPIO3_A7 | GPIO3_IOC_GPIO3A_IOMUX_SEL_1[15:12]=4'h2 |
| mac1_rxd0        | I   | GPIO3_A6 | GPIO3_IOC_GPIO3A_IOMUX_SEL_1[11:8]=4'h2  |
| eth1_refclk_o25m | O   | GPIO0_C3 | GPIO0_IOC_GPIO0C_IOMUX_SEL_0[15:12]=4'h1 |
| mac1_mdio        | I/O | GPIO3_B5 | GPIO3_IOC_GPIO3B_IOMUX_SEL_1[7:4]=4'h2   |
| mac1_mdc         | O   | GPIO3_B4 | GPIO3_IOC_GPIO3B_IOMUX_SEL_1[3:0]=4'h2   |

Table 38-4 MAC Rockchip Matrix IO Interface

| Module Pin    | Direction | Pad Name | IOMUX Setting         |
|---------------|-----------|----------|-----------------------|
| mac0_ppst_rig | I         | RM_IO    | GRF_SOC_CON8[6]=1'b1  |
| mac0_pps_clk  | O         | RM_IO    | NA                    |
| mac1_ppst_rig | I         | RM_IO    | GRF_SOC_CON11[6]=1'b1 |
| mac1_pps_clk  | O         | RM_IO    | NA                    |

Notes: I=input, O=output, I/O=input/output, bidirectional. For the configuration of RM\_IO, please refer to chapter "Rockchip Matrix IO"

## 38.6 Application Note

### 38.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 MAC 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 MAC supports the ring structure for the DMA descriptor.



Fig. 38-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:

$$\text{Current Descriptor Pointer} == \text{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:

$$\text{Current Descriptor Pointer} < \text{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.

### 38.6.2 Transmit Descriptors

The DMA in MAC 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.

### 38.6.3 Transmit Normal Descriptor (Read Format)

Table 38-5 TDES0 Normal Descriptor (Read Format)

| Bit  | Name   | Description                                                                                                                                                                                                                                                                                                    |
|------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | BUF1AP | <p>Buffer 1 Address Pointer or TSO Header Address Pointer</p> <p>These bits indicate the physical address of Buffer 1. These bits indicate the TSO Header Address pointer when the following bits are set:</p> <ul style="list-style-type: none"> <li>■ TSE bit of TDES3</li> <li>■ FD bit of TDES3</li> </ul> |

Table 38-6 TDES1 Normal Descriptor (Read Format)

| Bit  | Name   | Description                                                                                                                                                                                                                                                                                                                                 |
|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | BUF2AP | <p>Buffer 2 or Buffer 1 Address Pointer</p> <p>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.</p> <p>In 40- or 48-bit addressing mode, these bits indicate the most-significant 8- or 16- bits of the Buffer 1 Address Pointer.</p> |

Table 38-7 TDES2 Normal Descriptor (Read Format)

| Bit   | Name       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | IOC        | <p>Interrupt on Completion</p> <p>This bit controls the setting of TI and ETI status bits in the DMA_CH#_Status register. When ETIC = 1 and TDES2[LD] = 0, this bit sets the ETI bit. When TDES3[LD] = 1, this bit sets the TI status bit.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 30    | TTSE/T MWD | <p>Transmit Timestamp Enable or External TSO Memory Write Enable</p> <p>This bit enables the IEEE1588 time stamping for Transmit packet referenced by the descriptor, if TSE bit is not set.</p> <p>If TSE bit is set and external TSO memory is enabled, setting this bit disables external TSO memory writing for this packet.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 29:16 | B2L        | <p>Buffer 2 Length</p> <p>The driver sets this field. When set, this field indicates Buffer 2 length</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 15:14 | VTIR       | <p>VLAN Tag Insertion or Replacement</p> <p>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:</p> <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</p> |

| Bit  | Name      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:0 | HL or B1L | <p>core</p> <p>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.</p> <p>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.</p> <p>If the TCP Segmentation Offload feature is not enabled, this field is equal to Buffer 1 length.</p> |

Table 38-8 TDES3 Normal Descriptor (Read Format)

| Bit   | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | OWN  | <p>Own Bit</p> <p>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).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 30    | CTXT | <p>Context Type</p> <p>This bit should be set to 1'b0 for normal descriptor.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 29    | FD   | <p>First Descriptor</p> <p>When this bit is set, it indicates that the buffer contains the first segment of a packet.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 28    | LD   | <p>Last Descriptor</p> <p>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.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 27:26 | CPC  | <p>CRC Pad Control</p> <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> </ul> |

| Bit   | Name               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                    | <ul style="list-style-type: none"> <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. This field is valid only for the first descriptor.</li> </ul> <p>Note: When the TSE bit is set, the MAC ignores this field because the CRC and pad insertion is always done for segmentation.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 25:23 | SAIC               | <p>SA Insertion Control</p> <p>These bits request the MAC to add or replace the Source Address field in the Ethernet packet with the value given in the MAC Address 0 register. The application must set the CRC Pad Control bits appropriately when SA Insertion Control is enabled for the packet. Bit 25 specifies the MAC Address Register (1 or 0) value that is used for Source Address insertion or replacement.</p> <p>The following list describes the values of Bits[24:23]:</p> <ul style="list-style-type: none"> <li>■ 2'b00: Do not include the source address</li> <li>■ 2'b01: Include or insert the source address. For reliable transmission, the application must provide frames without source addresses.</li> <li>■ 2'b10: Replace the source address. For reliable transmission, the application must provide frames with source addresses.</li> <li>■ 2'b11: Reserved</li> </ul> <p>These bits are valid in the EQOS-DMA, EQOS-AXI, and EQOS-AHB configurations when the Enable SA and VLAN Insertion on Tx option is selected while configuring the core and when the First Segment control bit (TDES3 [29]) is set.</p> <p>This field is valid only for the first descriptor.</p> |
| 22:19 | SLOTPNUM<br>or THL | <p>SLOTPNUM: Slot Number Control Bits in AV Mode</p> <p>These bits indicate the slot interval in which the data should be fetched from the corresponding buffers addressed by TDES0 or TDES1. When the Transmit descriptor is fetched, the DMA compares the slot number value in this field with the slot interval maintained in the RSN field DMA_CH#_Slot_Function_Control_Status. It fetches the data from the buffers only if a value matches. These bits are valid only for the AV channels.</p> <p>THL: TCP/UDP Header Length</p> <p>If the TSE bit is set, this field contains the length of the TCP/UDP header. The minimum value of this field must be 5 for TCP header. The value must be equal to 2 for UDP header.</p> <p>This field is valid only for the first descriptor.</p>                                                                                                                                                                                                                                                                                                                                                                                                               |
| 18    | TSE                | <p>TCP Segmentation Enable</p> <p>When this bit is set, the DMA performs the TCP/UDP segmentation or UDP fragmentation for a packet depending on the TSE_MODE[1:0] bit of the DMA_CH(#i)_Tx_Control Register. This bit is valid only if the FD bit is set.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 17:16 | CIC/TPL            | Checksum Insertion Control or TCP Payload Length                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| Bit  | Name   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |        | <p>These bits control the checksum calculation and insertion. The following list describes the bit encoding:</p> <ul style="list-style-type: none"> <li>■ 2'b00: Checksum Insertion Disabled.</li> <li>■ 2'b01: Only IP header checksum calculation and insertion are enabled.</li> <li>■ 2'b10: IP header checksum and payload checksum calculation and insertion are enabled, but pseudo-header checksum is not calculated in hardware.</li> <li>■ 2'b11: IP Header checksum and payload checksum calculation and insertion are enabled, and pseudo-header checksum is calculated in hardware. This field is valid when the Enable Transmit TCP/IP Checksum Offload option is selected and the TSE bit is reset. 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.</li> </ul> <p>This field is valid only for the first descriptor.</p> |
| 15   | TPL    | <p>Reserved or TCP Payload Length</p> <p>When the TSE bit is reset, this bit is reserved. When the TSE bit is set, this is Bit 15 of the TCP payload length [17:0]. This field is valid only when the Enable TCP Segmentation Offloading for TCP/IP Packets option is selected while configuring the core.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 14:0 | FL/TPL | <p>Frame Length or TCP Payload Length</p> <p>This field is equal to the length of the packet to be transmitted in bytes. When the TSE bit is not set, this field is equal to the total length of the packet to be transmitted:</p> $\text{Ethernet Header Length} + \text{TCP /IP Header Length} - \text{Preamble Length} - \text{SFD Length} + \text{Ethernet Payload Length}$ <p>When the TSE bit is set, this field is equal to the lower 15 bits of the TCP payload length in case of segmentation and IP payload in case of UDP fragmentation. In case of segmentation, this length does not include Ethernet 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.</p>                                                                                                                                                                                            |

### 38.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 38-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 38-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 38-11 TDES2 Normal Descriptor (Write-Back Format)

| Bit  | Name     | Description |
|------|----------|-------------|
| 31:0 | Reserved | Reserved    |

Table 38-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    | CTXT     | Context Type<br>This bit should be set to 1'b0 for normal descriptor.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 29    | FD       | First Descriptor<br>When this bit is set, it indicates that the buffer contains the first segment of a packet.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 28    | LD       | Last Descriptor<br>When this bit is set, it indicates that the buffer contains the last segment of the packet. When this bit is set, the B1L or B2L field should have a non-zero value.                                                                                                                                                                                                                                                                                                                                                                                                          |
| 27:24 | Reserved | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 23    | DE       | Descriptor Error<br>When this bit is set, it indicates that the descriptor content is incorrect. The DMA sets this bit during write-back while closing the descriptor. Descriptor Errors can be: <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> 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. |

| Bit   | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          | <p>When IOC bit in TDES2 of corresponding first descriptor is set to 1, Transmit DMA will set the TI bit in the DMA_CH#_Status register.</p> <p>Note 2: Based on CTXT, LD, and FD bits of the transmit descriptor, the subsequent descriptor might be considered as the First Descriptor (even if FD bit is not set) and partial packet is sent.</p>                                                                                                                                                                                                                                             |
| 22:18 | Reserved | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 17    | TTSS     | <p>Tx Timestamp Status</p> <p>This status bit indicates that a timestamp has been captured for the corresponding transmit packet. When this bit is set, TDES0 and TDES1 have timestamp values that were captured for the Transmit packet. This field is valid only when the Last Segment control bit (TDES3 [28]) in a descriptor is set. This bit is valid only when IEEE1588 timestamping feature is enabled; otherwise, it is reserved.</p>                                                                                                                                                   |
| 16    | EUE      | <p>ECC Uncorrectable Error Status</p> <p>Indicates the ECC uncorrectable error in the TSO memory.</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 MAC.</p>                                                                                                                                                                                                                                                                                                                                           |
| 15    | ES       | <p>Error Summary</p> <p>This bit indicates the logical OR of the following bits:</p> <ul style="list-style-type: none"> <li>■ TDES3[0]: IP Header Error</li> <li>■ TDES3[14]: Jabber Timeout</li> <li>■ TDES3[13]: Packet Flush</li> <li>■ TDES3[12]: Payload Checksum Error</li> <li>■ TDES3[11]: Loss of Carrier</li> <li>■ TDES3[10]: No Carrier</li> <li>■ TDES3[9]: Late Collision</li> <li>■ TDES3[8]: Excessive Collision</li> <li>■ TDES3[3]: Excessive Deferral</li> <li>■ TDES3[2]: Underflow Error</li> </ul> <p>This bit is also set when EUE (bit 16) is set</p>                    |
| 14    | JT       | <p>Jabber Timeout</p> <p>This bit indicates that the MAC transmitter has experienced a jabber time-out. This bit is set only when the JD bit of the MAC_Configuration register is not set.</p>                                                                                                                                                                                                                                                                                                                                                                                                   |
| 13    | PF       | <p>Packet Flushed</p> <p>This bit indicates that the DMA or MTL flushed the packet because of a software flush command given by the CPU.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 12    | PCE      | <p>Payload Checksum Error</p> <p>This bit indicates that the Checksum Offload engine had a failure and did not insert any checksum into the 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</p> |

| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      | 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  | Loss of Carrier<br>This bit indicates that Loss of Carrier occurred during packet transmission (that is, the gmii_crs_i signal was inactive for one or more transmit clock periods during packet transmission). This is valid only for the packets transmitted without collision and when the MAC operates in the half-duplex mode.                                                                                                                                                                                                                                    |
| 10  | NC   | No Carrier<br>This bit indicates that the carrier sense signal from the PHY was not asserted during transmission.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 9   | LC   | Late Collision<br>This bit indicates that packet transmission was aborted because a collision occurred after the collision window (64 byte times including Preamble in MII mode and 512 byte times including Preamble and Carrier Extension in GMII mode). This bit is not valid if Underflow Error is set.                                                                                                                                                                                                                                                            |
| 8   | EC   | Excessive Collision<br>This bit indicates that the transmission was aborted after 16 successive collisions while attempting to transmit the current packet. If the DR bit is set in the MAC_Configuration register, this bit is set after first collision and the transmission of the packet is aborted.                                                                                                                                                                                                                                                               |
| 7:4 | CC   | Collision Count<br>This 4-bit counter value indicates the number of collisions occurred before the packet was transmitted. The count is not valid when the EC bit is set.                                                                                                                                                                                                                                                                                                                                                                                              |
| 3   | ED   | Excessive Deferral<br>This bit indicates that the transmission ended because of excessive deferral of over 24,288 bit times (155,680 bits times in 1000 Mbps mode or Jumbo Packet enabled mode) if DC bit is set in the MAC_Configuration register. When TBS is enabled in full duplex mode and this bit is set, it indicates that the frame has been dropped after the expiry time has reached.                                                                                                                                                                       |
| 2   | UF   | Underflow Error<br>This bit indicates that the MAC aborted the packet because the data arrived late from the system memory. The underflow error can occur because of either of the following conditions: <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> The transmission process enters the suspended state and sets the underflow bit corresponding to a queue in the MTL Interrupt_Status register. |
| 1   | DB   | Deferred Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      | 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. |

### 38.6.5 Programming Guide

#### 38.6.5.1 Initializing DMA

Complete the following steps to initialize the DMA:

1. Provide a software reset. This resets all of the MAC internal registers and logic (bit-0 of DMA\_Mode).
2. Wait for the completion of the reset process (poll bit 0 of the DMA\_Mode, which is only cleared after the reset operation is completed).
3. Program the following fields to initialize the DMA\_SysBus\_Mode register:
  - a. AAL
  - b. Fixed burst or undefined burst
  - c. Burst mode values in case of AHB bus interface, OSR\_LMT in case of AXI bus interface.
  - d. If fixed length value is enabled, select the maximum burst length possible on the AXI Bus (bits [7:1])
4. Create a descriptor list for transmit and receive. In addition, ensure that the descriptors are owned by DMA (set bit 31 of descriptor TDES3/RDES3). For more information about descriptors, see section "Descriptors".
5. Program the Transmit and Receive Ring length registers (DMA\_CH(#i)\_TxDesc\_Ring\_Length (for i = 0; i <= MAC\_NUM\_DMA\_TX\_CH-1) and DMA\_CH(#i)\_RxDesc\_Ring\_Length (for i = 0; i <= MAC\_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 <= MAC\_NUM\_DMA\_TX\_CH-1), DMA\_CH(#i)\_RxDesc\_List\_Address (for i = 0; i <= MAC\_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 <= MAC\_NUM\_DMA\_TX\_CH-1) and DMA\_CH(#i)\_RxDesc\_Tail\_Pointer (for i = 0; i <= MAC\_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 <= MAC\_NUM\_DMA\_TX\_CH-1)
  - DMA\_CH(#i)\_TX\_Control (for i = 0; i <= MAC\_NUM\_DMA\_TX\_CH-1)
  - DMA\_CH(#i)\_RX\_Control (for i = 0; i <= MAC\_NUM\_DMA\_RX\_CH-1)
8. Enable the interrupts by programming the DMA\_CH(#i)\_Interrupt\_Enable (for i = 0; i <= MAC\_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 <= MAC\_NUM\_DMA\_RX\_CH-1) and ST (bit 0) of the DMA\_CH(#i)\_TX\_Control (for i = 0; i <= MAC\_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.

### **38.6.5.2 Initializing MTL Registers**

The Transaction Layer (MTL) registers must be initialized to establish the transmit and receive operating modes and commands.

Complete the following steps to initialize the MTL registers:

1. Program the Tx Scheduling (SCHALG) and Receive Arbitration Algorithm (RAA) fields in MTL\_Operation\_Mode to initialize the MTL operation in case of multiple Tx and Rx queues.
2. Program the Receive Queue to DMA mapping in MTL\_RxQ\_DMA\_Map0 and MTL\_RxQ\_DMA\_Map1 registers.
3. Program the following fields to initialize the mode of operation in the MTL\_TxQ0\_Operation\_Mode register:
  - a. Transmit Store And Forward (TSF) or Transmit Threshold Control (TTC) in case of threshold mode
  - b. Transmit Queue Enable (TXQEN) to value 2'b10 to enable Transmit Queue0
  - c. Transmit Queue Size (TQS)
4. Program the following fields to initialize the mode of operation in the MTL\_RxQ0\_Operation\_Mode register:
  - a. Receive Store and Forward (RSF) or RTC in case of Threshold mode
  - b. Flow Control Activation and De-activation thresholds for MTL Receive FIFO (RFA and RFD)
  - c. Error Packet and undersized good Packet forwarding enable (FEP and FUP)
  - d. Receive Queue Size (RQS)
5. Repeat previous two steps for all MTL Tx and Rx queues selected in the configuration.

### **38.6.5.3 Initializing MAC**

The MAC configuration registers establish the operating mode of the MAC. These registers must be initialized before initializing the DMA.

The following MAC Initialization operations can be performed after DMA initialization. If the MAC initialization is completed before the DMA is configured, enable the MAC receiver (last step in the following sequence) only after the DMA is active. Otherwise, received frames fill the Rx FIFO and overflow.

1. Provide the MAC address registers: MAC\_Address0\_High and MAC\_Address0\_Low. If more than one MAC address is enabled in your configuration, program the MAC addresses appropriately.
2. Program the following fields to set the appropriate filters for the incoming frames in the MAC\_Packet\_Filter register:
  - a. Receive All
  - b. Promiscuous mode
  - c. Hash or Perfect Filter
  - d. Unicast, multicast, broadcast, and control frames filter settings
3. Program the following fields for proper flow control in the MAC\_Q0\_Tx\_Flow\_Ctrl register:
  - a. Pause time and other Pause frame control bits
  - b. Transmit Flow control bits
  - c. Flow Control Busy
4. Program the MAC\_Interrupt\_Enable register, as required, and if applicable, for your configuration.
5. Program the appropriate fields in the MAC\_Configuration register. For ex: Inter-packet gap while transmission and jabber disable.
6. Set bit 0 and 1 in MAC\_Configuration registers to start the MAC transmitter and receiver.

### **38.6.5.4 Performing Normal Receive and Transmit Operation**

During normal operation of the MAC, 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)

### **38.6.5.5 Stopping and Starting Transmission**

Complete the following steps to pause the transmission for some time.

1. Disable the Transmit DMA (if applicable) by clearing Bit 0 (ST) of DMA\_CH(#i).TX\_Control (for  $i = 0; i <= \text{MAC\_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.

### **38.6.5.6 Initialization Guidelines for System Time Generation**

You can enable the timestamp feature by setting Bit 0 of the MAC\_Timestamp\_Control Register. However, it is essential that the timestamp counter be initialized after this bit is set. Complete the following steps during MAC 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.

### **38.6.5.7 Coarse Correction Method**

To synchronize or update the system time in one process (coarse correction method), complete the following steps:

1. Set the offset (positive or negative) in the Timestamp Update registers (MAC\_System\_Time\_Seconds\_Update and MAC\_System\_Time\_Nanoseconds\_Update).
2. Set Bit 3 (TSUPDT) of MAC\_Timestamp\_Control Register. The value in the Timestamp Update registers is added to or subtracted from the system time when the TSUPDT bit is cleared.

### **38.6.5.8 Programming Guidelines for TSO**

The TCP Segmentation Offload (TSO) engine is used to offload the TCP segmentation functions to the hardware. To program the TSO, set the TSE bit to enable TCP packet segmentation, and program descriptor fields to enable TSO for the current packet.

Complete the following steps to program TSO:

1. Program the TSE bit of corresponding DMA\_CH[n]\_Tx\_Control register to enable TCP packet segmentation in that DMA.
2. In addition to the normal transfer descriptor setting, the following descriptor fields must be programmed to enable TSO for the current packet:
  - a. Enable TSE in Bit 18 of TDES3
  - b. Program the length of the un-segmented TCP/IP packet payload in bits [17:0] of TDES3 and the TCP header in bits [22:19] of TDES3.
  - c. Program the maximum size of the segment in MSS of DMA\_CH[n]\_Control register or MSS in the context descriptor. If MSS field is programmed in both DMA\_CH[n]\_Control register and in the context descriptor, the latest software programmed sequence is considered.
3. The header of the unsegmented TCP/IP packet should be in Buffer 1 of the first descriptor and this buffer must not hold any payload bytes. The payload is allocated to Buffer 2 and the buffers of the subsequent descriptors.

### **38.6.5.9 Programming Guidelines for Multi-Channel Multi-Queueing Transmit**

1. Program the Transmit queue size in the TQS field of MTL\_TxQ[n]\_Operation\_Mode register. Based on the value programmed in the TQS field, the size of the queue is determined.

In the Transmit operation, the number of channels is equal to the number of the queues. Due to this reason, the Channel-to-Queue mapping is fixed.

2. For a queue to be used, the queue needs to be enabled in TXQEN in the corresponding MTL\_TxQ[n]\_Operation\_Mode Register. In DMA configurations, the ST bit of DMA\_CH[n]\_Tx\_Control Register and corresponding TXQEN in MTL\_TxQ[n]\_Operation Mode Register needs to be enabled.

3. The scheduling method needs to be programmed in SCHALG of MTL\_Operation\_Mode register.

4. Program the MTL\_TxQ[n]\_Quantum\_Weight for DCB queue as per the selected algorithm. In case of CBS algorithm in AVB queues, the MTL\_TxQ[n]\_ETS\_Control, MTL\_TxQ[n]\_SendSlopeCredit, MTL\_TxQ[n]\_HiCredit and MTL\_TxQ[n]\_LoCredit registers also need to be programmed as required.

5. If DCB is enabled and PFC function is required, program MAC\_TxQ\_Prtv\_Map0 Register to assign a fixed priority to the queue. This priority assigned is used for determining if the corresponding queue should stop transmitting packet based on the received PFC packet.

### **Receive**

1. Program the Receive queue size in the RQS field of MTL\_RxQ[n]\_Operation\_Mode Register. Based on the value programmed in RQS field, the size of the queue is determined.
2. Enable the Receive Queues 0 to 7 in the fields RXQ0EN to RXQ7EN in MAC\_RxQ\_Ctrl0 Register for AV or DCB. In DMA configurations, SR bit of statically or dynamically mapped DMA\_CH[n]\_Rx\_Control Register and corresponding RXQ[n]\_EN in MAC\_RxQ\_Ctrl0 Register needs to be enabled.

3. The MAC routes the Rx packets to the Rx Queues based on following packet types:
- AV PTP Packets: Based on the programming of AVPTPQ in MAC\_RxQ\_Ctrl1 Register.
  - AV Untagged Control packets: Based on the programming of AVCPQ in MAC\_RxQ\_Ctrl1 Register.
  - Data Center Bridging (DCB) related Link Layer Discovery Protocol (LLDP) packets. Program DCBCPQ in MAC\_RxQ\_Ctrl1 Register to indicate to MAC which queue should get the DCB packets.
  - VLAN Tag Priority field in VLAN Tagged packets: Program PSRQ7-0 of the MAC\_RxQ\_Ctrl2 and MAC\_RxQ\_Ctrl3 Register for the routing of tagged packets based on the USP (user Priority) field of the received packets to the Rx Queues 0 to 7.
  - The AV tagged control and data packets are also routed based on PSRQ field of the MAC\_RxQ\_Ctrl2 and MAC\_RxQ\_Ctrl3 registers.
4. If multiple RX DMA channels are enabled, the following programming should be done for proper arbitration and mapping:
- Program the RAA field of MTL\_Operation\_Mode register to select the arbitration algorithm to decide which RxQ is read out from the RxFIFO memory.
  - Program the MTL\_RxQ[n]\_Control to decide the weights and the packet arbitration for each RxQ.
  - If static mapping is programmed in MTL\_RxQ\_DMA\_Map[n] register (RXQ[n]DADMACH is reset to 0), bits RXQx2DMA and others need to be programmed to select the channel for which each queue is mapped.
  - Set RXQ[n]DADMACH bit in MTL\_RxQ\_DMA\_Map0 Register to select dynamic mapping of packets in each RxQueue.
  - In dynamic channel mapping, the routing of a packet to a specific RxDMA channel is decided by the value of DCS field in the lowest MAC Address Register.

### **38.6.6 Transmit Context Descriptor**

The context descriptor is used to provide the timestamps for one-step timestamp correction, VLAN Tag ID for VLAN insertion feature. The Transmit Context descriptor can be provided any time before a packet descriptor. The context is valid for the current packet and subsequent packets. The context descriptor is used to provide the timestamps for one-step timestamp correction and VLAN Tag ID for VLAN insertion feature. Write back is done on a context descriptor only to reset the OWN bit.

Table 38-13 TDES0 Context Descriptor

| <b>Bit</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                  |
|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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. 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 38-14 TDES1 Context Descriptor

| <b>Bit</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                               |
|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | TTSH        | Transmit Packet Timestamp High<br>For one-step correction, the driver can provide the upper 32 bits of timestamp in this descriptor. The DMA uses this value as the high word for doing one-step timestamp correction. This field is valid only if the OSTC and TCMSSV bits of TDES3 context descriptor are set. |

Table 38-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 | Reserved | Reserved                                                                                                                                                                                                                                                                                                                                                                      |
| 13:0  | MSS      | Maximum Segment Size<br>When the Enable TCP Segmentation Offloading for TCP/IP Packets option is selected, the driver can provide maximum segment size in this field. This segment size is used while segmenting the TCP/IP payload. This field is valid only if the TCMSSV bit of TDES3 context descriptor is set and the OSTC bit of the TDES3 context descriptor is reset. |

Table 38-16 TDES3 Context Descriptor

| Bit   | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | OWN      | Own Bit<br>When this bit is set, it indicates that the MAC DMA owns the descriptor. When this bit is reset, it indicates that the application owns the descriptor. The DMA clears this bit immediately after the read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 30    | CTXT     | Context Type<br>This bit should be set to 1'b1 for Context descriptor.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 29:28 | Reserved | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 27    | OSTC     | One-Step Timestamp Correction Enable<br>When this bit is set, the DMA performs a one-step timestamp correction with reference to the timestamp values provided in TDES0 and TDES1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 26    | TCMSSV   | One-Step Timestamp Correction Input or MSS Valid<br>When this bit and the OSTC bit are set, it indicates that the Timestamp Correction input provided in TDES0 and TDES1 is valid. When the OSTC bit is reset and this bit and the TSE bit of TDES3 are set in subsequent normal descriptor, it indicates that the MSS input in TDES2 is valid.                                                                                                                                                                                                                                                                                                                                                                                                  |
| 25:24 | Reserved | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 23    | DE       | Descriptor Error<br>When this bit is set, it indicates that the descriptor content is incorrect. The DMA sets this bit during write-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. |

| Bit   | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          | 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 | Reserved | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 19:18 | IVTIR    | <p>Inner VLAN Tag Insert or Replace<br/>When this bit is set, these bits request the MAC to perform Inner VLAN tagging or un-tagging before transmitting the packets. If the packet is modified for VLAN tags, the MAC automatically recalculates and replaces the CRC bytes.</p> <p>The following list describes the values of these bits:</p> <ul style="list-style-type: none"> <li>■ 2'b00: Do not add the inner VLAN tag.</li> <li>■ 2'b01: Remove the inner VLAN tag from the packets before transmission. This option should be used only with the VLAN frames.</li> <li>■ 2'b10: Insert an inner VLAN tag with the tag value programmed in the MAC_Inner_VLAN_Incl register or context descriptor.</li> <li>■ 2'b11: Replace the inner VLAN tag in packets with the tag value programmed in the MAC_Inner_VLAN_Incl register or context descriptor. This option should be used only with the VLAN frames.</li> </ul> <p>These bits are valid when the Enable SA and VLAN Insertion on Tx and Enable Double VLAN Processing options are selected.</p> |
| 17    | IVLTV    | <p>Inner VLAN Tag Valid<br/>When this bit is set, it indicates that the IVT field of TDES2 is valid.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 16    | VLTV     | <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>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

### 38.6.7 Receive Descriptors

The DMA in MAC 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 RxFIFO 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".

### 38.6.8 Receive Normal Descriptors (Read Format)

Table 38-17 TDES0 Normal Descriptor (Read Format)

| <b>Bit</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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> <p>If the address pointer points to a buffer where the middle or last part of the packet is stored, the DMA ignores the offset address and writes to the full location as indicated by the data-width.</p> |

Table 38-18 TDES1 Normal Descriptor(Read Format)

| <b>Bit</b> | <b>Name</b>        | <b>Description</b>                                                                                                                              |
|------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | Reserved or BUF1AP | In 64-bit addressing mode, this field contains the most-significant 32 bits of the Buffer 1 Address Pointer. Otherwise, this field is reserved. |

Table 38-19 TDES2 Normal Descriptor(Read Format)

| <b>Bit</b> | <b>Name</b>        | <b>Description</b>                                                                                                                              |
|------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | Reserved or BUF1AP | In 64-bit addressing mode, this field contains the most-significant 32 bits of the Buffer 1 Address Pointer. Otherwise, this field is reserved. |

Table 38-20 TDES3 Normal Descriptor(Read Format)

| <b>Bit</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | OWN         | <p>Own Bit<br/>When this bit is set, it indicates that the MAC 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         | IOC         | Interrupt Enabled on Completion<br>When this bit is set, an interrupt is issued to the application when the DMA closes this descriptor.                                                                                                                                                                                                                                                                       |
| 29:26      | Reserved    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                      |
| 25         | BUF2V       | Buffer 2 Address Valid<br>When this bit is set, it indicates to the DMA that the buffer 2 address specified in RDES2 is valid.                                                                                                                                                                                                                                                                                |

| Bit  | Name     | Description                                                                                                                                                                                                                                                              |
|------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |          | The application must set this bit so that the DMA can use the address, to which the Buffer 2 address in RDES2 is pointing, to write received packet data.                                                                                                                |
| 24   | BUF1V    | Buffer 1 Address Valid<br>When set, this indicates to the DMA that the buffer 1 address specified in RDES1 is valid.<br>The application must set this value if the address pointed to by Buffer 1 address in RDES1 can be used by the DMA to write received packet data. |
| 23:0 | Reserved | Reserved                                                                                                                                                                                                                                                                 |

### 38.6.9 Receive Normal Descriptors (Write-Back Format)

Table 38-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 RSOV bit of RDES3 is set.<br>This is valid only when Double VLAN tag processing and VLAN tag stripping are enabled. |
| 15:0  | OVT  | Outer VLAN Tag<br>This field contains the Outer VLAN tag of the received packet if the RSOV bit of RDES3 is set.                                                                                           |

Table 38-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. 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.                                                                                                                                                          |

| Bit  | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:8 | PMT  | <p>PTP Message Type<br/>These bits are encoded to give the type of the message received:</p> <ul style="list-style-type: none"> <li>■ 0000: No PTP message received</li> <li>■ 0001: SYNC (all clock types)</li> <li>■ 0010: Follow_Up (all clock types)</li> <li>■ 0011: Delay_Req (all clock types)</li> <li>■ 0100: Delay_Resp (all clock types)</li> <li>■ 0101: Pdelay_Req (in peer-to-peer transparent clock)</li> <li>■ 0110: Pdelay_Resp (in peer-to-peer transparent clock)</li> <li>■ 0111: Pdelay_Resp_Follow_Up (in peer-to-peer transparent clock)</li> <li>■ 1000: Announce</li> <li>■ 1001: Management</li> <li>■ 1010: Signaling</li> <li>■ 1011–1110: Reserved</li> <li>■ 1111: PTP packet with Reserved message type</li> </ul> <p>These bits are available only when you select the Timestamp feature.</p> |
| 7    | IPCE | <p>IP Payload Error<br/>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<br/>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<br/>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<br/>This bit indicates that an IPV4 header is detected. When the SPH bit of RDES3 is set, the IPV4 header is available in the header buffer area to which RDES0 is pointing.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3    | IPHE | <p>IP Header Error<br/>When this bit is set, it indicates either of the following:</p> <ul style="list-style-type: none"> <li>■ The 16-bit IPv4 header checksum calculated by the MAC does not match the received checksum bytes.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      | <ul style="list-style-type: none"> <li>■ The IP datagram version is not consistent with the Ethernet Type value.</li> <li>■ Ethernet packet does not have the expected number of IP header bytes.</li> </ul> <p>This bit is valid when either Bit 5 or Bit 4 is set. This bit is available when you select the Enable Receive TCP/IP Checksum Check feature.</p>                                                                                                                                                                                                                                                                                                                                                          |
| 2:0 | PT   | <p>Payload Type</p> <p>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 38-23 TDES2 Normal Descriptor (Write-Back Format)

| Bit   | Name   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | L3L4FM | <p>Layer 3 and Layer 4 Filter Number Matched</p> <p>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</p> <p>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   | Layer 3 Filter Match                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| Bit   | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          | <p>When this bit is set, it indicates that the received packet matches one of the enabled Layer 3 IP Address fields. This status is given only when one of the following conditions is true:</p> <ul style="list-style-type: none"> <li>■ All enabled Layer 3 fields match and all enabled Layer 4 fields are bypassed</li> <li>■ All enabled filter fields match</li> </ul> <p>When more than one filter matches, this bit gives the layer 3 filter status of filter indicated by Bits[31:29]. Note: This status is not available when Flexible RX Parser is enabled.</p> |
| 26:19 | MADRM    | <p>MAC Address Match or Hash Value</p> <p>When the HF bit is reset, this field contains the MAC address register number that matched the Destination address of the received packet. This field is valid only if the DAF bit is reset.</p> <p>When the HF bit is set, this field contains the hash value computed by the MAC. A packet passes the hash filter when the bit corresponding to the hash value is set in the hash filter register.</p> <p>Note: This status is not available when Flexible RX Parser is enabled.</p>                                           |
| 18    | HF       | <p>Hash Filter Status</p> <p>When this bit is set, it indicates that the packet passed the MAC address hash filter. Bits[26:19] indicate the hash value.</p> <p>Note: This status is not available when Flexible RX Parser is enabled.</p>                                                                                                                                                                                                                                                                                                                                 |
| 17    | DAF/RXPI | <p>Destination Address Filter Fail</p> <p>When Flexible RX Parser is disabled, and this bit is set, it indicates that the packet failed the DA Filter in the MAC.</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 MAC_ERVFE is not enabled. If MAC_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 MAC_ERVFE is enabled.</p> <p>This bit is valid only for Double VLAN Tagged frames, when Double VLAN Processing is enabled.</p>                                                                                                                                                                                                                                                                                                                                                                    |

| Bit   | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          | For more information, see the Filter Status topic.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 13:11 | Reserved | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 10    | ARPNR    | ARP Reply Not Generated<br>When this bit is set, it indicates that the MAC did not generate the ARP Reply for received ARP Request packet. This bit is set when the MAC is busy transmitting ARP reply to earlier ARP request (only one ARP request is processed at a time).<br>This bit is reserved when the Enable IPv4 ARP Offload option is not selected.                                                                                                                                                                  |
| 9:0   | HL       | L3/L4 Header Length<br>This field contains the length of the header of the packet split by the MAC at L3 or L4 header boundary as identified by the MAC receiver. This field is valid only when the first descriptor bit is set (FD = 1).<br>The header data is written to the Buffer 1 address of corresponding descriptor. If header length is zero, this field is not valid. It implies that the MAC did not identify and split the header.<br>This field is valid when the Enable Split Header Feature option is selected. |

Table 38-24 TDES3 Normal Descriptor (Write-Back Format)

| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31  | OWN  | Own Bit<br>When this bit is set, it indicates that the MAC DMA owns the descriptor. When this bit is reset, it indicates that the application owns the descriptor. The DMA clears this bit when either of the following conditions is true: <ul style="list-style-type: none"><li>■ The DMA completes the packet reception</li><li>■ The buffers associated with the descriptor are full</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 30  | CTXT | Receive Context Descriptor<br>When this bit is set, it indicates that the current descriptor is a context type descriptor. The DMA writes 1'b0 to this bit for normal receive descriptor.<br>When CTXT and FD bits are used together, {CTX, FD} <ul style="list-style-type: none"><li>■ 2'b00: Intermediate Descriptor</li><li>■ 2'b01: First Descriptor</li><li>■ 2'b10: Reserved</li><li>■ 2'b11: Descriptor Error (due to all 1s)</li></ul> Note: When Descriptor Error occurs, the Receive DMA closes the receive descriptor indicating Descriptor Error. This receive descriptor is skipped and the buffer addresses are not used to write the packet data<br>Receive DMA will set the CDE bit in DMA_CH#_Status register but not the RI bit even when IOC is set, as this is not marked as last receive descriptor for the packet. The subsequent valid receive descriptor is used to write the packet data. |
| 29  | FD   | First Descriptor<br>When this bit is set, it indicates that this descriptor contains the first buffer of the packet. If the size of the first buffer is 0, the second buffer contains the beginning of the packet. If the size of the second                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| <b>Bit</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |             | buffer is also 0, the next descriptor contains the beginning of the packet.<br>See the CTXT bit description for details of using the CTXT bit and FD bit together.                                                                                                                                                                                                                     |
| 28         | LD          | Last Descriptor<br>When this bit is set, it indicates that the buffers to which this descriptor is pointing are the last buffers of the packet.                                                                                                                                                                                                                                        |
| 27         | RS2V        | Receive Status RDES2 Valid<br>When this bit is set, it indicates that the status in RDES2 is valid and it is written by the DMA. This bit is valid only when the LD bit of RDES3 is set.                                                                                                                                                                                               |
| 26         | RS1V        | Receive Status RDES1 Valid<br>When this bit is set, it indicates that the status in RDES1 is valid and it is written by the DMA. This bit is valid only when the LD bit of RDES3 is set.                                                                                                                                                                                               |
| 25         | RS0V        | Receive Status RDES0 Valid<br>When this bit is set, it indicates that the status in RDES0 is valid and it is written by the DMA. This bit is valid only when the LD bit of RDES3 is set.                                                                                                                                                                                               |
| 24         | CE          | CRC Error<br>When this bit is set, it indicates that a Cyclic Redundancy Check (CRC) Error occurred on the received packet. This field is valid only when the LD bit of RDES3 is set.                                                                                                                                                                                                  |
| 23         | GP          | Giant Packet<br>When this bit is set, it indicates that the packet length exceeds the specified maximum Ethernet size of 1518, 1522, or 2000 bytes (9018 or 9022 bytes if jumbo packet enable is set).<br>Note: Giant packet indicates only the packet length. It does not cause any packet truncation.                                                                                |
| 22         | RWT         | Receive Watchdog Timeout<br>When this bit is set, it indicates that the Receive Watchdog Timer has expired while receiving the current packet. The current packet is truncated after watchdog timeout.                                                                                                                                                                                 |
| 21         | OE          | Overflow Error<br>When this bit is set, it indicates that the received packet is damaged because of buffer overflow in Rx FIFO.<br>Note: This bit is set only when the DMA transfers a partial packet to the application. This happens only when the Rx FIFO is operating in the threshold mode. In the store-and-forward mode, all partial packets are dropped completely in Rx FIFO. |
| 20         | RE          | Receive Error<br>When this bit is set, it indicates that the gmii_rxer_i signal is asserted while the gmii_rxdv_i signal is asserted during packet reception. This error also includes carrier extension error in the GMII and half-duplex mode. Error can be of less or no extension, or error (rxd!=0f) during extension.                                                            |
| 19         | DE          | Dribble Bit Error                                                                                                                                                                                                                                                                                                                                                                      |

| Bit   | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      | 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   | <p>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:</p> <ul style="list-style-type: none"> <li>■ 3'b000: The packet is a length packet</li> <li>■ 3'b001: The packet is a type packet.</li> <li>■ 3'b011: The packet is a ARP Request packet type</li> <li>■ 3'b100: The packet is a type packet with VLAN Tag</li> <li>■ 3'b101: The packet is a type packet with Double VLAN Tag</li> <li>■ 3'b110: The packet is a MAC Control packet type</li> <li>■ 3'b111: The packet is a OAM packet type</li> <li>■ 3'b010: Reserved</li> </ul>                     |
| 15    | ES   | <p>Error Summary<br/>When this bit is set, it indicates the logical OR of the following bits:</p> <ul style="list-style-type: none"> <li>■ RDES3[24]: CRC Error</li> <li>■ RDES3[19]: Dribble Error</li> <li>■ RDES3[20]: Receive Error</li> <li>■ RDES3[22]: Watchdog Timeout</li> <li>■ RDES3[21]: Overflow Error</li> <li>■ RDES3[23]: Giant Packet</li> <li>■ RDES2[17]: Destination Address Filter Fail, when Flexible RX Parser is enabled</li> <li>■ RDES2[16]: SA Address Filter Fail, when Flexible RX Parser is enabled</li> </ul> <p>This field is valid only when the LD bit of RDES3 is set.</p>                                               |
| 14    | PL   | <p>Packet Length<br/>These bits indicate the byte length of the received packet that was transferred to system memory (including CRC).</p> <p>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.</p> <p>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> |

### 38.6.10 Receive Context Descriptor

This descriptor is read-only for the application. Only the DMA can write to this descriptor. The context descriptor provides information about the extended status related to the last received packet. The Bit 30 of RDES3 indicates the context type descriptor.

Table 38-25 TDES0 Context Descriptor

| Bit  | Name | Description                                                                                                                           |
|------|------|---------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RSTL | Receive Packet Timestamp Low<br>The DMA updates this field with least significant 32 bits of the timestamp captured for corresponding |

| Bit | Name | Description                                                                                                                   |
|-----|------|-------------------------------------------------------------------------------------------------------------------------------|
|     |      | Receive packet. When this field and the RTSH field of RDES1 show all-ones value, the timestamp must be considered as corrupt. |

Table 38-26 TDES1 Context Descriptor

| Bit  | Name | Description                                                                                                                                                                                                                                                         |
|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RSTH | Receive Packet Timestamp High<br>The DMA updates this field with most significant 32 bits of the timestamp captured for corresponding receive packet. When this field and the RTSL field of RDES0 show all-ones value, the timestamp must be considered as corrupt. |

Table 38-27 TDES2 Context Descriptor

| Bit  | Name     | Description |
|------|----------|-------------|
| 31:0 | Reserved | Reserved    |

Table 38-28 TDES3 Context Descriptor

| 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 when either of the following conditions is true:<br><ul style="list-style-type: none"> <li>■ The DMA completes the packet reception</li> <li>■ The buffers associated with the descriptor are full</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 30   | CTXT     | 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, {CTX, DE}<br><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<br/>Receive DMA will set the CDE bit in DMA_CH#_Status register but not the RI bit even when IOC is set, as this is not marked as last receive descriptor for the packet. The subsequent valid receive descriptor is used to write the packet data.</p> |
| 29   | DE       | Descriptor Error<br>See the CTXT bit description for details of using the DE bit along with CTXT bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 28:0 | Reserved | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

### 38.6.11 Clock Architecture

In RMII mode, reference clock and TX/RX clock be from PHY as following figure. The mux of selecting rmii\_speed is GRF\_SOC\_CON8[3]/GRF\_SOC\_CON11[3].



Fig. 38-11 RMII Clock Architecture When Clock Source From PHY



Fig. 38-12 RMII Clock Architecture When Clock Source From CRU

# Chapter 39 Mobile Storage Host Controller (SDMMC&EMMC)

## 39.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 data width.

The Host Controller is instantiated for SDMMC, 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 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 and 4-bit SDR modes
  - Supports 4-bit DDR
  - Support boot in 1-bit and 4-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 is 128. The average delay for every delay element is 29ps~61ps, the total delay is 3.7ns~7.8ns, varies with VT.

## 39.2 Block Diagram

The controller consists of the following main functional blocks.



Fig.39-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.

## 39.3 Function Description

### 39.3.1 Bus Interface Unit

The Bus Interface Unit provides the following functions:

- Host interface
- Interrupt control
- Register access
- External FIFO access

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

#### 39.3.1.2 Register Unit

The register unit is part of the bus interface unit; it provides read and write access to the registers.

All registers reside in the Bus Interface Unit clock domain. When a command is sent to a card by setting the start\_bit, which is bit[31] of the SDMMC\_CMD register, all relevant registers needed for the CIU operation are transferred to the CIU block. During this time, the registers that are transferred from the BIU to the CIU should not be written. The software should wait for the hardware to clear the start bit before writing to these registers again. The register unit has a hardware locking feature to prevent illegal writes to registers. The lock is necessary in order to avoid metastability violations, both because the host and card clock domains are different and to prevent illegal software operations.

Once a command start is issued by setting the start\_bit of the SDMMC\_CMD register, the following registers cannot be reprogrammed until the command is accepted by the card interface unit:

- SDMMC\_CMD
- SDMMC\_CMDARG
- SDMMC\_BYTCNT
- SDMMC\_BLKSIZ
- SDMMC\_CLKDIV
- SDMMC\_CLKENA
- SDMMC\_CLKSRC
- SDMMC\_TMOUT
- SDMMC\_CTYPE

The hardware resets the start\_bit once the CIU accepts the command. If a host write to any of these registers is attempted during this locked time, then the write is ignored and the hardware lock error bit is set in the raw interrupt status register. Additionally, if the interrupt is enabled and not masked for a hardware lock error, then an interrupt is sent to the host.

When the Card Interface Unit is in an idle state, it typically takes the following number of clocks for the command handshake, where clk is the BIU clock and cclk\_in is the CIU clock: 3 (clk) + 3 (cclk\_in)

Once a command is accepted, you can send another command to the CIU—which has a one-deep command queue—under the following conditions:

- If the previous command was not a data transfer command, the new command is sent to the SD/MMC card once the previous command completes.
- If the previous command is a data transfer command and if wait\_prvdata\_complete (bit[13]) of the SDMMC\_CMD register is set for the new command, the new command is sent to the SD/MMC card only when the data transfer completes.

If the wait\_prvdata\_complete is 0, then the new command is sent to the SD/MMC card as soon as the previous command is sent. Typically, you should use this only to stop or abort a previous data transfer or query the card status in the middle of a data transfer.

#### 39.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 39-1 Bits in Interrupt Status Register

| Bits | Interrupt                                 | Description                                                                                                                                                                                                                                                                                                                                                                                |
|------|-------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24   | sdio_interrupt                            | Interrupt from SDIO card. In MMC-Ver3.3-only mode, these bits are always 0.                                                                                                                                                                                                                                                                                                                |
| 16   | Card no-busy                              | If card exit busy status, the interrupt happened.                                                                                                                                                                                                                                                                                                                                          |
| 15   | End Bit Error (read) / Write no CRC (EBE) | Error in end-bit during read operation, or no data CRC received during write operation.<br>For MMC CMD19, there may be no CRC status returned by the card. Hence, EBE is set for CMD19. The application should not treat this as an error.                                                                                                                                                 |
| 14   | Auto Command Done (ACD)                   | Stop/abort commands automatically sent by card unit and not initiated by host; similar to Command Done (CD) interrupt.<br>Recommendation:<br>Software typically need not enable this for non CE-ATA accesses; Data Transfer Over (DTO) interrupt that comes after this interrupt determines whether data transfer has correctly completed.                                                 |
| 13   | Start Bit Error (SBE)                     | Error in data start bit when data is read from a card. In 4-bit mode, if DAT[0] line indicates start bit—that is, 0—and any of the other data bits do not have start bit, then this error is set.<br>Busy Complete Interrupt when data is written to the card. This interrupt is generated after completion of busy driven by the card after the last data block is written into the card. |
| 12   | Hardware Locked write Error (HLE)         | During hardware-lock period, write attempted to one of locked registers.<br>When software sets the start_cmd bit in the SDMMC_CMD register, the Host Controller tries to load the command. If the command buffer is already filled with a command, this error is raised. The software then has to reload the command.                                                                      |
| 11   | FIFO Underrun/ Overrun Error (FRUN)       | Host tried to push data when FIFO was full, or host tried to read data when FIFO was empty. Typically this should not happen, except due to error in software.<br>Card unit never pushes data into FIFO when FIFO is full, and pop data when FIFO is empty.<br>If IDMAC is enabled, FIFO under-run/over-run can occur due to a programming error on MSIZE and                              |

| Bits | Interrupt                             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                                       | watermark values in SDMMC_FIFOTH register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 10   | Data Starvation by Host Timeout (HTO) | <p>To avoid data loss, card clock out is stopped if FIFO is empty when writing to card, or FIFO is full when reading from card. Whenever card clock is stopped to avoid data loss, data-starvation timeout counter is started with data-timeout value. This interrupt is set if host does not fill data into FIFO during write to card, or does not read from FIFO during read from card before timeout period.</p> <p>Even after timeout, card clock stays in stopped state, with CIU state machines waiting. It is responsibility of host to push or pop data into FIFO upon interrupt, which automatically restarts cclk_out and card state machines.</p> <p>Even if host wants to send stop/abort command, it still needs to ensure it has to push or pop FIFO so that clock starts in order for stop/abort command to send on command signal along with data that is sent or received on data line.</p> |
| 9    | Data Read Timeout (DRTO)              | <p>In Normal functioning mode: Data read timeout (DRTO)</p> <p>Data timeout occurred. Data Transfer Over (DTO) also set if data timeout occurs.</p> <p>In Boot Mode: Boot Data Start (BDS)</p> <p>When set, indicates that Host Controller has started to receive boot data from the card. A write to this register with a value of 1 clears this interrupt.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 8    | Response Timeout (RTO)                | <p>In normal functioning mode: Response timeout (RTO)</p> <p>Response timeout occurred. Command Done (CD) also set if response timeout occurs. If command involves data transfer and when response times out, no data transfer is attempted by Host Controller.</p> <p>In Boot Mode: Boot Ack Received (BAR)</p> <p>When expect_boot_ack is set, on reception of a boot acknowledge pattern—0-1-0—this interrupt is asserted. A write to this register with a value of 1 clears this interrupt.</p>                                                                                                                                                                                                                                                                                                                                                                                                          |
| 7    | Data CRC Error (DCRC)                 | <p>Received Data CRC does not match with locally-generated CRC in CIU.</p> <p>Can also occur if the Write CRC status is incorrectly sampled by the Host.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 6    | Response CRC Error (RCRC)             | Response CRC does not match with locally-generated CRC in CIU.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 5    | Receive FIFO Data Request (RXDR)      | <p>Interrupt set during read operation from card when FIFO level is greater than Receive-Threshold level.</p> <p>Recommendation:</p> <p>In DMA modes, this interrupt should not be enabled.</p> <p>In non-DMA mode: pop RX_WMark + 1 data from FIFO.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4    | Transmit FIFO Data Request (TXDR)     | <p>Interrupt set during write operation to card when FIFO level reaches less than or equal to Transmit-Threshold level.</p> <p>Recommendation:</p> <p>In DMA modes, this interrupt should not be enabled.</p> <p>In non-DMA mode:<br/>if (pending_bytes &gt; (FIFO_DEPTH - TX_WMark))</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Bits | Interrupt                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                          | push (FIFO_DEPTH - TX_WMark) data into FIFO<br>else<br>push pending_bytes data into FIFO                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 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.<br><br>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.<br>DTO bit is set at the end of the last data block, even if the device asserts MMC busy after the last data block. |
| 2    | Command Done(CD)         | Command sent to card and got response from card, even if Response Error or CRC error occurs.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 1    | Response Error (RE)      | Error in received response set if one of following occurs: <ul style="list-style-type: none"> <li>● Transmission bit != 0</li> <li>● Command index mismatch</li> <li>● End-bit != 1</li> </ul>                                                                                                                                                                                                                                                                                                                                                  |
| 0    | Card-Detect (CDT)        | When one or more cards inserted or removed, this interrupt occurs.<br>Software should read card-detect register to determine current card status.<br>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.                     |

### 39.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).

### 39.3.2 Card Interface Unit

The Card Interface Unit (CIU) interfaces with the Bus Interface Unit (BIU) and the external devices. The host writes command parameters to the BIU control registers, and these parameters are then passed to the CIU. Depending on control register values, the CIU generates SD/MMC command and data traffic on a selected card bus according to SD/MMC protocol. The Host Controller accordingly controls the command and data path.

The following software restrictions should be met for proper CIU operation:

- Only one data transfer command can be issued at a time.
- During an open-ended card write operation, if the card clock is stopped because the FIFO is empty, the software must first fill the data into the FIFO and start the card clock. It can then issue only a stop/abort command to the card.
- When issuing card reset commands (CMD0, CMD15 or CMD52\_reset) while a card data

transfer is in progress, the software must set the stop\_abort\_cmd bit in the SDMMC\_CMD register so that the Host Controller can stop the data transfer after issuing the card reset command.

- When the data end bit error is set in the SDMMC\_RINTSTS register, the Host Controller does not guarantee SDIO interrupts. The software should ignore the SDIO interrupts and issue the stop/abort command to the card, so that the card stops sending the read data.
- If the card clock is stopped because the FIFO is full during a card read, the software should read at least two FIFO locations to start the card clock.

The CIU block consists of the following primary functional blocks:

- Command path
- Data path
- SDIO interrupt control
- Clock control
- Error detection

### **39.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. 39-2 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.

### **39.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. 39-3 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 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 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, 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. 39-4 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 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 data transfer, data is received from 1, 4 data lines, respectively, and CRC16 is separately generated and checked for 1, 4 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 39-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          |

| Card type | Transfer type        | Byte Count | send_auto_stop bit set | Comments                   |
|-----------|----------------------|------------|------------------------|----------------------------|
| SDIO      | Multiple-block read  | >0         | No                     | Pre-defined multiple block |
| SDIO      | Multiple-block write | 0          | No                     | Open-ended multiple block  |
| SDIO      | Multiple-block write | >0         | No                     | Pre-defined multiple block |

D: The condition under which the transfer mode is set to block transfer and byte\_count is equal to block size is treated as a single-block data transfer command for both MMC and SD cards. If byte\_count = n\*block\_size (n = 2, 3, ...), the condition is treated as a predefined multiple-block data transfer command. In the case of an MMC card, the host software can perform a predefined data transfer in two ways: 1) Issue the CMD23 command before issuing CMD18/CMD25 commands to the card – in this case, issue MD18/CMD25 commands without setting the send\_auto\_stop bit. 2) Issue CMD18/CMD25 commands without issuing CMD23 command to the card, with the send\_auto\_stop bit set. In this case, the multiple-block data transfer is terminated by an internally-generated auto-stop command after the programmed byte count.

The following list conditions for the auto-stop command.

- Stream read for MMC card with byte count greater than 0 – The Host Controller generates an internal stop command and loads it into the command path so that the end bit of the stop command is sent out when the last byte of data is read from the card and no extra data byte is received. If the byte count is less than 6 (48 bits), a few extra data bytes are received from the card before the end bit of the stop command is sent.
- Stream write for MMC card with byte count greater than 0 - The Host Controller generates an internal stop command and loads it into the command path so that the end bit of the stop command is sent when the last byte of data is transmitted on the card bus and no extra data byte is transmitted. If the byte count is less than 6 (48 bits), the data path transmits the data last in order to meet the above condition.
- Multiple-block read memory for SD card with byte count greater than 0 – If the block size is less than 4 (single-bit data bus), 16 (4-bit data bus), or 32 (8-bit data bus), the auto-stop command is loaded in the command path after all the bytes are read. Otherwise, the 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.

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

| Base Address [12:8]                          | CMD 27     | CMD 30                            | CMD 42                 | ACMD 13    | ACMD 22    | ACMD 51    |
|----------------------------------------------|------------|-----------------------------------|------------------------|------------|------------|------------|
| check_response_crc                           | 1          | 1                                 | 1                      | 1          | 1          | 1          |
| data_expected                                | 1          | 1                                 | 1                      | 1          | 1          | 1          |
| read/write                                   | 1          | 0                                 | 1                      | 0          | 0          | 0          |
| transfer_mode                                | 0          | 0                                 | 0                      | 0          | 0          | 0          |
| send_auto_stop                               | 0          | 0                                 | 0                      | 0          | 0          | 0          |
| wait_prevdata_complete                       | 0          | 0                                 | 0                      | 0          | 0          | 0          |
| stop_abort_cmd                               | 0          | 0                                 | 0                      | 0          | 0          | 0          |
| <b>Command Argument register programming</b> |            |                                   |                        |            |            |            |
|                                              | stuff bits | 32-bit write protect data address | stuff bits             | stuff bits | stuff bits | stuff 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)

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

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

### **39.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.

### **39.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.

#### **39.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.

#### **39.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. 39-5 Dual-Buffer Descriptor Structure

- Chain Structure – Each descriptor points to a unique buffer and the next descriptor.



Fig. 39-6 Chain Descriptor Structure

- Descriptor formats

Following figure illustrates the internal formats of a descriptor. The descriptor addresses must be aligned to the bus width used for 32-bit AHB data buses. Each descriptor contains 16 bytes of control and status information. DES0 is a notation used to denote the [31:0] bits, DES1 to denote [63:32] bits, DES2 to denote [95:64] bits, DES3 to denote [127:96] bits.



Fig. 39-7 Descriptor Formats for 32-bit AHB Address Bus Width

- The DES0 element in the IDMAC contains control and status information.

Table 39-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 39-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 39-6 Bits in IDMAC DES2 Element

| Bit   | Name                | Description                                                                                                                                                                              |
|-------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:26 | Reserved            |                                                                                                                                                                                          |
| 25:13 | Buffer 2 Size (BS2) | These bits indicate the second data buffer byte size. The buffer size must be a multiple of 2, 4, or 8, depending upon the bus widths—16, 32, and 64 respectively. In the case where the |

| Bit  | Name                | Description                                                                                                                                                                                                                                                                                                                                                                                       |
|------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                     | 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 39-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. |

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

### **39.3.3.4 Variable Delay/Clock Generation Unit**

Variable delay mechanism for the cclk\_in\_drv is useful in order to meet a range of hold-time requirements across modes. Variable delay mechanism for the cclk\_in\_sample is mandatory and is required to achieve the correct sampling point for data.

The Clock Generation Unit (CLKGEN) includes Phase Shift Unit and Delay Line Unit.

The Phase Shift Unit can shift cclk\_in\_sample/cclk\_in\_drv by 0/90/180/270-degree relative to cclk\_in. The Delay Line Unit can shift cclk\_in\_sample/cclk\_in\_drv step by step in the unit of delay element. The delay value range is 21ps~48ps for every delay element; the max delay element number is 128.

The architecture is as follows.



Fig. 39-8 Clock Generation Unit

## **39.4 Register Description**

### **39.4.1 Registers Summary**

| Name                 | Offset | Size | Reset Value | Description                      |
|----------------------|--------|------|-------------|----------------------------------|
| <u>SDMMC_CTRL</u>    | 0x0000 | W    | 0x00000000  | Control register                 |
| <u>SDMMC_PWREN</u>   | 0x0004 | W    | 0x00000000  | Power enable register            |
| <u>SDMMC_CLKDIV</u>  | 0x0008 | W    | 0x00000000  | Clock divider register           |
| <u>SDMMC_CLKSRC</u>  | 0x000C | W    | 0x00000000  | SD clock source register         |
| <u>SDMMC_CLKENA</u>  | 0x0010 | W    | 0x00000000  | Clock enable register            |
| <u>SDMMC_TMOUT</u>   | 0x0014 | W    | 0xFFFFFFF40 | Timeout register                 |
| <u>SDMMC_CTYPE</u>   | 0x0018 | W    | 0x00000000  | Card type register               |
| <u>SDMMC_BLKSIZ</u>  | 0x001C | W    | 0x00000200  | Block size register              |
| <u>SDMMC_BYTCNT</u>  | 0x0020 | W    | 0x00000200  | Byte count register              |
| <u>SDMMC_INTMASK</u> | 0x0024 | W    | 0x00000000  | Interrupt mask register          |
| <u>SDMMC_CMDARG</u>  | 0x0028 | W    | 0x00000000  | Command argument register        |
| <u>SDMMC_CMD</u>     | 0x002C | W    | 0x20000000  | Command register                 |
| <u>SDMMC_RESP0</u>   | 0x0030 | W    | 0x00000000  | Response register 0              |
| <u>SDMMC_RESP1</u>   | 0x0034 | W    | 0x00000000  | Response register 1              |
| <u>SDMMC_RESP2</u>   | 0x0038 | W    | 0x00000000  | Response register 2              |
| <u>SDMMC_RESP3</u>   | 0x003C | W    | 0x00000000  | Response register 3              |
| <u>SDMMC_MINTSTS</u> | 0x0040 | W    | 0x00000000  | Masked interrupt status register |
| <u>SDMMC_RINTSTS</u> | 0x0044 | W    | 0x00000000  | Raw interrupt status register    |

| Name                | Offset | Size | Reset Value | Description                                      |
|---------------------|--------|------|-------------|--------------------------------------------------|
| SDMMC_STATUS        | 0x0048 | W    | 0x00000106  | Status register                                  |
| SDMMC_FIFOTH        | 0x004C | W    | 0x00FF0000  | FIFO threshold register                          |
| SDMMC_CDETECT       | 0x0050 | W    | 0x00000001  | Card detect register                             |
| SDMMC_WRPRT         | 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_CLKGEN_CON0   | 0x0130 | W    | 0x00000004  | Clock generation control register 0              |
| SDMMC_CLKGEN_CON1   | 0x0134 | W    | 0x00000000  | Clock generation control register 1              |
| SDMMC_MISC_CON      | 0x0138 | W    | 0x00000000  | Miscellaneous control register                   |
| SDMMC_FIFO_BASE     | 0x0200 | W    | 0x00000000  | FIFO base address register                       |

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

### 39.4.2 Detail Register Description

#### SDMMC\_CTRL

Address: Operational Base (0xFF480000) + 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                                                                                                                                                                                                         |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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<br/>           Software should appropriately write to this bit after power-on reset or any other reset to CE-ATA device. After reset, usually CE-ATA device interrupt is disabled. If the host enables CE-ATA device interrupt, then software should set this bit.</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<br/>           NOTE: Always set send_auto_stop_ccsd and send_ccsd bits together send_auto_stop_ccsd should not be set independent of send_ccsd.<br/>           When set, the Host Controller automatically sends internally-generated STOP command (CMD12) to CE-ATA device. After sending internally-generated STOP command, Auto Command Done (ACD) bit in SDMMC_RINTSTS is set and generates interrupt to host if Auto Command Done interrupt is not masked. After sending the CCSD, the Host Controller automatically clears send_auto_stop_ccsd bit.</p>                                                                                                                               |
| 9   | RW   | 0x0         | <p>send_ccsd<br/>           1'b0: Clear bit if Host Controller does not reset the bit<br/>           1'b1: Send Command Completion Signal Disable (CCSD) to CE-ATA device<br/>           When set, the Host Controller sends CCSD to CE-ATA device. Software sets this bit only if current command is expecting CCS (that is, RW_BLK) and interrupts are enabled in CE-ATA device. Once the CCSD pattern is sent to device, the Host Controller automatically clears send_ccsd bit. It also sets Command Done (CD) bit in SDMMC_RINTSTS register and generates interrupt to host if Command Done interrupt is not masked.<br/>           NOTE: Once send_ccsd bit is set, it takes two card clock cycles to drive the CCSD on the CMD line. Due to this, during the boundary conditions it may happen that CCSD is sent to the CE-ATA device, even if the device signalled CCS.</p> |
| 8   | RW   | 0x0         | <p>abort_read_data<br/>           1'b0: No change<br/>           1'b1: After suspend command is issued during read-transfer, software polls card to find when suspend happened. Once suspend occurs, software sets bit to reset data state-machine, which is waiting for next block of data. Bit automatically clears once data state machine resets to idle.<br/>           Used in SDIO card suspend sequence.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 7   | RW   | 0x0         | <p>send_irq_response<br/>           1'b0: No change<br/>           1'b1: Send auto IRQ response<br/>           Bit automatically clears once response is sent.<br/>           To wait for MMC card interrupts, software issues CMD40, and the Host Controller waits for interrupt response from MMC card. In meantime, if software wants the Controller to exit waiting for interrupt state, it can set this bit, at which time the Host Controller command state-machine sends CMD40 response on bus and returns to idle state.</p>                                                                                                                                                                                                                                                                                                                                                |

| <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          | W1C         | 0x0                | dma_reset<br>1'b0: No change<br>1'b1: Reset internal DMA interface control logic<br>To reset DMA interface, firmware should set bit to 1.<br>This bit is auto-cleared after two AHB clocks.                                                                                                                                                                                                                                                                                                |
| 1          | W1C         | 0x0                | fifo_reset<br>1'b0: No change<br>1'b1: Reset to data FIFO to reset FIFO pointers<br>To reset FIFO, firmware should set bit to 1.<br>This bit is auto-cleared after completion of reset operation.                                                                                                                                                                                                                                                                                          |
| 0          | W1C         | 0x0                | controller_reset<br>1'b0: No change<br>1'b1: Reset Host Controller<br>To reset Host Controller, firmware should set bit to 1. This bit is auto-cleared after two AHB and two cclk_in clock cycles.<br>This resets:<br>a. BIU/CIU interface<br>b. CIU and state machines<br>c. abort_read_data, send_irq_response, and read_wait bits of SDMMC_CTRL register<br>d. start_cmd bit of SDMMC_CMD register<br>Does not affect any registers or DMA interface, or FIFO or controller interrupts. |

**SDMMC PWREN**

Address: Operational Base (0xFF480000) + 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**

## RK3506 TRM (Part 1)

Address: Operational Base (0xFF480000) + offset (0x0008)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                        |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0000000   | 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 = 1$ (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 (0xFF480000) + 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 (0xFF480000) + 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. 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 (0xFF480000) + 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 (0xFF480000) + offset (0x0018)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------|
| 16         | RW          | 0x0                | card_width_8<br>Indicates if card is 8-bit.<br>1'b0: Non 8-bit mode<br>1'b1: 8-bit mode    |
| 15:1       | RO          | 0x0000             | reserved                                                                                   |
| 0          | RW          | 0x0                | card_width<br>Indicates if card is 1-bit or 4-bit.<br>1'b0: 1-bit mode<br>1'b1: 4-bit mode |

**SDMMC\_BLKSIZ**

Address: Operational Base (0xFF480000) + 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 (0xFF480000) + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000200         | 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 (0xFF480000) + 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> <ul style="list-style-type: none"> <li>bit 15: End-bit error (read)/Write no CRC (EBE)</li> <li>bit 14: Auto command done (ACD)</li> <li>bit 13: Start-bit error (SBE)</li> <li>bit 12: Hardware locked write error (HLE)</li> <li>bit 11: FIFO underrun/overrun error (FRUN)</li> <li>bit 10: Data starvation-by-host timeout (HTO) /Volt_switch_int</li> <li>bit 9: Data read timeout (DRTO)</li> <li>bit 8: Response timeout (RTO)</li> <li>bit 7: Data CRC error (DCRC)</li> <li>bit 6: Response CRC error (RCRC)</li> <li>bit 5: Receive FIFO data request (RXDR)</li> <li>bit 4: Transmit FIFO data request (TXDR)</li> <li>bit 3: Data transfer over (DTO)</li> <li>bit 2: Command done (CD)</li> <li>bit 1: Response error (RE)</li> <li>bit 0: Card detect (CD)</li> </ul> |

**SDMMC\_CMDARG**

Address: Operational Base (0xFF480000) + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>cmd_arg<br/>           Value indicates command argument to be passed to card</p> |

**SDMMC\_CMD**

Address: Operational Base (0xFF480000) + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | <p>start_cmd<br/>           Start command.<br/>           Once command is taken by CIU, bit is cleared.<br/>           When bit is set, host should not attempt to write to any command registers. If write is attempted, hardware lock error is set in raw interrupt register.<br/>           Once command is sent and response is received from SD/MMC cards, Command Done bit is set in raw interrupt register.</p> |
| 30         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                               |
| 29         | RW          | 0x1                | <p>use_hold_reg<br/>           Use hold register.<br/>           1'b0: CMD and DATA sent to card bypassing hold register<br/>           1'b1: CMD and DATA sent to card through the hold register</p>                                                                                                                                                                                                                  |
| 28         | RW          | 0x0                | <p>volt_switch<br/>           Voltage switch bit.<br/>           1'b0: No voltage switching<br/>           1'b1: Voltage switching enabled; must be set for CMD11 only.</p>                                                                                                                                                                                                                                            |
| 27         | RW          | 0x0                | <p>boot_mode<br/>           Boot mode selection.<br/>           1'b0: Mandatory boot operation<br/>           1'b1: Alternate boot operation</p>                                                                                                                                                                                                                                                                       |
| 26         | RW          | 0x0                | <p>disable_boot<br/>           Disable boot.<br/>           When software sets this bit along with start_cmd, CIU terminates the boot operation. Do not set disable_boot and enable_boot together.</p>                                                                                                                                                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25         | RW          | 0x0                | expect_boot_ack<br>Expect boot acknowledge.<br>When software sets this bit along with enable_boot, CIU expects a boot acknowledge start pattern of 0-1-0 from the selected card.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 24         | RW          | 0x0                | enable_boot<br>Enable boot.<br>This bit should be set only for mandatory boot mode. When Software sets this bit along with start_cmd, CIU starts the boot sequence for the corresponding card by asserting the CMD line low. Do not set disable_boot and enable_boot together.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 23         | RW          | 0x0                | ccs_expected<br>1'b0: Interrupts are not enabled in CE-ATA device or command does not expect CCS from device<br>1'b1: Interrupts are enabled in CE-ATA device and RW_BLK command expects command completion signal from CE-ATA device<br>If the command expects command completion signal (CCS) from the CE-ATA device, the software should set this control bit.<br>The Host Controller sets data transfer over (DTO) bit in SDMMC_RINTSTS register and generates interrupt to host if data transfer over interrupt is not masked.                                                                                                                                                                                                                                                                                                                |
| 22         | RW          | 0x0                | read_ceata_device<br>1'b0: Host is not performing read access towards CE-ATA device<br>1'b1: Host is performing read access towards CE-ATA device<br>Software should set this bit to indicate that CE-ATA device is being accessed for read transfer. This bit is used to disable read data timeout indication while performing CE-ATA read transfers. Maximum value of I/O transmission delay can be no less than 10 seconds. The Host Controller should not indicate read data timeout while waiting for data from CE-ATA device.                                                                                                                                                                                                                                                                                                                |
| 21         | RW          | 0x0                | update_clock_regs_only<br>1'b0: Normal command sequence<br>1'b1: Do not send commands, just update clock register value into card clock domain.<br>Following register values transferred into card clock domain: SDMMC_CLKDIV, SDMMC_CLRSRC, SDMMC_CLKENA.<br>Changes card clocks (change frequency, truncate off or on, and set low-frequency mode); provided in order to change clock frequency or stop clock without having to send command to cards.<br>During normal command sequence, when update_clock_regs_only = 0, following control registers are transferred from BIU to CIU: SDMMC_CMD, SDMMC_CMDARG, SDMMC_TMOUT, SDMMC_CTYPE, SDMMC_BLKSIZ, SDMMC_BYTCNT. CIU uses new register values for new command sequence to card.<br>When bit is set, there are no Command Done interrupts because no command is sent to SD_MMC_CEATA cards. |
| 20:16      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15         | RW          | 0x0                | <p>send_initialization<br/>1'b0: Do not send initialization sequence (80 clocks of 1) before sending this command<br/>1'b1: Send initialization sequence before sending this command<br/>After power on, 80 clocks must be sent to card for initialization before sending any commands to card. Bit should be set while sending first command to card so that controller will initialize clocks before sending command to card. This bit should not be set for either of the boot modes (alternate or mandatory).</p>                                                                                                                                                            |
| 14         | RW          | 0x0                | <p>stop_abort_cmd<br/>1'b0: Neither stop nor abort command to stop current data transfer in progress. If abort is sent to function-number currently selected or not in data-transfer mode, then bit should be set to 0.<br/>1'b1: Stop or abort command intended to stop current data transfer in progress.<br/>When open-ended or predefined data transfer is in progress, and host issues stop or abort command to stop data transfer, bit should be set so that command/data state-machines of CIU can return correctly to idle state. This is also applicable for Boot mode transfers. To Abort boot mode, this bit should be set along with SDMMC_CMD[26]=disable_boot.</p> |
| 13         | RW          | 0x0                | <p>wait_prvdata_complete<br/>1'b0: Send command at once, even if previous data transfer has not completed<br/>1'b1: Wait for previous data transfer completion before sending command<br/>The wait_prvdata_complete=0 option typically used to query status of card during data transfer or to stop current data transfer; card_number should be same as in previous command.</p>                                                                                                                                                                                                                                                                                                |
| 12         | RW          | 0x0                | <p>send_auto_stop<br/>1'b0: No stop command sent at end of data transfer<br/>1'b1: Send stop command at end of data transfer<br/>When set, the Host Controller sends stop command to card at end of data transfer.<br/>a. When send_auto_stop bit should be set, since some data transfers do not need explicit stop commands<br/>b. Open-ended transfers that software should explicitly send to stop command<br/>Additionally, when "resume" is sent to resume-suspended memory access of SD-Combo card, bit should be set correctly if suspended data transfer needs send_auto_stop.<br/>Don't care if no data expected from card.</p>                                        |
| 11         | RW          | 0x0                | <p>transfer_mode<br/>1'b0: Block data transfer command<br/>1'b1: Stream data transfer command<br/>Don't care if no data expected.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 10         | RW          | 0x0                | <p>wr<br/>1'b0: Read from card<br/>1'b1: Write to card<br/>Don't care if no data expected from card.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 9          | RW          | 0x0                | <p>data_expected<br/>1'b0: No data transfer expected (read/write)<br/>1'b1: Data transfer expected (read/write)</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8          | RW          | 0x0                | check_response_crc<br>1'b0: Do not check response CRC<br>1'b1: Check response CRC<br>Some of command responses do not return valid CRC bits.<br>Software should disable CRC checks for those commands in order to disable CRC checking by controller. |
| 7          | RW          | 0x0                | response_length<br>1'b0: Short response expected from card<br>1'b1: Long response expected from card                                                                                                                                                  |
| 6          | RW          | 0x0                | response_expect<br>1'b0: No response expected from card<br>1'b1: Response expected from card                                                                                                                                                          |
| 5:0        | RW          | 0x00               | cmd_index<br>Command index                                                                                                                                                                                                                            |

**SDMMC RESP0**

Address: Operational Base (0xFF480000) + 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 (0xFF480000) + 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 (0xFF480000)** + 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 (0xFF480000)** + 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 (0xFF480000) + 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<br/>           Interrupt enabled only if corresponding bit in interrupt mask register is set.</p> <ul style="list-style-type: none"> <li>bit 15: End-bit error (read)/Write no CRC (EBE)</li> <li>bit 14: Auto command done (ACD)</li> <li>bit 13: Start-bit error (SBE)</li> <li>bit 12: Hardware locked write error (HLE)</li> <li>bit 11: FIFO underrun/overrun error (FRUN)</li> <li>bit 10: Data starvation-by-host timeout (HTO) /Volt_switch_int</li> <li>bit 9: Data read timeout (DRTO)</li> <li>bit 8: Response timeout (RTO)</li> <li>bit 7: Data CRC error (DCRC)</li> <li>bit 6: Response CRC error (RCRC)</li> <li>bit 5: Receive FIFO data request (RXDR)</li> <li>bit 4: Transmit FIFO data request (TXDR)</li> <li>bit 3: Data transfer over (DTO)</li> <li>bit 2: Command done (CD)</li> <li>bit 1: Response error (RE)</li> <li>bit 0: Card detect (CD)</li> </ul> |

**SDMMC\_RINTSTS**

Address: Operational Base (0xFF480000) + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 24         | R/W SC      | 0x0                | <p>sdio_interrupt<br/>           Raw SDIO interrupt status.<br/>           Write value of 1 clears this bit, and value of 0 leaves bit intact.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 23:17      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 16         | R/W SC      | 0x0                | <p>data_nobusy_int_status<br/>           Raw data no busy interrupt status.<br/>           Write value of 1 clears this bit, and value of 0 leaves bit intact.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 15:0       | R/W SC      | 0x0000             | <p>int_status<br/>           Raw interrupt status.<br/>           Writes to bits clear status bit. Write value of 1 clears status bit, and value of 0 leaves bit intact.</p> <ul style="list-style-type: none"> <li>bit 15: End-bit error (read)/Write no CRC (EBE)</li> <li>bit 14: Auto command done (ACD)</li> <li>bit 13: Start-bit error (SBE)</li> <li>bit 12: Hardware locked write error (HLE)</li> <li>bit 11: FIFO underrun/overrun error (FRUN)</li> <li>bit 10: Data starvation-by-host timeout (HTO) /Volt_switch_int</li> <li>bit 9: Data read timeout (DRTO)</li> <li>bit 8: Response timeout (RTO)</li> <li>bit 7: Data CRC error (DCRC)</li> <li>bit 6: Response CRC error (RCRC)</li> <li>bit 5: Receive FIFO data request (RXDR)</li> <li>bit 4: Transmit FIFO data request (TXDR)</li> <li>bit 3: Data transfer over (DTO)</li> <li>bit 2: Command done (CD)</li> <li>bit 1: Response error (RE)</li> <li>bit 0: Card detect (CD)</li> </ul> |

**SDMMC\_STATUS**

Address: Operational Base (0xFF480000) + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | dma_req<br>DMA request signal state                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 30         | RO          | 0x0                | dma_ack<br>DMA acknowledge signal state                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 29:17      | RO          | 0x0000             | fifo_count<br>Number of filled locations in FIFO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 16:11      | RO          | 0x00               | response_index<br>Index of previous response, including any auto-stop sent by core.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 10         | RO          | 0x0                | data_state_mc_busy<br>Data transmit or receive state-machine is busy                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 9          | RO          | 0x0                | data_busy<br>Inverted version of raw selected card_data[0].<br>1'b0: Card data not busy<br>1'b1: Card data busy                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 8          | RO          | 0x1                | data_3_status<br>Raw selected card_data[3]; checks whether card is present.<br>1'b0: Card not present<br>1'b1: Card present                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 7:4        | RO          | 0x0                | command_fsm_states<br>Command FSM states:<br>4'h0: Idle<br>4'h1: Send init sequence<br>4'h2: Tx cmd start bit<br>4'h3: Tx cmd tx bit<br>4'h4: Tx cmd index + arg<br>4'h5: Tx cmd crc7<br>4'h6: Tx cmd end bit<br>4'h7: Tx resp start bit<br>4'h8: Rx resp IRQ response<br>4'h9: Rx resp tx bit<br>4'ha: Rx resp cmd idx<br>4'hb: Rx resp data<br>4'hc: Rx resp crc7<br>4'hd: Rx resp end bit<br>4'he: Cmd path wait NCC<br>4'hf: Wait CMD-to-response turnaround<br>The command FSM state is represented using 19 bits.<br>The SDMMC_STATUS register[7:4] has 4 bits to represent the command FSM states. Using these 4 bits, only 16 states can be represented. Thus three states cannot be represented in the SDMMC_STATUS[7:4] register. The three states that are not represented in the SDMMC_STATUS register[7:4] are:<br>Bit 16: Wait for CCS<br>Bit 17: Send CCSD<br>Bit 18: Boot Mode<br>Due to this, while command FSM is in "Wait for CCS state" or "Send CCSD" or "Boot Mode", the SDMMC_STATUS register indicates status as 0 for the bit field [7:4]. |
| 3          | RO          | 0x0                | fifo_full<br>FIFO is full status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 2          | RO          | 0x1                | fifo_empty<br>FIFO is empty status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 1          | RO          | 0x1                | fifo_tx_watermark<br>FIFO reached Transmit watermark level; not qualified with data transfer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------|
| 0          | RO          | 0x0                | fifo_rx_watermark<br>FIFO reached Receive watermark level; not qualified with data transfer. |

**SDMMC FIFO TH**

Address: Operational Base (0xFF480000) + 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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 11:0       | RW          | 0x000              | 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.<br>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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | (not before FIFO is full or after CIU completes data transfers, because FIFO may not be empty).<br>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.<br>12 bits -1 bit less than FIFO-count of status register, which is 13 bits.<br>Limitation: tx_wmark $\geq 1$ ;<br>Recommended: FIFO_DEPTH/2; (means less than or equal to FIFO_DEPTH/2) |

**SDMMC\_CDETECT**

Address: Operational Base (0xFF480000) + offset (0x0050)

| Bit  | Attr | Reset Value | Description                                                                                                                  |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| 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 (0xFF480000) + offset (0x0054)

| Bit  | Attr | Reset Value | Description                                                                         |
|------|------|-------------|-------------------------------------------------------------------------------------|
| 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 (0xFF480000) + offset (0x005C)

| Bit  | Attr | Reset Value | Description                                                              |
|------|------|-------------|--------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | trans_card_byte_count<br>Number of bytes transferred by CIU unit to card |

**SDMMC\_TBBCNT**

Address: Operational Base (0xFF480000) + offset (0x0060)

| Bit  | Attr | Reset Value | Description                                                                               |
|------|------|-------------|-------------------------------------------------------------------------------------------|
| 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 (0xFF480000) + offset (0x0064)

| Bit   | Attr | Reset Value | Description                                                                                             |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------|
| 31:24 | RO   | 0x00        | reserved                                                                                                |
| 23:0  | RW   | 0xfffffff   | debounce_count<br>Number of host clock used by debounce filter logic; typical debounce time is 5-25 ms. |

**SDMMC\_USRID**

Address: Operational Base (0xFF480000) + offset (0x0068)

| Bit  | Attr | Reset Value | Description                           |
|------|------|-------------|---------------------------------------|
| 31:0 | RW   | 0x00000000  | usrid<br>User identification register |

**SDMMC\_VERID**

## RK3506 TRM (Part 1)

Address: Operational Base (0xFF480000) + offset (0x006C)

| Bit  | Attr | Reset Value | Description                              |
|------|------|-------------|------------------------------------------|
| 31:0 | RO   | 0x5342270a  | verid<br>Version identification register |

## SDMMC HCON

Address: Operational Base (0xFF480000) + offset (0x0070)

| Bit   | Attr | Reset Value | Description                                                                                    |
|-------|------|-------------|------------------------------------------------------------------------------------------------|
| 31:27 | RO   | 0x00        | reserved                                                                                       |
| 26    | RO   | 0x1         | area_optimized<br>1'b0: No area optimization<br>1'b1: Area optimization                        |
| 25:24 | RO   | 0x0         | num_clk_div<br>divider number-1.                                                               |
| 23    | RO   | 0x1         | set_clk_false_path<br>1'b0: No false path<br>1'b1: False path set                              |
| 22    | RO   | 0x1         | impl_hold_reg<br>1'b0: No hold register<br>1'b1: Hold register                                 |
| 21    | RO   | 0x0         | fifo_ram_inside<br>1'b0: Outside<br>1'b1: Inside                                               |
| 20:18 | RO   | 0x1         | ge_dma_data_width<br>3'b000: 16 bits<br>3'b001: 32 bits<br>3'b010: 64 bits<br>Others: Reserved |
| 17:16 | RO   | 0x0         | dma_interface<br>2'b00: None<br>2'b01: INT_DMA<br>2'b10: GENERIC_DMA<br>2'b11: NON_INT_DMA     |
| 15:10 | RO   | 0x0d        | h_addr_width<br>6'h8: 9 bits<br>6'h9: 10 bits<br>.....<br>6'h1f: 32 bits<br>Others: Reserved   |
| 9:7   | RO   | 0x1         | h_data_width<br>3'b000: 16 bits<br>3'b001: 32 bits<br>3'b010: 64 bits<br>Others: Reserved      |
| 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 (0xFF480000) + 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 (0xFF480000) + 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 (0xFF480000) + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:11      | RO          | 0x0000000          | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 10:8       | RO          | 0x0                | 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.<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>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. |
| 7          | RW          | 0x0                | de<br>IDMAC enable.<br>When set, the IDMAC is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 6:2        | RW          | 0x00               | 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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | 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. |
| 0          | RW          | 0x0                | swr<br>Software reset.<br>When set, the DMA Controller resets all its internal registers. It is automatically cleared after 1 clock cycle.                                                                                                                                            |

**SDMMC PLDMND**

Address: Operational Base (0xFF480000) + offset (0x0084)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | WO          | 0x00000000         | 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. |

**SDMMC DBADDR**

Address: Operational Base (0xFF480000) + 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 (0xFF480000) + 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>IDMAC 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           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9          | RW          | 0x0                | <p>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.</p>                                                                                                                                                                                                                                                                                            |
| 8          | RW          | 0x0                | <p>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.</p>                                                                                                                                                                                                                                                                                              |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 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:<br/>EBE: End Bit Error<br/>RTO: Response Timeout/Boot Ack Timeout<br/>RCRC: Response CRC<br/>SBE: Start Bit Error<br/>DRTO: Data Read Timeout/BDS timeout<br/>DCRC: Data CRC for Receive<br/>RE: Response Error<br/>Writing a 1 clears this bit.<br/>The abort condition of the IDMAC depends on the setting of this CES bit. If the CES bit is enabled, then the IDMAC aborts on a "response error"; however, it will not abort if the CES bit is cleared.</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]).<br/>When this bit is set, the DMA disables all its bus accesses.<br/>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.<br/>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.<br/>Writing 1 clears this bit.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

**SDMMC\_IDINTEN**

Address: Operational Base (0xFF480000) + offset (0x0090)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9          | RW          | 0x0                | ai<br>Abnormal interrupt summary enable.<br>When set, an abnormal interrupt is enabled.<br>This bit enables the following bits:<br>SDMMC_IDINTEN[2] fatal bus error interrupt<br>SDMMC_IDINTEN[4] du interrupt                                      |
| 8          | RW          | 0x0                | ni<br>Normal interrupt summary enable.<br>When set, a normal interrupt is enabled. When reset, a normal interrupt is disabled.<br>This bit enables the following bits:<br>SDMMC_IDINTEN[0] transmit interrupt<br>SDMMC_IDINTEN[1] receive interrupt |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                            |
| 5          | RW          | 0x0                | ces<br>Card error summary interrupt enable.<br>When set, it enables the card interrupt summary.                                                                                                                                                     |
| 4          | RW          | 0x0                | du<br>Descriptor unavailable interrupt.<br>When set along with abnormal interrupt summary enable, the du interrupt is enabled.                                                                                                                      |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                                                                                            |
| 2          | RW          | 0x0                | fbe<br>Fatal bus error enable.<br>When set with abnormal interrupt summary enable, the fatal bus error interrupt is enabled.<br>When reset, fatal bus error enable interrupt is disabled.                                                           |
| 1          | RW          | 0x0                | ri<br>Receive interrupt enable.<br>When set with normal interrupt summary enable, receive interrupt is enabled.<br>When reset, receive interrupt is disabled.                                                                                       |
| 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 (0xFF480000) + 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 (0xFF480000) + 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 (0xFF480000) + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 27:16      | RW          | 0x000              | card_rd_thres<br>Card read threshold size                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 15:2       | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 1          | RW          | 0x0                | 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. |
| 0          | RW          | 0x0                | card_rd_thres_en<br>Card read threshold enable.<br>1'b0: Card read threshold disabled<br>1'b1: Card read threshold enabled. The host initiates read transfer only if card_rd_thres amount of space is available in receive FIFO.                                                                                                                                                                                                                                                                                                                                    |

**SDMMC BACKEND POWER**

Address: Operational Base (0xFF480000) + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                   |
| 0          | RW          | 0x0                | back_end_power<br>Back end power.<br>1'b0: Off; Reset<br>1'b1: Back-end power supplied to card application |

**SDMMC EMMCDDR REG**

Address: Operational Base (0xFF480000) + offset (0x010C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                        |
| 0          | RW          | 0x0                | half_start_bit<br>Control for start bit detection mechanism inside Host Controller based on duration of start bit.<br>For eMMC 4.5, start bit can be:<br>1'b0: Full cycle (half_start_bit=0)<br>1'b1: Less than one full cycle (half_start_bit=1)<br>Set half_start_bit=1 for eMMC 4.5 and above; set to 0 for SD applications. |

**SDMMC RDYINT GEN**

Address: Operational Base (0xFF480000) + offset (0x0120)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------|
| 31:25      | RO          | 0x00               | reserved                                                                                                        |
| 24         | RO          | 0x0                | rdyint_cnt_finish<br>Counter finish indication.<br>When high, it indicates that the rdyint counter is finished. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23:16      | RO          | 0xff               | rdyint_cnt_status<br>Counter status, reflect internal counter value.                                                                                                                                                                                                                              |
| 15:9       | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                          |
| 8          | RW          | 0x0                | rdyint_gen_working<br>Working indication for rdyint generator.<br>When high, Host Controller start to count and generate one rdyint trigger. After the rdyint trigger is generated, this bit will be set to 0 by Host Controller. So software should set it to 1 before detecting next interrupt. |
| 7:0        | RW          | 0x00               | rdyint_gen_maxval<br>Max counter value to detect cdata_in0 high value for generating rdyint, based on internal clock frequency.                                                                                                                                                                   |

### **SDMMC CLKGEN CON0**

Address: Operational Base (0xFF480000) + 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:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                       |
| 11         | RW          | 0x0                | drv_sel<br>Selection for drive clock.<br>1'b0: Select clock delayed by phase shift<br>1'b1: Select clock delayed by phase shift and delay line<br>It can be modified when init_state=1 and should be stable when init_state=0. |
| 10         | RO          | 0x0                | reserved                                                                                                                                                                                                                       |
| 9:3        | RW          | 0x00               | drv_delaynum<br>Delay element number configuration for drive clock.<br>It can be modified when init_state=1 and should be stable when init_state=0.                                                                            |
| 2:1        | RW          | 0x2                | drv_degree<br>Phase selection for drive clock.<br>2'h0: 0-degree<br>2'h1: 90-degree<br>2'h2: 180-degree<br>2'h3: 270-degree<br>It can be modified when init_state=1 and should be stable when init_state=0.                    |
| 0          | RW          | 0x0                | init_state<br>Enable initialization for clock source.<br>1'b0: Disable<br>1'b1: Enable<br>When init_state=1, the host clocks including drive clock and sample clock are inactive.                                              |

### **SDMMC CLKGEN CON1**

Address: Operational Base (0xFF480000) + 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:12      | RO          | 0x0                | reserved                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11         | RW          | 0x0                | sample_sel<br>Selection for sample clock.<br>1'b0: Select clock delayed by phase shift<br>1'b1: Select clock delayed by phase shift and delay line<br>It can be modified when init_state=1 and should be stable when init_state=0. |
| 10         | RO          | 0x0                | reserved                                                                                                                                                                                                                           |
| 9:3        | RW          | 0x00               | sample_delaynum<br>Delay element number configuration for sample clock.<br>It can be modified when init_state=1 and should be stable when init_state=0.                                                                            |
| 2:1        | RW          | 0x0                | sample_degree<br>Phase selection for sample clock.<br>2'h0: 0-degree<br>2'h1: 90-degree<br>2'h2: 180-degree<br>2'h3: 270-degree<br>It can be modified when init_state=1 and should be stable when init_state=0.                    |
| 0          | RO          | 0x0                | reserved                                                                                                                                                                                                                           |

### **SDMMC\_MISC\_CON**

Address: Operational Base (0xFF480000) + offset (0x0138)

| <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                | mem_clkgat_enable<br>Memory clock gate enable.<br>1'b0: Disable<br>1'b1: Enable. Memory clock is gated automatically when memory is idle. |
| 4:0        | RO          | 0x0                | reserved                                                                                                                                  |

### **SDMMC\_FIFO\_BASE**

Address: Operational Base (0xFF480000) + 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 |

## **39.5 Interface Description**

### **39.5.1 SDMMC Interface Description**

Table 39-8 SDMMC 1bit mode Interface Description

| <b>Module Pin</b> | <b>Dir.</b> | <b>PAD Name</b> | <b>IOMUX Setting</b>                    |
|-------------------|-------------|-----------------|-----------------------------------------|
| sdmmc_cclk        | O           | GPIO3_A0        | GPIO3_IOC_GPIO3A_IOMUX_SEL_0[3:0]=4'h1  |
| sdmmc_ccmd        | I/O         | GPIO3_A1        | GPIO3_IOC_GPIO3A_IOMUX_SEL_0[7:4]=4'h1  |
| sdmmc_cdata0      | I/O         | GPIO3_A2        | GPIO3_IOC_GPIO3A_IOMUX_SEL_0[11:8]=4'h1 |

Notes: I=input, O=output, I/O=input/output, bidirectional

Table 39-9 SDMMC 4 bits mode Interface Description

| <b>Module Pin</b> | <b>Dir.</b> | <b>PAD Name</b> | <b>IOMUX Setting</b>                   |
|-------------------|-------------|-----------------|----------------------------------------|
| sdmmc_cclk        | O           | GPIO3_A0        | GPIO3_IOC_GPIO3A_IOMUX_SEL_0[3:0]=4'h1 |

| Module Pin   | Dir. | PAD Name | IOMUX Setting                            |
|--------------|------|----------|------------------------------------------|
| sdmmc_ccmd   | I/O  | GPIO3_A1 | GPIO3_IOC_GPIO3A_IOMUX_SEL_0[7:4]=4'h1   |
| sdmmc_cdata0 | I/O  | GPIO3_A2 | GPIO3_IOC_GPIO3A_IOMUX_SEL_0[11:8]=4'h1  |
| sdmmc_cdata1 | I/O  | GPIO3_A3 | GPIO3_IOC_GPIO3A_IOMUX_SEL_0[15:12]=4'h1 |
| sdmmc_cdata2 | I/O  | GPIO3_A4 | GPIO3_IOC_GPIO3A_IOMUX_SEL_1[3:0]=4'h1   |
| sdmmc_cdata3 | I/O  | GPIO3_A5 | GPIO3_IOC_GPIO3A_IOMUX_SEL_1[7:4]=4'h1   |

Notes: I=input, O=output, I/O=input/output, bidirectional

## 39.6 Application Notes

### 39.6.1 Software/Hardware Restriction

Before issuing a new data transfer command, the software should ensure that the card is not busy due to any previous data transfer command. Before changing the card clock frequency, the software must ensure that there are no data or command transfers in progress.

To avoid glitches in the card clock outputs, the software should use the following steps when changing the card clock frequency:

- 1) Before disable the clocks, ensure that the card is not busy due to any previous data command. To determine this, check for 0 in bit9 of SDMMC\_STATUS register.
- 2) Update the Clock Enable register to disable clock. To ensure completion of any previous command before this update, send a command to the CIU to update the clock registers by setting:
  - start\_cmd bit
  - "update clock registers only" bits
  - "wait\_previous data complete" bit
 Wait for the CIU to take the command by polling for 0 on the start\_cmd bit.
- 3) Set the start\_cmd bit to update the Clock Divider and/or Clock Source register, and send a command to the CIU in order to update the clock registers; wait for the CIU to take the command.
- 4) Set start\_cmd to update the Clock Enable register in order to enable the required clocks and send a command to the CIU to update the clock registers; wait for the CIU to take the command.

In non-DMA mode, while reading from a card, the Data Transfer Over (SDMMC\_RINTSTS[3]) interrupt occurs as soon as the data transfer from the card is over. There still could be some data left in the FIFO, and the RX\_WMark interrupt may or may not occur, depending on the remaining bytes in the FIFO. Software should read any remaining bytes upon seeing the Data Transfer Over (DTO) interrupt. While using the external DMA interface for reading from a card, the DTO interrupt occurs only after all the data is flushed to memory by the DMA interface unit.

While writing to a card in external DMA mode, if an undefined-length transfer is selected by setting the Byte Count Register to 0, the DMA logic will likely request more data than it will send to the card, since it has no way of knowing at which point the software will stop the transfer. The DMA request stops as soon as the DTO is set by the CIU.

If the software issues a controller\_reset command by setting control register bit[0] to 1, all the CIU state machines are reset; the FIFO is not cleared. The DMA sends all remaining bytes to the host. In addition to a card-reset, if a FIFO reset is also issued, then:

- Any pending DMA transfer on the bus completes correctly
- DMA data read is ignored
- Write data is unknown(x)

Additionally, if dma\_reset is also issued, any pending DMA transfer is abruptly terminated. When the DMA is used, the DMA controller channel should also be reset and reprogrammed.

If any of the previous data commands do not properly terminate, then the software should issue the FIFO reset in order to remove any residual data, if any, in the FIFO. After asserting the FIFO reset, you should wait until this bit is cleared.

One data-transfer requirement between the FIFO and host is that the number of transfers should be a multiple of the FIFO data width (32bits). For example, you want to write only

15 bytes to an SD/MMC card (SDMMC\_BYTCNT), the host should write 16 bytes to the FIFO or program the DMA to do 16-byte transfers. The software can still program the Byte Count register to only 15, at which point only 15 bytes will be transferred to the card. Similarly, when 15 bytes are read from a card, the host should still read all 16 bytes from the FIFO. It is recommended that you not change the FIFO threshold register in the middle of data transfers.

## 39.6.2 Programming Sequence

### 39.6.2.1 Initialization

Following figure illustrates the initialization flow.



Fig. 39-9 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:0x0fffff) in host clock cycle units in the SDMMC\_DEBNCE register.

FIFO threshold value in bytes in the SDMMC\_FIFOTH register.

### 39.6.2.2 Enumerated Card Stack

The card stack does the following:

- Enumerates all connected cards
- Sets the RCA for the connected cards

- Reads card-specific information
- Stores card-specific information locally

Enumeration depends on the operating mode of the SD/MMC card; the card type is first identified and the appropriate card enumeration routine is called.

- 1) Check if the card is connected.
- 2) Clear the card type register to set the card width as a single bit. For the given card number, clear the corresponding bits in the card\_type register. Clear the register bit for a 1-bit, 4-bit bus width. For example, for card number=1, clear bit 0 and bit 16 of the card\_type register.
- 3) Set clock frequency to FOD=400KHz, maximum – Program clock divider0 (bits 0-7 in the SDMMC\_CLKDIV register) value to one-half of the cclk\_in frequency divided by 400KHz. For example, if cclk\_in is 20MHz, then the value is  $20,000/(2*400)=25$ .
- 4) Identify the card type; that is, SD, MMC, or SDIO.
  - a. Send CMD5 first. If a response is received, then the card is SDIO
  - b. If not, send CMD8 with the following Argument  
Bit[31:12] = 20'h0 //reserved bits  
Bit[11:8] = 4'b0001 //VHS value  
Bit[7:0] = 8'b10101010 //Preferred Check Pattern by SD2.0
  - c. If Response is received the card supports High Capacity SD2.0 then send ACMD41 with the following Argument  
Bit[31] = 1'b0; //Reserved bits  
Bit[30] = 1'b1; //High Capacity Status  
Bit[29:24] = 6'h0; //Reserved bits  
Bit[23:0] = Supported Voltage Range
  - d. If Response is received for ACMD41 then the card is SD. Otherwise the card is MMC.
  - e. If response is not received for initial CMD8 then card does not support High Capacity SD2.0, then issue CMD0 followed by ACMD41 with the following Argument  
Bit[31] = 1'b0; //Reserved bits  
Bit[30] = 1'b0; //High Capacity Status  
Bit[29:24] = 6'h0; //Reserved bits  
Bit[23:0] = Supported Voltage Range
- 5) Enumerate the card according to the card type.
- 6) Use a clock source with a frequency = Fod (that is, 400KHz) and use the following enumeration command sequence:
  - SD card – Send CMD0, CMD8, ACMD41, CMD2, CMD3.
  - MMC – Send CMD0, CMD1, CMD2, CMD3.

### **39.6.2.3 Clock Programming**

The Host Controller supports one clock source. The clock to an individual card can be enabled or disabled. Registers that support this are:

- SDMMC\_CLKDIV – Programs individual clock source frequency. SDMMC\_CLKDIV limited to 0 or 1 is recommended.
- SDMMC\_CLKSRC – Assign clock source for each card.
- SDMMC\_CLKENA – Enables or disables clock for individual card and enables low-power mode, which automatically stops the clock to a card when the card is idle for more than 8 clocks.

The Host Controller loads each of these registers only when the start\_cmd bit and the update\_clk\_regs\_only bit in the SDMMC\_CMD register are set. When a command is successfully loaded, the Host Controller clears this bit, unless the Host Controller already has another command in the queue, at which point it gives an HLE(Hardware Locked Error). Software should look for the start\_cmd and the update\_clk\_regs\_only bits, and should also set the wait\_prvdata\_complete bit to ensure that clock parameters do not change during data transfer. Note that even though start\_cmd is set for updating clock registers, the Host Controller does not raise a command\_done signal upon command completion.

The following shows how to program these registers:

- 1) Confirm that no card is engaged in any transaction; if there is a transaction, wait until it finishes.
- 2) Stop all clocks by writing 0 to the SDMMC\_CLKENA register. Set the start\_cmd,

- Update\_clk\_regs\_only, and wait\_prvdata\_complete bits in the SDMMC\_CMD register. Wait until start\_cmd is cleared or an HLE is set; in case of an HLE, repeat the command.
- 3) Program the SDMMC\_CLKDIV and SDMMC\_CLKSRC registers, as required. Set the start\_cmd, Update\_clk\_regs\_only, and wait\_prvdata\_complete bits in the SDMMC\_CMD register. Wait until start\_cmd is cleared or an HLE is set; in case of an HLE, repeat the command.

Re-enable all clocks by programming the SDMMC\_CLKENA register. Set the start\_cmd, update\_clk\_regs\_only, and wait\_prvdata\_complete bits in the SDMMC\_CMD register. Wait until start\_cmd is cleared or an HLE is set; in case of an HLE, repeat the command.

### 39.6.2.4 No-Data Command With or Without Response Sequence

To send any non-data command, the software needs to program the SDMMC\_CMD register @0x2C and the SDMMC\_CMDARG register @0x28 with appropriate parameters. Using these two registers, the Host Controller forms the command and sends it to the command bus. The Host Controller reflects the errors in the command response through the error bits of the SDMMC\_RINTSTS register.

When a response is received – either erroneous or valid – the Host Controller sets the command\_done bit in the SDMMC\_RINTSTS register. A short response is copied in Response Register0, while along response is copied to all four response registers @0x30, 0x34, 0x38, and 0x3C. The Response3 register bit 31 represents the MSB, and the Response0 register bit 0 represents the LSB of a long response.

For basic commands or non-data commands, follow these steps:

- 1) Program the Command register @0x28 with the appropriate command argument parameter.
- 2) Program the Command register @0x2C with the settings in following table.

Table 39-10 Command Settings for No-Data Command

| Parameter              | Value         | Description                                                                              |
|------------------------|---------------|------------------------------------------------------------------------------------------|
| <b>Default</b>         |               |                                                                                          |
| start_cmd              | 1             | -                                                                                        |
| use_hold_reg           | 1             | Choose value based on speed mode being used; ref to "use_hold_reg" on SDMMC_CMD register |
| update_clk_regs_only   | 0             | No clock parameters update command                                                       |
| data_expected          | 0             | No data command                                                                          |
| card number            | 0             | Actual card number(one controller only connect one card, the num is No. 0)               |
| cmd_index              | command-index | -                                                                                        |
| send_initialization    | 0             | Can be 1, but only for card reset commands, such as CMD0                                 |
| stop_abort_cmd         | 0             | Can be 1 for commands to stop data transfer, such as CMD12                               |
| response_length        | 0             | Can be 1 for R2(long) response                                                           |
| response_expect        | 1             | Can be 0 for commands with no response; for example, CMD0, CMD4, CMD15, and so on        |
| <b>User-selectable</b> |               |                                                                                          |
| wait_prvdata_complete  | 1             | Before sending command on command line, host should wait for completion of any           |

| Parameter          | Value | Description                                                                                                                                                            |
|--------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    |       | 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.

### 39.6.2.5 Data Transfer Commands

Data transfer commands transfer data between the memory card and the Host Controller. To send a data command, the Host Controller needs a command argument, total data size, and block size. Software can receive or send data through the FIFO.

Before a data transfer command, software should confirm that the card is not busy and is in a transfer state, which can be done using the CMD13 and CMD7 commands, respectively. For the data transfer commands, it is important that the same bus width that is programmed in the card should be set in the card type register @0x18.

The Host Controller generates an interrupt for different conditions during data transfer, which are reflected in the SDMMC\_RINTSTS register @0x44 as:

- 1) Data\_Transfer\_Over (bit 3) – When data transfer is over or terminated. If there is a response timeout error, then the Host Controller does not attempt any data transfer and the “Data Transfer Over” bit is never set.
- 2) Transmit\_FIFO\_Data\_request (bit 4) – FIFO threshold for transmitting data was reached; software is expected to write data, if available, in FIFO.
- 3) Receive\_FIFO\_Data\_request (bit 5) – FIFO threshold for receiving data was reached; software is expected to read data from FIFO.
- 4) Data starvation by Host timeout (bit 10) – FIFO is empty during transmission or is full during reception. Unless software writes data for empty condition or reads data for full condition, the Host Controller cannot continue with data transfer. The clock to the card has been stopped.
- 5) Data read timeout error (bit 9) – Card has not sent data within the timeout period.
- 6) Data CRC error (bit 7) – CRC error occurred during data reception.
- 7) Start bit error (bit 13) – Start bit was not received during data reception.
- 8) End bit error (bit 15) – End bit was not received during data reception or for a write operation; a CRC error is indicated by the card.

Conditions 6), 7), and 8) indicate that the received data may have errors. If there was a response timeout, then no data transfer occurred.

### 39.6.2.6 Single-Block or Multiple-Block Read

Steps involved in a single-block or multiple-block read are:

- 1) Write the data size in bytes in the SDMMC\_BYTCNT register @0x20.
- 2) Write the block size in bytes in the SDMMC\_BLKSIZ register @0x1C. The Host Controller expects data from the card in blocks of size SDMMC\_BLKSIZ each.
- 3) Program the SDMMC\_CMDARG register @0x28 with the data address of the beginning of a data read.
- 4) Program the Command register with the parameters listed in following table. For SD and MMC cards, use CMD17 for a single-block read and CMD18 for a multiple-block read. For SDIO cards, use CMD53 for both single-block and multiple-block transfers.

Table 39-11 Command Setting for Single or Multiple-Block Read

| Parameter              | Value         | Description                                                                                      |
|------------------------|---------------|--------------------------------------------------------------------------------------------------|
| <b>Default</b>         |               |                                                                                                  |
| start_cmd              | 1             | -                                                                                                |
| use_hold_reg           | 1             | Choose value based on speed mode being used; ref to "use_hold_reg" on SDMMC_CMD register         |
| update_clk_regs_only   | 0             | No clock parameters update command                                                               |
| card number            | 0             | Actual card number(one controller only connect one card, the num is No.0)                        |
| send_initialization    | 0             | Can be 1, but only for card reset commands, such as CMD0                                         |
| stop_abort_cmd         | 0             | Can be 1 for commands to stop data transfer, such as CMD12                                       |
| send_auto_stop         | 0/1           | -                                                                                                |
| transfer_mode          | 0             | Block transfer                                                                                   |
| read_write             | 0             | Read from card                                                                                   |
| data_expected          | 1             | Data command                                                                                     |
| response_length        | 0             | Can be 1 for R2(long) response                                                                   |
| response_expect        | 1             | Can be 0 for commands with no response; for example, CMD0, CMD4, CMD15, and so on                |
| <b>User-selectable</b> |               |                                                                                                  |
| cmd_index              | command-index | -                                                                                                |
| wait_prvdata_complete  | 1             | 0: Sends command immediately<br>1: Sends command after previous data transfer ends               |
| check_response_crc     | 1             | 0: Host Controller should not check response CRC<br>1: Host Controller should check response CRC |

After writing to the SDMMC\_CMD register, the Host Controller starts executing the command; when the command is sent to the bus, the command\_done interrupt is generated.

- Software should look for data error interrupts; that is, bits 7, 9, 13, and 15 of the SDMMC\_RINTSTS register. If required, software can terminate the data transfer by sending a STOP command.
- Software should look for Receive\_FIFO\_Data\_request and/or data starvation by host

timeout conditions. In both cases, the software should read data from the FIFO and make space in the FIFO for receiving more data.

When a Data\_Transfer\_Over interrupt is received, the software should read the remaining data from the FIFO.

### 39.6.2.7 Single-Block or Multiple-Block Write

Steps involved in a single-block or multiple-block write are:

- 1) Write the data size in bytes in the SDMMC\_BYTCNT register @0x20.
- 2) Write the block size in bytes in the SDMMC\_BLKSIZ register @0x1C; the Host Controller sends data in blocks of size SDMMC\_BLKSIZ each.
- 3) Program SDMMC\_CMDARG register @0x28 with the data address to which data should be written.
- 4) Write data in the FIFO; it is usually best to start filling data the full depth of the FIFO.
- 5) Program the Command register with the parameters listed in following table.

Table 39-12 Command Settings for Single or Multiple-Block Write

| Parameter              | Value         | Description                                                                                      |
|------------------------|---------------|--------------------------------------------------------------------------------------------------|
| <b>Default</b>         |               |                                                                                                  |
| start_cmd              | 1             | -                                                                                                |
| use_hold_reg           | 1             | Choose value based on speed mode being used; ref to "use_hold_reg" on SDMMC_CMD register         |
| update_clk_regs_only   | 0             | No clock parameters update command                                                               |
| card number            | 0             | Actual card number(one controller only connect one card, the num is No. 0)                       |
| send_initialization    | 0             | Can be 1, but only for card reset commands, such as CMD0                                         |
| stop_abort_cmd         | 0             | Can be 1 for commands to stop data transfer, such as CMD12                                       |
| send_auto_stop         | 0/1           | -                                                                                                |
| transfer_mode          | 0             | Block transfer                                                                                   |
| read_write             | 1             | Write to card                                                                                    |
| data_expected          | 1             | Data command                                                                                     |
| response_length        | 0             | Can be 1 for R2(long) response                                                                   |
| response_expect        | 1             | Can be 0 for commands with no response; for example, CMD0, CMD4, CMD15, and so on                |
| <b>User-selectable</b> |               |                                                                                                  |
| cmd_index              | command-index | -                                                                                                |
| wait_prvdata_complete  | 1             | 0: Sends command immediately<br>1: Sends command after previous data transfer ends               |
| check_response_crc     | 1             | 0: Host Controller should not check response CRC<br>1: Host Controller should check response CRC |

After writing to the SDMMC\_CMD register, Host Controller starts executing a command; when the command is sent to the bus, a command\_done interrupt is generated.

- Software should look for data error interrupts; that is, for bits 7, 9, and 15 of the SDMMC\_RINTSTS register. If required, software can terminate the data transfer by

- sending the STOP command.
- Software should look for Transmit\_FIFO\_Data\_Request and/or timeout conditions from data starvation by the host. In both cases, the software should write data into the FIFO.

When a Data\_Transfer\_Over interrupt is received, the data command is over. For an open-ended block transfer, if the byte count is 0, the software must send the STOP command. If the byte count is not 0, then upon completion of a transfer of a given number of bytes, the Host Controller should send the STOP command, if necessary. Completion of the AUTO-STOP command is reflected by the Auto\_Command\_done interrupt – bit 14 of the SDMMC\_RINTSTS register. A response to AUTO\_STOP is stored in SDMMC\_RESP1 @0x34.

### **39.6.2.8 Sending Stop or Abort in Middle of Transfer**

The STOP command can terminate a data transfer between a memory card and the Controller, while the ABORT command can terminate an I/O data transfer for only the SDIO\_IOONLY and SDIO\_COMBO cards.

- Send STOP command – Can be sent on the command line while a data transfer is in progress; this command can be sent at any time during a data transfer.

You can also use an additional setting for this command in order to set the Command register bits (5-0) to CMD12 and set bit 14 (stop\_abort\_cmd) to 1. If stop\_abort\_cmd is not set to 1, the Controller does not know that the user stopped a data transfer. Reset bit 13 of the Command register (wait\_prvdata\_complete) to 0 in order to make the Controller send the command at once, even though there is a data transfer in progress.

Send ABORT command – Can be used with only an SDIO\_IOONLY or SDIO\_COMBO card. To abort the function that is transferring data, program the function number in ASx bits (CCCR register of card, address 0x06, bits (0-2) using CMD52.

### **39.6.2.9 Read\_Wait Sequence**

Read\_wait is used with only the SDIO card and can temporarily stall the data transfer—either from function or memory—and allow the host to send commands to any function within the SDIO device. The host can stall this transfer for as long as required. The Host Controller provides the facility to signal this stall transfer to the card. The steps for doing this are:

- 1) Check if the card supports the read\_wait facility; read SRW (bit 2) of the CCCR register @0x08. If this bit is 1, then all functions in the card support the read\_wait facility. Use CMD52 to read this bit.
- 2) If the card supports the read\_wait signal, then assert it by setting the read\_wait (bit 6) in the SDMMC\_CTRL register @0x00.

Clear the read\_wait bit in the SDMMC\_CTRL register.

### **39.6.2.10 Controller/DMA/FIFO Reset Usage**

- Controller reset – Resets the controller by setting the controller\_reset bit (bit 0) in the SDMMC\_CTRL register; this resets the CIU and state machines, and also resets the BIU-to-CIU interface. Since this reset bit is self-clearing, after issuing the reset, wait until this bit is cleared.
- FIFO reset - Resets the FIFO by setting the fifo\_reset bit (bit 1) in the SDMMC\_CTRL register; this resets the FIFO pointers and counters of the FIFO. Since this reset bit is self-clearing, after issuing the reset, wait until this bit is cleared.

In external DMA transfer mode, even when the FIFO pointers are reset, if there is a DMA transfer in progress, it could push or pop data to or from the FIFO; the DMA itself completes correctly. In order to clear the FIFO, the software should issue an additional FIFO reset and clear any FIFO under-run or overrun errors in the SDMMC\_RAWINTS register caused by the DMA transfers after the FIFO was reset.

### **39.6.2.11 Card Read Threshold**

When an application needs to perform a Single or Multiple Block Read command, the application must program the SDMMC\_CARDTHRCTL register with the appropriate Card Read Threshold size (CardRdThreshold) and set the Card Read Threshold Enable

(CardRdThrEnable) bit to 1'b1. This additional programming ensures that the Host controller sends a Read Command only if there is space equal to the Card Read Threshold available in the Rx FIFO. This in turn ensures that the card clock is not stopped in the middle 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.

### **39.6.2.12 Error Handling**

The Host Controller implements error checking; errors are reflected in the SDMMC\_RAWINTS register@0x44 and can be communicated to the software through an interrupt, or the software can poll for these bits. Upon power-on, interrupts are disabled (int\_enable in the SDMMC\_CTRL register is 0), and all the interrupts are masked (bits 0-31 of the SDMMC\_INTMASK register; default is 0).

Error handling:

- Response and data timeout errors – For response timeout, software can retry the command. For data timeout, the Host Controller has not received the data start bit – either for the first block or the intermediate block – within the timeout period, so software can either retry the whole data transfer again or retry from a specified block onwards. By reading the contents of the SDMMC\_TCBCNT later, the software can decide how many bytes remain to be copied.
- Response errors – Set when an error is received during response reception. In this case, the response that copied in the response registers is invalid. Software can retry the command.
- Data errors – Set when error in data reception are observed; for example, data CRC, start bit not found, end bit not found, and so on. These errors could be set for any block-first block, intermediate block, or last block. On receipt of an error, the software can issue a STOP or ABORT command and retry the command for either whole data or partial data.
- Hardware locked error – Set when the Host Controller cannot load a command issued by software. When software sets the start\_cmd bit in the SDMMC\_CMD register, the Host Controller tries to load the command. If the command buffer is already filled with a command, this error is raised. The software then has to reload the command.
- FIFO under-run/overrun error – If the FIFO is full and software tries to write data in the FIFO, then an overrun error is set. Conversely, if the FIFO is empty and the software tries to read data from the FIFO, an under-run error is set. Before reading or writing data in the FIFO, the software should read the fifo\_empty or fifo\_full bits in the Status register.
- Data starvation by host timeout – Raised when the Host Controller is waiting for software intervention to transfer the data to or from the FIFO, but the software does not transfer within the stipulated timeout period. Under this condition and when a read transfer is in process, the software should read data from the FIFO and create space for further data reception. When a transmit operation is in process, the software should fill data in the FIFO in order to start transferring data to the card.
- CRC Error on Command – If a CRC error is detected for a command, the CE-ATA device does not send a response, and a response timeout is expected from the Host Controller. The ATA layer is notified that an MMC transport layer error occurred.

*Notes: During a multiple-block data transfer, if a negative CRC status is received from the device, the data path signals a data CRC error to the BIU by setting the data CRC error bit in the SDMMC\_RINTSTS register. It then continues further data transmission until all the bytes are transmitted.*

### **39.6.2.13 Voltage Switching**

The Host Controller supports SD 3.0 Ultra High Speed (UHS-1) and is capable of voltage switching in SD-mode, which can be applied to SD High-Capacity (SDHC) and SD Extended Capacity (SDXC) cards. UHS-1 supports only 4-bit mode.

However, whether the IO voltage of 1.8v supported or not is depended on the SoC design. SD 3.0 UHS-1 supports the following transfer speed modes for UHS-50 and/or UHS-104 cards:

- DS – default-speed up to 25MHz, 3.3V signaling
- HS – high-speed up to 50MHz, 3.3V signaling
- SDR12 – SDR up to SDR 25MHz, 1.8V signaling
- SDR25 – SDR up to 50MHz, 1.8V signaling
- SDR50 – SDR up to 100MHz, 1.8V signaling
- DDR50 – DDR up to 50MHz, 1.8V signaling

Voltage selection can be done in only SD mode. The first CMD0 selects the bus mode-either SD mode or SPI mode. The card must be in SD mode in order for 1.8V signaling mode to apply, during which time the card cannot be switched to SPI mode or 3.3V signaling without a power cycle.

If the System BIOS in an embedded system already knows that it is connected to an SD 3.0 card, then the driver programs the Controller to initiate ACMD41. The software knows from the response of ACMD41 whether or not the card supports voltage switching to 1.8V.

- If bit 32 of ACMD41 response is 1'b1: card supports voltage switching and next command-CMD11-invokes voltage switching sequence. After CMD11 is started, the software must program the IO voltage selection register based on the soc architecture.
- If bit 32 of ACMD41 response is 1'b0: card does not support voltage switching and CMD11 should not be started.

If the card and host controller accept voltage switching, then they support UHS-1 modes of data transfer. After the voltage switch to 1.8V, SDR12 is the default speed.

Since the UHS-1 can be used in only 4-bit mode, the software must start ACMD6 and change the card data width to 4-bit mode; ACMD6 is driven in any of the UHS-1 speeds. If the host wants to select the DDR mode of data transfer, then the software must program the SDMMC\_DDR\_REG register in the CSR space with the appropriate card number.

To choose from any of the SDR or DDR modes, appropriate values should be programmed in the SDMMC\_CLKDIV register.

### 39.6.2.14 Voltage Switch Operation

The Voltage Switch operation must be performed in SD mode only.



Fig. 39-10 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. 39-11 ACMD41 Argument

- Bit 30 informs the card if host supports SDHC/SDXC or not; this bit should be set to 1'b1.
- Bit 28 can be either 1 or 0.
- Bit 24 should be set to 1'b1, indicating that the host is capable of voltage switching; refer to following figure.



Fig. 39-12 ACMD41 Response(R3)

- Bit 30 – If set to 1'b1, card supports SDHC/SDXC; if set to 1'b0, card supports only SDSC
  - Bit 24 – If set to 1'b1, card supports voltage switching and is ready for the switch
  - Bit 31 – If set to 1'b1, initialization is over; if set to 1'b0, means initialization in process
- If the card supports voltage switching, then the software must perform the steps discussed for either the “Voltage Switch Normal Scenario” or the “Voltage Switch Error Scenario”.

### 39.6.2.15 Voltage Switch Normal Scenario



Fig. 39-13 Voltage Switch Normal Scenario

- 1) 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 2ms 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 100KHz; that is, 10us  
Total time = 160 \* 10us = 1600us = 1. 6ms ~ 2ms
- 2) 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".
- 3) The card returns R1 response; the host controller does not generate cmd\_done interrupt on receiving R1 response.
- 4) 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.

### 39.6.2.16 Voltage Switch Error Scenario



Fig. 39-14 Voltage Switch Error Scenario

- 1) If the interrupt (VOLT\_SWITCH\_INT) does not come, then the 2ms 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.

### 39.6.3 DDR Operation

#### 39.6.3.1 4-bit DDR Programming Sequence

DDR programming should be done only after the voltage switch operation has completed. The following outlines the steps for the DDR programming sequence:

- 1) Once the voltage switch operation is complete, the user must program voltage selection register to the required values for the corresponding card.
- To start a card to work in DDR mode, the application must program a bit of the newly defined SDMMC\_UHSREG[16] register with a value of 1'b1.
- The bit that the user programs depends on which card is to be accessed in DDR mode. To move back to SDR mode, a power cycle should be run on the card—putting the card in SDR12 mode—and only then should SDMMC\_UHSREG[16] be set back to 1'b0 for the appropriate card.

### **39.6.3.2 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.*

### **39.6.3.3 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.*

### **39.6.4 H/W Reset Operation**

When the RST\_n signal goes low, the card enters a pre-idle state from any state other than the inactive state.

The following outlines the steps for the H/W reset programming sequence:

- 1) Program CMD12 to end any transfer in process.
- 2) Wait for DTO, even if no response is sent back by the card.
- 3) Set the following resets:
  - DMA reset—SDMMC\_CTRL [2] bit
  - FIFO reset—SDMMC\_CTRL [1] bit

*Note: The above steps are required only if a transfer is in process.*

- 4) Program the SDMMC\_RSTN register with a value of 0; this can be done at any time when the card is connected to the controller. This programming asserts the RST\_n signal and resets the card.
- 5) Wait for minimum of 1  $\mu$ s or cclk\_in period, whichever is greater
- 6) After a minimum of 1  $\mu$ s, the application should program a value of 0 into the SDMMC\_RSTN register. This de-asserts the RST\_n signal and takes the card out of reset.
- 7) The application can program a new CMD only after a minimum of 200 $\mu$ s after the de-assertion of the RST\_n signal, as per the MMC 4.41 standard.

*Note: For backward compatibility, the RST\_n signal is temporarily disabled in the card by default. The host may need to set the signal as either permanently enabled or permanently disabled before it uses the card.*

### **39.6.5 FBE Scenarios**

An FBE occurs due to an AHB error response on the AHB bus. This is a system error, so the software driver should not perform any further programming to the Host. The only recovery mechanism from such scenarios is to do one of the following:

- Issue a hard reset by asserting the reset\_n signal
- Do a program controller reset by writing to the SDMMC\_CTRL[0] bit

### 39.6.5.1 FIFO Overflow and Underflow

During normal data transfer conditions, FIFO overflow and underflow will not occur. However if there is a programming error, then FIFO overflow/underflow can result. For example, consider the following scenarios.

- For transmit: PBL=4, Tx watermark = 1. For the above programming values, if the FIFO has only one location empty, it issues a dma\_req to IDMAC FSM. Due to PBL value=4, the IDMAC FSM performs 4 pushes into the FIFO. This will result in a FIFO overflow interrupt.
- For receive: PBL=4, Rx watermark = 1. For the above programming values, if the FIFO has only one location filled, it issues a dma\_req to IDMAC FSM. Due to PBL value=4, the IDMAC FSM performs 4 pops to the FIFO. This will result in a FIFO underflow interrupt.

The driver should ensure that the number of bytes to be transferred as indicated in the descriptor should be a multiple of 4bytes with respect to H\_DATA\_WIDTH=32. For example, if the SDMMC\_BYTCNT=13, the number of bytes indicated in the descriptor should be 16 for H\_DATA\_WIDTH=32.

### 39.6.5.2 Programming of PBL and Watermark Levels

The DMAC performs data transfers depending on the programmed PBL and threshold values.

Table 39-13 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 |

### 39.6.6 Variable Delay Usage

The control signals for variable delay element usage are described in SDMMC\_CLKGEN\_CON0 and SDMMC\_CLKGEN\_CON1.

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.

### 39.6.7 Variable Delay Tuning

Tuning is defined by SD and MMC cards to determine the correct sampling point required for the host, especially for the speed modes SDR104 and HS200 where the output delays from the cards can be up to 2 UI. Tuning is required for other speed modes-such as DDR50-even though the output delay from the card is less than one cycle.

Command for tuning is different for different cards.

- SD Memory Card:
  - CMD19 – SD card for SDR50 and SDR104 speed modes. Tuning data is defined by card specifications.
  - CMD6 – SD card for speed modes not supporting CMD19. Tuning data is the 64byte SD status.
- Multimedia Card:
  - CMD21 – MMC card for HS200 speed mode. Tuning data is defined by card specifications.
  - CMD8 – MMC card for speed modes not supporting CMD21. Tuning data is 512 byte ExtCSD data.

The following is the procedure for variable delay tuning:

- 1) Set a phase shift of 0-degree on cclk\_in\_sample.
  - 2) Send the Tuning command to the card; the card in turn sends an R1 response on the CMD line and tuning data on the DAT line.
  - 3) If the host sees any of the errors—start bit error, data CRC error, end bit error, data read time-out, response CRC error, response error—then the sampling point is incorrect.
  - 4) Send CMD12 to bring the host controller state machines to idle.
    - The card may treat CMD12 as an invalid command because the card has successfully sent the tuning data, and it cannot send a response.
    - The host controller may generate a response time-out interrupt that must be cleared by software.
  - 5) Repeat steps 2) to 4) by increasing the phase shift value or delay element number on cclk\_in\_sample until the correct sampling point is received such that the host does not see any of the errors.
  - 6) Mark this phase shift value as the starting point of the sampling window.
  - 7) Repeat steps 2 to 4 by increasing the phase shift value or delay element number on cclk\_in\_sample until the host sees the errors starting to come again or the phase shift value reaches 360-degree.
  - 8) Mark the last successful phase shift value as the ending point of the sampling window.
- A window is established where the tuning block is matched. For example, for a scenario where the tuning block is received correctly for a phase shift window of 90-degree and 180-degree, then an appropriate sampling point is established as 135-degree. Once a sampling point is established, no errors should be visible in the tuning block.