# RK30xx Technical Reference Manual

Revision 1.0 Feb. 2012

## **Revision History**

| Date       | Revision | Description     |
|------------|----------|-----------------|
| 2012-02-29 | 1.0      | Initial Release |
|            |          |                 |
|            |          |                 |
|            |          |                 |



## **Table of Content**

| Table of Content                                                 |     |
|------------------------------------------------------------------|-----|
| Figure Index                                                     |     |
| Table Index                                                      |     |
| Acronym Descriptions                                             |     |
| Chapter 1 Introduction                                           |     |
| 1.1 Features                                                     | 25  |
| 1.1.1 MicroProcessor                                             | .25 |
| 1.1.2 Memory Organization                                        | .26 |
| 1.1.3 Internal Memory                                            |     |
| 1.1.4 External Memory or Storage device                          |     |
| 1.1.5 System Component                                           |     |
| 1.1.6 Video CODEC                                                | .30 |
| 1.1.7 JPEG CODEC                                                 | .31 |
| 1.1.8 Image Enhancement                                          | .31 |
| 1.1.9 Graphics Engine                                            | .33 |
| 1.1.10 Video IN/OUT                                              | .34 |
| 1.1.10 Video IN/OUT  1.1.11 Audio Interface  1.1.12 Connectivity | .33 |
| 1.1.13 Others                                                    | .30 |
| 1.2 Block Diagram                                                |     |
| 1.2 block Diagram                                                | 30  |
| 1.3 Pin Description                                              | 39  |
|                                                                  |     |
| 1.3.1 RK30xx power/ground IO descriptions                        | .39 |
| 1.3.3 IO pin name descriptions                                   |     |
| 1.3.4 RK30xx IO Type                                             |     |
| 1.4 Package information                                          |     |
|                                                                  |     |
| 1.4.1 Dimension                                                  |     |
| 1.4.2 Ball Map                                                   |     |
| 1.4.3 Ball Pin Number Order                                      |     |
| 1.5 Electrical Specification                                     | 75  |
| 1.5.1 Absolute Maximum Ratings                                   | .75 |
| 1.5.2 Recommended Operating Conditions                           | .76 |
| 1.5.3 DC Characteristics                                         |     |
| 1.5.4 Recommended Operating Frequency                            |     |
| 1.5.5 Electrical Characteristics for General IO                  |     |
| 1.5.6 Electrical Characteristics for PLL                         |     |
| 1.5.7 Electrical Characteristics for SAR-ADC                     |     |
| 1.5.8 Electrical Characteristics for TS-ADC                      |     |
| 1.5.9 Electrical Characteristics for USB OTG/Host2.0 Interface   |     |
| 1.5.10 Electrical Characteristics for HDMI                       |     |
| 1.5.11 Electrical Characteristics for DDR IO                     |     |
| 1.5.12 Electrical Characteristics for eFuse                      |     |
| 1.6 Hardware Guideline                                           | 84  |
| 1.6.1 Reference design for RK30xx oscillator PCB connection      | .84 |
| 1.6.2 Reference design for PLL PCB connection                    | .85 |
| 1.6.3 Reference design for USB OTG/Host2.0 connection            | .86 |
| 1.6.4 Reference design for HDMI Tx PHY connection                | .86 |
| 1.6.5 RK30xx Power up/down sequence requirement                  | .87 |

| 1.6.6 RK30xx Power on reset descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 89                                                                                   |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|
| 2.2 System Boot                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 91                                                                                   |
| 2.3 System Interrupt connection                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 92                                                                                   |
| 2.4 System DMA hardware request connection                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 94                                                                                   |
| Chapter 3 CRU (Clock & Reset Unit)                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                      |
| Chapter 4 PMU (Power Management Unit)                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 97                                                                                   |
| 4.1.1 Features                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 98                                                                                   |
| Chapter 6 System Debug                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 99                                                                                   |
| 6.1.1 Features                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 99                                                                                   |
| 6.3 Function description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                      |
| 6.3.1 DAP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | .101<br>.101<br>.101<br>.102                                                         |
| 6.4.1 DAP APB-AP register summary 6.4.2 DAP APB-AP Detailed Register Description 6.4.3 DAP AHB-AP register summary 6.4.4 DAP AHB-AP Detailed Register Description 6.4.5 DAP-ROM register summary 6.4.6 DAP-ROM Detailed Register Description 6.4.7 PTM register summary 6.4.8 PTM Detailed Register Description 6.4.9 Funnel register summary 6.4.10 Funnel register details 6.4.11 CTI register summary 6.4.12 CTI register details 6.4.13 TPIU register summary 6.4.14 TPIU detailed register description | .103<br>.105<br>.108<br>.108<br>.110<br>.111<br>.121<br>.121<br>.127<br>.128<br>.135 |
| 6.5 Interface description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                      |
| 6.5.2 TPIU trace port interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | .143                                                                                 |

| 7.2 Function Description                                    | 145               |
|-------------------------------------------------------------|-------------------|
| 7.3 Register description、                                   | 145               |
| Chapter 8 Embedded Processor: Cortex-A9                     |                   |
| 8.1 Overview                                                | 255               |
| 8.2 Block Diagram                                           | 256               |
| 8.3 Function description                                    | 256               |
| 8.4 Register description                                    | 256               |
| 8.4.1 Registers Summary                                     | 260<br>292        |
| 8.5.1 Address filtering                                     | 292<br>292<br>293 |
| Chapter 9 AXI interconnect                                  | 294<br>295        |
| Chapter 10 DMAC0(DMA Controller)                            | 296               |
| 10.1 Overview                                               |                   |
| 10.2 Block Diagram                                          | 296               |
| 10.3 Function Description                                   | 297               |
| 10.3.1 Introduction                                         | 298               |
| 10.4.1 Register summary                                     | 298<br>301        |
| 10.6 Interface Description                                  | 314               |
| 10.7 Application Notes                                      | 315               |
| 10.7.1 Using the APB slave interfaces 10.7.2 Security usage | 315<br>319        |
| 10.7.5 Interrupt snares between channel                     | 320               |
| 10.7.6 Instruction sets                                     |                   |
| 10.7.8 MFIFO usage                                          |                   |
| Chapter 11 DMAC1(DMA Controller)                            |                   |
|                                                             |                   |
| 11.2 Block Diagram                                          |                   |
| 11.3 Function Description                                   | 324               |
| 11.4 Register Description                                   | 324               |

|   |       | 11.4.1 Register summary                                                                                                            | 327 |
|---|-------|------------------------------------------------------------------------------------------------------------------------------------|-----|
|   | 11.5  | Timing Diagram                                                                                                                     | 340 |
|   | 11.6  | Interface Description                                                                                                              | 340 |
|   | 11.7  | Application Notes                                                                                                                  | 341 |
| C |       | r 12 GIC(General Interrupt Controller)                                                                                             |     |
|   | 12.1  | Overview                                                                                                                           | 342 |
|   | 12.2  | Block Diagram                                                                                                                      | 342 |
|   | 12.3  | Function Description                                                                                                               | 342 |
|   |       | 12.3.1 The Distributor                                                                                                             |     |
|   |       | 12.3.2 CPU interface                                                                                                               | 344 |
|   | 12.4  | 12.3.3 Interrupt handling state machine                                                                                            | 346 |
|   | 12.1  |                                                                                                                                    |     |
|   |       | 12.4.1 GIC Distributor interface register summary                                                                                  |     |
|   |       | 12.4.3 GIC CPU interface register summary                                                                                          |     |
|   |       | 12.4.4 GIC CPU interface detail register description                                                                               | 352 |
|   | 12.5  | Interface Description                                                                                                              | 355 |
|   | 12.6  | Application Notes                                                                                                                  | 355 |
|   |       | 12.6.1 General handling of interrupts                                                                                              |     |
|   |       | 12.6.2 Interrupt prioritization                                                                                                    |     |
|   |       | 12.6.3 The effect of the Security Extensions on interrupt handling. 12.6.4 The effect of Security Extensions on interrupt priority |     |
| C | hante | r 13 DMC (Dynamic Memory Interface)                                                                                                |     |
| _ |       | Overview                                                                                                                           |     |
|   |       | Block Diagram                                                                                                                      |     |
|   |       |                                                                                                                                    |     |
|   |       | Function description                                                                                                               |     |
|   | 13.4  | DDR PHY                                                                                                                            | 363 |
|   |       | 13.4.1 DDR PHY Overview                                                                                                            |     |
|   |       | 13.4.2 Lane-Based Architecture                                                                                                     |     |
|   |       | 13.4.3 Master DLL(MDLL)                                                                                                            |     |
|   |       | 13.4.5 DQS Gating                                                                                                                  |     |
|   |       | 13.4.6 Dynamic Strobe Drift Detection                                                                                              |     |
|   | 13.5  | Register description                                                                                                               | 375 |
|   |       | 13.5.1 Registers Summary                                                                                                           |     |
|   | 40 -  | 13.5.2 Detail Registers Description                                                                                                |     |
|   | 13.6  | Timing Diagram                                                                                                                     |     |
|   |       | 13.6.1 DDR3 Read/Write Access Timing                                                                                               |     |
|   |       | 13.6.2 LPDDR2 Read/Write Access Timing                                                                                             |     |
|   | 137   | Interface description                                                                                                              | 583 |

| 13.8 Application Notes                       | .584 |
|----------------------------------------------|------|
| 13.8.1 State transition of PCTL              |      |
| 13.8.3 MDLL and MSDLL Reset Requirements     |      |
| 13.8.4 Data Training                         |      |
| 13.8.5 Impedance Calibration                 |      |
| 13.8.6 Retention Functional                  | .593 |
| 13.8.7 Low Power Operation                   | .595 |
| 13.8.8 PHY Power Down                        |      |
| 13.8.9 Dynamic ODT for I/Os                  |      |
| Chapter 14 SMC(Static Memory Controller)     | .601 |
| 14.1 Overview                                | .601 |
| 14.2 Block Diagram                           | .601 |
| 14.3 Function Description                    | .601 |
| 14.3.1 APB slave interface                   | .601 |
| 14.3.2 Format                                |      |
| 14.3.3 Memory manager14.3.4 Memory interface | .603 |
| 14.3.4 Memory interface                      | .604 |
| 14.3.5 Pad interface                         | .605 |
| 14.3.6 SRAM interface timing diagrams        | .605 |
| 14.4 Register Description                    | .607 |
| 14.4.1 Registers Summary                     | .607 |
| 14.4.2 Detail Register Description           | .607 |
| 14.5 Timing Diagram                          | .617 |
| 14.6 Interface Description                   | .618 |
| 14.7 Application Notes                       | .619 |
| 14.7.1 multiplexed address/data mode         | .619 |
| 14.7.2 Booting using the SRAM interface      |      |
| Chapter 15 NandC(Nand Flash Controller)      | .620 |
| 15.1 Overview                                |      |
| 15.1.1 Features                              | 620  |
| Chapter 16 eMMC Interface                    | 622  |
|                                              |      |
| 16.1 Overview                                |      |
| Chapter 17 SD/MMC Card Host Controller       | .623 |
| 17.1 Overview                                | .623 |
| 17.2 Block Diagram                           | .623 |
| 17.3 Function description                    | .624 |
| 17.3.1 Bus Interface Unit                    |      |
| 17.3.2 Card Interface Unit                   | .628 |
| 17.4 Register description                    | .640 |
| 17.4.1 Register Summary                      | .640 |
| 17.4.2 Detail Register Description           |      |
| 17.5 Timing Diagram                          |      |
|                                              |      |

| 17.6 Interface description                                                                          | 663        |
|-----------------------------------------------------------------------------------------------------|------------|
| 17.6.1 Card-Detect and Write-Protect Mechanism                                                      | 664        |
| 17.6.3 SD/MMC Controller IOMUX                                                                      |            |
| 17.7.1 Software/Hardware Restriction                                                                |            |
| 17.7.3 Programming SD/MMC Controller for Boot Operation 17.7.4 Voltage Switching and DDR Operations | 679        |
| 17.7.5 H/W Reset Operation                                                                          | 692        |
| 18.1 Overview                                                                                       |            |
| 18.1.1 Features supported                                                                           | 692        |
| 18.2 Block Diagram                                                                                  | 692        |
| 18.3 Function Description                                                                           | 692        |
| 18.3.1 TZMA                                                                                         | 692        |
| 18.3.2 AXI slave interface                                                                          | 692        |
| Chapter 19 GPU (Graphics Process Unit)                                                              | 693        |
| 19.1 Overview                                                                                       | 693        |
| Chapter 20 VCODEC (Video encoder and decoder Unit)                                                  | 694        |
| 20.1 Overview                                                                                       |            |
| Chapter 21 IPP (Image Post Processor)                                                               | 695        |
| 21.1.1 Features                                                                                     | 695        |
| Chapter 22 LCDC                                                                                     | 696        |
| 22.1.1 Features                                                                                     |            |
| 22.2 Block Diagram                                                                                  |            |
| 22.3 Function Description                                                                           | 698        |
| 22.3.1 Data Format                                                                                  |            |
| 22.3.2 Virtual display                                                                              | 700        |
| 22.3.3 Scaling                                                                                      | /00<br>703 |
| 22.3.5 Overlay                                                                                      |            |
| 22.4 Register Description                                                                           |            |
| 22.4.1 Register Summary                                                                             | 709        |
| 22.4.2 Detail Register Description                                                                  | 712        |
| 22.5 Timing Diagram                                                                                 | 731        |
| 22.6 Interface Description                                                                          | 733        |
| 22.6.1 LCDC0 Ouputs                                                                                 |            |
|                                                                                                     |            |

|      | 22.6.3 Pin Definition               | 734<br>735 |
|------|-------------------------------------|------------|
| -    | r 23 RGA                            | 736        |
| 23.1 | Overview                            | /36        |
| -    | 23.1.1 Featuresr 24 HDMI TX         | 738        |
| 24.1 | Overview                            | /38        |
| 24.2 | 24.1.1 Features                     |            |
| 24.3 | Function Description                | 739        |
|      | 24.3.1 Video Data Processing        | 739        |
|      | 24.3.2 Audio Data Processing        | 752        |
|      | 24.3.3 Controller Interface         | 754        |
|      | 24.3.4 HDCP Key Memory Interface    | 756        |
|      | 24.3.5 Power Save Mode              | /5/<br>757 |
| 24.4 | Register Description                | 759        |
|      | 24.4.1 Register Summary             | 759        |
|      | 24.4.2 Detail Register Description  | 759        |
| 24.5 | 24.4.2 Detail Register Description  | 760        |
|      | 24.5.1 Video Input Source           | 760        |
| 24.6 | 24.5.2 Audio Input Source           |            |
| 24.6 | Programming Guide                   |            |
|      | 24.6.1 Main Sequence                |            |
|      | 24.6.2 Hot Plug Detection Sequences |            |
|      | 24.6.3 Reading EDID Sequence        |            |
|      | 24.6.5 Control Packet               |            |
|      | 24.6.6 Loading HDCP Key             |            |
|      | 24.6.7 Hardware HDCP Authentication |            |
|      | 24.6.8 Software HDCP Authentication |            |
| •    | r 25 Camera Interface               |            |
| 25.1 | Overview                            | 774        |
| 25.2 | Block Diagram                       | 774        |
| 25.3 | Function description                | 775        |
| 25.4 | Register description                | 778        |
|      | 25.4.1 Register Summary             |            |
|      | 25.4.2 Detail Register Description  |            |
| 25.5 | Timing Diagram                      | 790        |
| 25.6 | Interface description               | 791        |
| 25.7 | Application Notes                   | 792        |

| Chapter 26 USB Host2.0793                       |     |  |
|-------------------------------------------------|-----|--|
| 26.1 Overview                                   |     |  |
| 26.1.1 Features                                 |     |  |
| 26.2.1 USB HOST 2.0 Controller Function         |     |  |
| 26.3 USB Host2.0 Controller                     | 794 |  |
| 26.4 USB Host2.0 PHY                            | 795 |  |
| 26.4.1 Block Diagram                            |     |  |
| 26.5.1 Registers Summary                        | 796 |  |
| 26.5.2 Registers Description                    | 801 |  |
|                                                 |     |  |
| Chapter 27 USB OTG2.0                           | 802 |  |
| 27.1.1 Features                                 | 802 |  |
| 27.2 Block Diagram                              | 802 |  |
| 27.2.1 USB OTG 2.0 Controller Function          | 803 |  |
| 27.2.3 UTMI Interface                           | 803 |  |
| 27.3.1 Host Architercture                       |     |  |
| 27.3.2 Device Architercture                     | 807 |  |
| 27.3.3 Internal DMA Mode                        |     |  |
| 27.3.5 Sub-Module Architecture                  |     |  |
| 27.4 USB OTG2.0 PHY                             | 813 |  |
| 27.4.1 Block Diagram                            | 813 |  |
| 27.4.2 Powering Up and Powering Down            |     |  |
| 27.4.3 Removing Power Supplies for Power Saving |     |  |
|                                                 |     |  |
| 27.5.1 Register Summary                         |     |  |
| 27.6 Interface description                      |     |  |
| Chapter 28 I2S/PCM0 Controller (8 channel)      | 968 |  |
| 28.1 Overview                                   |     |  |
| 28.2 Block Diagram                              | 969 |  |
| 28.3 Function description                       | 969 |  |
| 28.3.1 I2S normal mode                          | 970 |  |
| 28.3.2 I2S left justified mode                  |     |  |
| 28.3.3 I2S right justified mode                 |     |  |

| 28.4   | 28.3.5 PCM late1 mode                  | 972<br>973                 |
|--------|----------------------------------------|----------------------------|
|        | 28.4.1 Register Summary                | 973<br>974                 |
|        | 28.5.1 Master mode                     | 985<br>985                 |
|        | Application Notes                      |                            |
| Chapte | r 29 I2S/PCM1/2 Controller (2 channel) | 989                        |
| 29.1   | Overview                               | 989                        |
| 29.2   | Block Diagram                          | 990                        |
| 29.3   | Function description                   | 990                        |
|        | 29.3.1 I2S normal mode                 | 991                        |
|        | 29.3.2 I2S left justified mode         | 991                        |
|        | 29.3.3 I2S right justified mode        | 992                        |
|        | 29.3.5 PCM late1 mode                  | 992<br>200                 |
|        | 29.3.6 PCM late2 mode                  | 992<br>993                 |
|        | 29.3.7 PCM late3 mode                  | 993                        |
| 29.4   | Register description                   | 994                        |
|        | 29.4.1 Register Summary                | 994<br>994                 |
| 29.5   | Timing Diagram                         | 1004                       |
|        | 29.5.1 Master mode                     | . 1004                     |
| 20.6   | 29.5.2 Slave mode                      |                            |
| 29.0   | Interface description                  | 1000                       |
|        | Application Notes                      |                            |
| Chapte | r 30 SPDIF transmitter                 | . 1009                     |
| 30.1   | Overview                               | 1009                       |
| 30.2   | Block Diagram                          | 1009                       |
| 30.3   | Function description                   | 1010                       |
| 30.4   | 30.3.1 Frame Format                    | . 1011<br>. 1011<br>. 1012 |
|        | 30.4.1 Register Summary                |                            |
|        | 30.4.2 Detail Register Description     |                            |
| 30.5   | Interface description                  | 1015                       |

|   | 30.6 Application Notes                         | 1015                                         |
|---|------------------------------------------------|----------------------------------------------|
| C | hapter 31 SDIO Host Controller                 |                                              |
|   | 31.2 Block Diagram                             | 1016                                         |
|   | 31.3 Function description                      | 1017                                         |
|   | 31.4 Register description                      | 1017                                         |
|   | 31.5 Timing Diagram                            | 1017                                         |
|   | 31.6 Interface description                     | 1017                                         |
|   | 31.6.1 Card-Detect and Write-Protect Mechanism | 1017<br>1017<br>1019<br>1019                 |
| C | hapter 32 MAC Ethernet Interface               | 1020                                         |
|   | 32.1 Overview                                  |                                              |
|   | 32.1.1 Features                                | 1020<br>1020                                 |
|   | 32.2.1 Architecture                            | 1021<br>1022                                 |
|   | 32.3 Register description                      |                                              |
|   | 32.3.1 Register Summary                        | 1023                                         |
|   | 32.5 Interface Description                     |                                              |
|   | 32.6 Application Notes                         |                                              |
| C | 32.6.1 Buffer Descriptors                      | 1035<br>1036<br>1038<br>1040<br>1041<br>1042 |
|   | 33.1.1 Features                                |                                              |
|   | 33.2 Block Diagram                             |                                              |
|   | 33.3 Function Description                      | 1043                                         |
|   | 33.4 Register Description                      |                                              |
|   | 33.4.1 Registers Summary                       | 1044                                         |

| 33.6           | Interface Description                                     | 1048                 |
|----------------|-----------------------------------------------------------|----------------------|
| 33.7           | Application Notes                                         | 1049                 |
| •              | r 34 PID-FILTER                                           |                      |
| 34.1           | Overview                                                  |                      |
| 34.2           | 34.1.1 Key Feature  Block Diagram                         |                      |
| 34.3           | Function Description                                      | 1052                 |
| 34.4           | Register Description                                      | 1053                 |
| 34.5           | 34.4.1 Register summary                                   | 1053<br>1056         |
| Chapte<br>35.1 | 34.5.1 Working Flow                                       | 1056<br>1056<br>1057 |
| 35.2           | Block Diagram                                             | 1057                 |
| 35.3           | Block Diagram  Function description  Register description | 1059                 |
| 35.4           |                                                           |                      |
| 35.5           | 35.4.1 Registers Summary                                  | 1061                 |
| 35.6           | Interface description                                     | 1069                 |
| 35.7           | Application Notes                                         | 1070                 |
| Chapte         | r 36 UART Interface                                       | 1072                 |
| 36.1           | Overview                                                  |                      |
| 36.2           | 36.1.1 Features  Block Diagram                            |                      |
| 36.3           | Function description                                      | 1073                 |
| 36.4           | Register description                                      | 1076                 |
| 36.5           | 36.4.1 Registers Summary                                  | 1077                 |
| 36.6           | Application Notes                                         | 1089                 |
| Chante         | 36.6.1 None FIFO Mode Transfer Flow                       | 1089<br>1090         |

|   | 37.1 Overview                | 1092                 |
|---|------------------------------|----------------------|
|   | 37.2 Block Diagram           | 1092                 |
|   | 37.3 Function description    | 1093                 |
|   | 37.4 Register description    | 1096                 |
|   | 37.5 Timing Diagram          | 1103                 |
|   | 37.6 Interface description   | 1103                 |
|   | 37.7 Application Notes       | 1104                 |
| С | Chapter 38 GPIO38.1 Overview | 1108<br>1108         |
|   | 38 2 Block Diagram           | 1108                 |
|   | 38.3 Function description    | 1109                 |
|   | 38.3 Function description    | 1111                 |
| C | 38.4.1 Registers Summary     | 1112<br>1115<br>1115 |
|   | 39.2 Block Diagram           | 1115                 |
|   | 39.3 Function description    | 1115                 |
|   | 39.3.1 Timer clk selection   | 1115<br>1116<br>1116 |
|   | 39.4.1 Registers Summary     | 1117                 |
| C | Chapter 40 PWM               |                      |
|   | 40.1 Overview                |                      |
|   | 40.1.1 Features              |                      |
|   | 40.3 Register description    | 1121                 |
|   | 40.3.1 Register Summary      | 1122                 |
| C | Chapter 41 WatchDog          |                      |
|   | 41.1 Overview                | 1125                 |

| 41.2           | Block Diagram           | 1125                 |
|----------------|-------------------------|----------------------|
| 41.3           | Function Description    | 1125                 |
| 41.4           | 41.3.1 Operation        | 1126                 |
|                | 41.4.1 Register Summary | 1127<br>1131         |
| 42.2           | Block Diagram           | 1131                 |
| 42.3           | Function Description    | 1131                 |
| 42.4           | Register description    | 1132                 |
| 42.5           | 42.4.1 Register Summary | 1132<br>1132<br>1134 |
| 42.6           | Application Notes       | 1134                 |
| Chapte<br>43.1 | Overview                | 1135<br>1135         |
| 43.2           | Block Diagram           | 1135                 |
|                | Function description    |                      |
| 43.4           | Register description    | 1136                 |
| 43.5           | 43.4.1 Register Summary | 1136                 |
| 43.6           | Application Notes       | 1138                 |
| •              | r 44 eFuseOverview      |                      |
|                | r 45 Chip Test Solution |                      |

## **Figure Index**

| Fig. | 1-1 RK30xx Block Diagram                                               | 39  |
|------|------------------------------------------------------------------------|-----|
| Fig. | 1-2 RK3066 TFBGA453 Package Top View                                   | 65  |
|      | 1-3 RK3066 TFBGA453 Package Side View                                  |     |
| Fig. | 1-4RK3066 TFBGA453 Package Bottom View                                 | 66  |
| _    | 1-5 RK3066 TFBGA453 Package Dimension                                  |     |
|      | 1-6 RK3066 Ball Mapping Diagram                                        |     |
|      | 1-7 External Reference Circuit for 24MHzOscillators                    |     |
| _    | 1-8 External reference circuit for PLL                                 |     |
|      | 1-9 RK30xx USB OTG/Host2.0 interface reference connection              |     |
|      | 1-10RK30xx HDMI interface reference connection                         |     |
|      | 1-11 RK30xx reset signals sequence                                     |     |
| Fig. | 2-1 RK30xx Address Mapping when BTMODE=low before remap                | 89  |
|      | 2-2 RK30xx Address Mapping when BTMODE=lowafter remap                  |     |
|      | 2-3 RK30xx Address Mapping when BTMODE=high                            |     |
| Fia. | 2-4 RK30xx boot procedure flow                                         | 92  |
| Fig. | 6-1 RK30xx Debug system structure                                      | 100 |
| Fig. | 6-2 DAP SWJ interface                                                  | 143 |
| Fig. | 8-1MP Subsystem architecture                                           | 256 |
| Fig. | 8-1MP Subsystem architecture                                           | 297 |
| Fig. | 10-2 DMAC0 operation states                                            | 298 |
| Fig. | 10-3 DMAC0 request and acknowledge timing                              | 314 |
| Fig. | 11-1 Block diagram of dmac1                                            | 324 |
| Fig. | 11-1 Block diagram of dmac1                                            | 342 |
| Fig. | 12-2 GIC Interrupt handling state machine                              | 345 |
|      | 12-3Secure view of the priority field for a Secure interrupt           |     |
|      | 12-4 Non-secure view of the priority field for a Non-secure interrupt. |     |
|      | 12-5 Secure read of the priority field for a Non-secure interrupt      |     |
|      | 13-1Protocol controller architecture                                   |     |
|      | 13-2PHY controller architecture                                        |     |
|      | 13-3Protocol controller architecture                                   |     |
| Fig. | 13-4 DDR PHY architecture                                              | 363 |
| Fig. | 13-5 DDR PHY master DLL architecture diagram                           | 366 |
| Fig. | 13-6 DDR PHY master-slave DLL architecture diagram                     | 369 |
|      | 13-7Strobe Gating Requirements During Read Operations                  |     |
|      | 13-8DQS gating - passive windowing mode                                |     |
| Fig. | 13-9DQS gating – active windowing mode                                 | 375 |
| Fig. | 13-10DDR3 burst write operation: AL=0,CWL=4, BC4                       | 581 |
|      | 13-11DDR3 burst read operation: AL=0,CL=5, BC4                         |     |
| Fig. | 13-12LPDDR2 burst write operation: WL=1,BL=4                           | 582 |
| Fig. | 13-13LPDDR2 burst read operation: RL=3, BL=4                           | 582 |
| Fig. | 13-14Protocol controller architecture                                  | 586 |
| Fig. | 13-15DLL reset requirements                                            | 589 |
| Fig. | 13-16DLL reset requirements                                            | 590 |
| Fig. | 13-17Impedance Calibration Circuit                                     | 592 |
|      | 13-18I/O cell arrangement with retention                               |     |
|      | 13-19Sequence of Events to Enter and Exit Retention                    |     |
| Fig. | 14-1 SMC architecture diagram                                          | 601 |
|      | 14-2Software Mechanism of Direct Commands in SMC                       |     |
|      | 14-3 SMC asynchronous read timing                                      |     |
|      | 14-4 SMC asynchronous read timing in multiplexed mode                  |     |
|      | 14-5 SMC asynchronous write timing                                     |     |
| Fig. | 14-6 SMC asynchronous write timing in multiplexed mode 1               | 606 |

|      | 14-7 SMC asynchronous write timing in multiplexed mode 2   |            |
|------|------------------------------------------------------------|------------|
|      | 14-8 SMC page read timing                                  |            |
| _    | 14-9 SMC timing diagram of asynchronous read               |            |
|      | 14-10Asynchronous Write Timing Diagram In Multiplexed Mode |            |
| _    | 17-1SD/MMC Controller Block Diagram                        |            |
|      | 17-2SD/MMC Card-Detect Signal                              |            |
|      | 17-3 SD/MMC Command Path State Machine                     |            |
|      | 17-4 SD/MMC Data Transmit State Machine                    |            |
|      | 17-5 SD/MMC Data Receive State Machine                     |            |
|      | 17-6 Card-Detect and Write-Protect                         |            |
|      | 17-7 SD/MMC Termination                                    |            |
|      | 17-8 Initialization Sequence                               |            |
|      | 17-9 Command format for CMD52                              |            |
|      | 17-10 Boot Operation                                       |            |
| Fig. | 17-11 SD/MMC Controller Flow for Boot Operation            | 680        |
| Fig. | 17-12 Alternative Boot Opertation                          | 683        |
| Fig. | 17-13 Host Controller Flow for Alternative Boot Mode       | 684        |
|      | 17-14 Voltage Switching Command Flow Diagram               |            |
|      | 17-15 ACMD41 Argument                                      |            |
| Fia. | 17-16 ACMD41 Response(R3)                                  | 688        |
| Fia. | 17-16 ACMD41 Response(R3)                                  | 688        |
| Fia. | 17-18 Voltage Switch Error Scenario                        | 690        |
| Fia. | 18-1 Embedded SRAM block diagram                           | 692        |
| Fig. | 22-1LCDC Block Diagram                                     | 697        |
| Fia  | 22-2LCDC Dual LCDCs in SOC                                 | 697        |
| Fig  | 22-3LCDC Frame Buffer Data Format                          | 698        |
|      | 22-4LCDC Win2 Palette (8bpp/4bpp)                          |            |
|      | 22-5LCDC Hwc Data Format                                   |            |
|      | 22-6LCDC Virtual Display Mode                              |            |
| Fig. | 22-7LCDC Scaling Down Offset                               | 700<br>701 |
|      | 22-8LCDC Scaling Down Onset                                |            |
|      | 22-9LCDC Interlace Vertical Filtering                      |            |
|      | 22-10LCDC Mix 3D Display                                   |            |
|      |                                                            |            |
|      | 22-11LCDC Interleave 3D Display                            |            |
|      | 22-12LCDC Overlay Block Diagram                            |            |
|      | 22-13LCDC Overlay Display                                  |            |
| _    | 22-14LCDC Transparency Color Key                           |            |
| _    | 22-15LCDC Alpha blending                                   |            |
|      | 22-16LCDC Replication                                      |            |
|      | 22-17LCDC Dithering                                        |            |
|      | 22-18 LCDC RGB interface timing                            |            |
|      | 22-19 LCDC MCU interface (i80)timing                       |            |
|      | 22-20 LCDC RGB interface timing setting                    |            |
|      | 22-21 LCDC Serail RGB LCD interface                        |            |
|      | 22-22 LCDC MCU interface timing setting                    |            |
| _    | 22-23 LCDC RGB delta LCD interface                         |            |
|      | 24-1HDMI TX Block Diagram                                  |            |
| _    | 24-2HDMI TXVideo Data Processing                           |            |
| _    | 24-3HDMI TX Video Input Timing ID.1                        |            |
|      | 24-4HDMI TX Video Input Timing ID.3                        |            |
|      | 24-5HDMI TXExternal Video Parameter Setting                |            |
| Fig. | 24-6HDMI TXExternal Video SettingParameters Diagram        | 745        |
| Fig. | 24-7HDMI TXEmbedded Sync. Extraction Parameters Diagram    | 748        |
| Fia  | 24-8 HDMI TX HDCP Authentication State Diagram             | 751        |

| Fig. | 24-9HDMI TX I2S input timing at Standard I2S mode                   | 753 |
|------|---------------------------------------------------------------------|-----|
| Fig. | 24-10HDMI TX I2S input timing at Left justified mode                | 753 |
| Fig. | 24-11 HDMI TX HBR data stream input ordering                        | 754 |
| Fig. | 24-12 HDMI TXInterrupt Signaling Block Diagram                      | 755 |
| Fig. | 24-13 HDMI TXintegration example diagram related with DDC bus       | 756 |
| Fig. | 24-14HDMI TX Software Main Sequence Diagram                         | 760 |
|      | 24-15HDMI TX Hot Plug Sequence Diagram                              |     |
| Fig. | 24-16HDMI TX Software EDID Read Sequence Diagram                    | 763 |
|      | 24-17HDMI TX Software TX SettingSequence Diagram                    |     |
| Fig. | 24-18HDMI TX Software Control Packet Sequence Diagram               | 768 |
| Fig. | 24-19HDMI TX Loading HDCP Key Sequence Diagram                      | 769 |
|      | 24-20HDMI TX Hardware HDCP Authentication Sequence Diagram          |     |
|      | 25-1CIF block diagram                                               |     |
|      | 25-2 Timing diagram for CIF when vsync low active                   |     |
| Fig. | 25-3Timing diagram for CIF when vsync high active                   | 775 |
| Fig. | 25-4Timing diagram for CIF when href high active                    | 775 |
| Fig. | 25-5Timing diagram for CIF when href low active                     | 775 |
| Fig. | 25-6Timing diagram for CIF when Y data first                        | 776 |
| Fig. | 25-7Timing diagram for CIF when U data first                        | 776 |
| Fig. | 25-8CCIR656 timing                                                  | 776 |
| Fig. | 25-8CCIR656 timing25-9Raw Data or JPEG Timing                       | 776 |
| Fig. | 26-1USB HOST 2.0 Architecture                                       | 793 |
| Fig. | 26-2 USB HOST 2.0 Controller Architecture                           | 795 |
| Fig. | 26-3 USB HOST 2.0 PHY Architecture                                  | 796 |
|      | 27-1USB OTG 2.0 Architecture                                        |     |
| Fig. | 27-2 UTMI interface –Transmit timing for a data packet              | 804 |
|      | 27-3 UTMI interface – Receive timing for a data packet              |     |
|      | 27-4 USB OTG2.0 Controller Architecture                             |     |
| _    | 27-5 USB OTG2.0 Controller – Host Architecture                      |     |
|      | 27-6 USB OTG2.0 Controller – Host Architecture                      |     |
|      | 27-7 USB OTG2.0 Controller – Internal DMA mode                      |     |
| _    | 27-8 USB OTG 2.0 Controller host mode FIFO address mapping          |     |
| _    | 27-9 USB OTG 2.0 Controller device mode FIFO address mapping        |     |
| _    | 27-10 USB OTG 2.0 Controller Packet FIFO controller                 |     |
|      | 27-11 DFIFO single-port synchRnous SRAM interface                   |     |
|      | 27-12 USB OTG 2.0 Controller – MAC block diagram                    |     |
|      | 27-13 USB OTG 2.0 PHY Architecture                                  |     |
|      | 27-14 USB OTG 2.0 PHY power supply and power up sequency            |     |
|      | 27-15 USB OTG 2.0 PHY removing power supplies                       |     |
| _    | 28-1 I2S/PCM0 controller (8 channel) Block Diagram                  |     |
| _    | 28-2I2S transmitter-master & receiver-slave condition               |     |
| _    | 28-3I2S transmitter-slave& receiver-master condition                |     |
|      | 28-4I2S normal mode timing format                                   |     |
|      | 28-5I2S left justified mode timing format                           |     |
|      | 28-6I2S right justified modetiming format                           |     |
|      | 28-7PCM early modetiming format                                     |     |
|      | 28-8PCM late1 modetiming format                                     |     |
|      | 28-9PCM late2 modetiming format                                     |     |
| _    | 28-10PCM late3 modetiming format                                    |     |
| _    | 28-12Master mode timing diagram                                     |     |
|      | 28-13Slave mode timing diagram                                      |     |
|      | 28-14 I2S/PCM0 controller (8 channel) transmit operation flow chart |     |
|      | 28-15I2S/PCM0 controller (8 channel) receive operation flow chart   |     |
| Fia  | 29-1 I2S/PCM1/2 controller (2 channel) Block Diagram                | 990 |

| Eia  | 29-2I2S transmitter-master & receiver-slave condition                 | 001   |
|------|-----------------------------------------------------------------------|-------|
| _    | 29-312S transmitter-slave & receiver-master condition                 |       |
| _    |                                                                       |       |
|      | 29-4I2S normal mode timing format                                     |       |
|      | 29-5I2S left justified mode timing format                             |       |
| _    | 29-6I2S right justified mode timing format                            |       |
|      | 29-7PCM early mode timing format                                      |       |
| _    | 29-8PCM late1 mode timing format                                      |       |
| _    | 29-9PCM late2 mode timing format                                      |       |
| _    | 29-10PCM late3 mode timing format                                     |       |
| _    | 29-11Master mode timing diagram                                       |       |
|      | 29-12Slave mode timing diagram                                        |       |
|      | 29-13I2S/PCM1/2 controller transmit operation flow chart              |       |
| Fig. | 29-14I2S/PCM1/2 controller receive operation flow chart               | 1008  |
|      | 30-1SPDIF transmitter Block Diagram                                   |       |
|      | 30-2SPDIF Frame Format                                                |       |
| _    | 30-3SPDIF Sub-frame Format                                            |       |
|      | 30-4SPDIF Channel Coding                                              |       |
|      | 30-5SPDIF Preamble                                                    |       |
| Fig. | 30-6 SPDIF transmitter operation flow chart                           | 1015  |
| Fig. | 31-1SD/MMC Controller Block Diagram                                   | 1016  |
| Fig. | 31-1SD/MMC Controller Block Diagram31-2 Card-Detect and Write-Protect | 1017  |
| Fia. | 31-3 SD/MMC Termination                                               | 1018  |
| Fig. | 32-1 VMAC architecture                                                | 1020  |
| Fig. | 32-2 VMAC Frame structure                                             | 1021  |
| Fig. | 32-3RMII transmission in 100Mb/s mode                                 | 1022  |
|      | 32-4 RMII reception with no errors in 100Mb/s mode                    |       |
|      | 32-5Management timing diagram                                         |       |
|      | 32-6 RMII timing diagram                                              |       |
| Fig. | 32-7 VMAC buffer chain                                                | 1036  |
| _    | 32-8 VMAC transmit buffer descriptor written by CPU                   |       |
|      | 32-9 VMAC transmit buffer descriptor written by VMAC                  |       |
|      | 32-10 VMAC receive buffer descriptor written by VMAC                  |       |
|      | 32-11 VMAC receive buffer descriptor written by CPU                   |       |
|      | 33-1 HS-ADC/TS Interface block diagram                                |       |
| _    | 33-2 HS-ADC application diagram                                       |       |
|      | 33-3 GPS application diagram                                          |       |
|      | 33-4 TS application diagram                                           |       |
|      | 33-5 HS-AD Interface timing diagram                                   |       |
|      | 33-6Almost empty triggers a DMA request by DMA request mode           |       |
|      | 33-7Almost full triggers a DMA request by DMA request mode            |       |
| -    | 34-1 PID-Filter block diagram                                         |       |
|      | 34-2 PID-Filter data flow                                             |       |
| _    | 35-1SPI Controller Block diagram                                      |       |
|      | 35-2SPI Master & Slave Interconnection                                |       |
|      | 35-3 SPI Format (SCPH=0 SCPOL=0)                                      |       |
|      | 35-4SPI Format (SCPH=0 SCPOL=1)                                       |       |
|      | 35-5SPI Format (SCPH=1 SCPOL=0)                                       |       |
|      | 35-6SPI Format (SCPH=1 SCPOL=1)                                       |       |
|      | 35-7SPI controller timing diagram                                     |       |
|      | 35-8SPI controller timing diagram in slave mode                       |       |
|      |                                                                       |       |
| _    | 35-9SPI Master transfer flow diagram                                  |       |
| _    | 35-10SPI Slave transfer flow diagram                                  |       |
| _    | 36-1UART Architecture                                                 | 1072  |
| -10  | DUTZUAKT BELIATURUUU                                                  | 111/3 |

## Rockchip **RK30xx**Technical Reference Manual Rev2.0

| Fig. 36-3UART baud rate Fig. 36-4UART Auto flow control block diagram Fig. 36-5UART AUTO RTS TIMING Fig. 36-6 UART AUTO CTS TIMING Fig. 36-7UARTnone fifo mode Fig. 36-8UART flifo mode Fig. 36-9 UART clock generation Fig. 37-112C architechture Fig. 37-212C DATA Validity Fig. 37-3 I2C Start and stop conditions Fig. 37-4I2C Acknowledge Fig. 37-6 I2C timing diagram Fig. 37-6 I2C timing diagram Fig. 37-8I2C Flow chat for tx only mode Fig. 37-9I2C Flow chat for mix mode Fig. 38-1GPIO block diagram Fig. 38-2 Interrupt RTL Block Diagram Fig. 39-2 Timer Block Diagram Fig. 39-2 Timer Usage Flow Fig. 39-3Timing of Timer_en and Timer_clk (timer_clk is async to pclk) Fig. 39-4Timer0 and Timer1Usage Flow Fig. 40-1 PWM architecture Fig. 41-1WDT block diagram Fig. 42-1RK30xx SAR-ADC block diagram Fig. 42-1RK30xx SAR-ADC block diagram Fig. 43-2TS-ADC timing diagram in single-sample conversion mode Fig. 43-2TS-ADC timing diagram in single-sample conversion mode | 1075<br>1075<br>1076<br>1089<br>1089<br>1095<br>1095<br>1095<br>1095<br>1106<br>1107<br>1108<br>1110<br>1115<br>1116<br>1115<br>1115<br>1113<br>1121<br>1121<br>1123 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Rockering                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                      |

### **Table Index**

| Table 1-1 RK30xx Power/Ground IO informations                              |      |
|----------------------------------------------------------------------------|------|
| Table 1-2 RK3066 IO descriptions                                           |      |
| Table 1-3 RK30xx IO function description list                              | 57   |
| Table 1-4 RK30xx IO Type List                                              | 63   |
| Table 1-5 RK3066Ball Pin Number Order Information                          | 69   |
| Table 1-6 RK30xx absolute maximum ratings                                  | 75   |
| Table 1-7 RK30xx recommended operating conditions                          |      |
| Table 1-8 RK30xx DC Characteristics                                        | 77   |
| Table 1-9 Recommended operating frequency for PD_ALIVE domain              |      |
| Table 1-10 Recommended operating frequency for A9 core                     |      |
| Table 1-11 Recommended operating frequency for PD_CPU domain               |      |
| Table 1-12 Recommended operating frequency for PD_PERI domain              |      |
| Table 1-13 Recommended operating frequency for PD_VIO domain               |      |
| Table 1-14 Recommended operating frequency PD_GPU domain                   |      |
| Table 1-15 Recommended operating frequency for PD_VIDEO domain             |      |
| Table 1-16RK30xx Electrical Characteristics for Digital General IO         |      |
| Table 1-17 RK30xx Electrical Characteristics for PLL                       |      |
| Table 1-18 RK30xx Electrical Characteristics for SAR-ADC                   | 82   |
| Table 1-19 RK30xx Electrical Characteristics for TS-ADC                    |      |
| Table 1-20 RK30xx Electrical Characteristics for USB OTG/Host2.0 Interface |      |
| Table 1-21 RK30xx Electrical Characteristics for HDMI                      |      |
| Table 1-22 RK30xx Electrical Characteristics for DDR IO                    |      |
| Table 1-23 RK30xx Electrical Characteristics for eFuse                     |      |
|                                                                            |      |
| Table 1-24 Ferrite Bead Selection                                          | 93   |
| Table 2-2 RK30xx DMAC0 Hardware request connection list                    | 95   |
| Table 2-3 RK30xx DMAC1 Hardware request connection list                    |      |
| Table 6-1SWJ interface                                                     |      |
| Table 6-2TPIU interface                                                    |      |
| Table 10-1DMAC0 Request Mapping Table                                      | .296 |
| Table 10-2 DMAC Instruction sets                                           |      |
| Table 11-1DMAC1 Request Mapping Table                                      |      |
| Table 17-1 Bits in Interrupt Status Register                               |      |
| Table 17-2 Auto-Stop Generation                                            |      |
| Table 17-3 Non-data Transfer Commands and Requirements                     |      |
| Table 17-4 SDMMC IOMUX Settings                                            |      |
| Table 17-5 Recommended Usage of use_hold_reg                               |      |
| Table 17-6 Command Settings for No-Data Command                            |      |
| Table 17-7 Command Setting for Single-Block or Multiple-Block Read         |      |
| Table 17-8 Command Settings for Single-Block or Multiple-Block Write       |      |
| Table 17-9 Parameters for CMDARG Registers                                 |      |
| Table 17-10 CMDARG Bit Values                                              |      |
| Table 22-1Hwc 3-color Transparency Mode                                    |      |
| Table 22-2Hwc 2-color Transparency Mode                                    |      |
| Table 22-3LCDC Data Swap of Win0, Win1 and Win2                            |      |
| Table 22-4LCDC Scaling Start Point Offset Registers                        |      |
| Table 22-5 LCDC0 RGB interface signal timing constant                      |      |
| Table 22-6 LCDC1 RGB interface signal timing constant                      |      |
| Table 22-7 LCDC0 RGB interface signal timing constant                      |      |
| Table 22-8 LCDC1 RGB interface signal timing constant                      |      |
| Table 22-9I CDC1 IOMLIX                                                    | 733  |

| Table 22-10 LCDC output pin definition                                  |      |
|-------------------------------------------------------------------------|------|
| Table 22-11 LCDC delta and swap setting for RGB delta LCD               |      |
| Table 24-1HDMI TX Supported Input Video Formats                         |      |
| Table 24-2HDMI TX Video Data Assignment (1-19)                          |      |
| Table 24-3HDMI TX Video Data Assignment (20-29)                         |      |
| Table 24-4HDMI TX Video Data Assignment (30-35)                         |      |
| Table 24-5HDMI TX control register settings for each video input ID     |      |
| Table 24-6HDMI TX External Video Setting Example                        |      |
| Table 24-7HDMI TX Special video format                                  | 746  |
| Table 24-8HDMI TX External Video ParameterSetting for Special video for |      |
|                                                                         |      |
| Table 24-9HDMI TX External Video ParameterSetting for Special video for |      |
|                                                                         |      |
| Table 24-10HDMI TX CSC coeffcients Values                               |      |
| Table 24-11HDMI TX Supported SPDIF Sampling frequency at each video for |      |
| T.I.I. 24 42UDM TV.C                                                    | /52  |
| Table 24-12HDMI TX Supported I2S 2Ch Audio Sampling frequency at ea     |      |
| video format                                                            | /53  |
| Table 24-13HDMI TX Supported I2S 8Ch Audio Sampling frequency at ea     | ch   |
| video format                                                            | /53  |
| Table 24-14HDMI TX HDCP key map example as provided by DCP LLC          |      |
| Table 24-15HDMI TX Power save mode summary                              |      |
| Table 24-16HDMI TX Register Setting Summary for Video                   |      |
| Table 24-17HDMI TX Register Setting Summary for Audio                   |      |
| Table 24-18HDMI TX PHY Parameter Setting                                |      |
| Table 25-1CIF0 Timing  Table 25-2CIF1 Timing                            | /90  |
| Table 26 1 USB HOST 2.0 Interface Description                           | /91  |
| Table 26-1 USB HOST 2.0 Interface Description                           |      |
| Table 27-1 USB OTG 2.0 PHY power supply timing parameter                |      |
| Table 27-2 USB OTG 2.0 Interface Description                            |      |
| Table 28-1Meaning of the parameterin Fig. 28-12                         |      |
| Table 29-1Meaning of the parameter in Fig. 29-11                        |      |
| Table 29-1Meaning of the parameter in Fig. 29-11                        |      |
| Table 31-1 SDMMC IOMUX Settings                                         |      |
| Table 32-1 Management timing parameters                                 |      |
| Table 32-2 RMii timing parameters                                       |      |
| Table 32-3 RMII/MII Interface Description                               |      |
| Table 32-4 VMAC tx buffer descriptor                                    |      |
| Table 32-5 VMAC- rx buffer descriptor for VMAC                          | 1030 |
| Table 32-6 VMAC-rx buffer descriptor for CPU                            | 1033 |
| Table 33-1 HS-ADC interface timing parameter                            |      |
| Table 33-2 IOMUX configuration in ADC mode                              |      |
| Table 33-3 IOMUX configuration in GPS mode                              |      |
| Table 33-4 IOMUX configuration in TS mode                               |      |
| Table 35-1Meaning of the parameter in Fig.35-7                          |      |
| Table 35-2Meaning of the parameter in Fig.35-8                          |      |
| Table 35-3SPI interface description in master mode                      |      |
| Table 35-4SPI interface description in slave mode                       |      |
| Table 36-1 UART Interface Description                                   |      |
| Table 36-2 UART baud rate configuration                                 |      |
| Table 37-1 I2C timing parameters                                        |      |
| Table 37-2I2C Interface Description                                     |      |
| •                                                                       | 1124 |



| Table 45-1 RK30xx test mode list                     | 1141 |
|------------------------------------------------------|------|
| Table 45-2 RK30xx iomux for misc signal in test mode | 1142 |



### **Acronym Descriptions**



### **Chapter 1 Introduction**

RK30xx is a low power, high performance processor for mobile phones, personal mobile internet device and other digital multimedia applications, and integrates dual-coreCortex-A9 with separately NEONand FPU coprocessor.

Many embedded powerful hardware engines provide optimized performance for high-end application. RK30xx supports almost full-format video decoder by 1080p@60fps, also support H.264/MVC/VP8 encoder by 1080p@30fps, high-quality JPEG encoder/decoder, special image preprocessor and postprocessor .

Embedded 3D GPU makes RK30xx completely compatible with OpenGL ES2.0 and 1.1, OpenVG 1.1. Special 2D hardware engine with MMU will maximize display performance and provide very smoothly operation.

RK30xx has high-performance external memory interface(DDR3/LPDDR2/LVDDR3) capable of sustaining demanding memory bandwidths, also provides a complete set of peripheral interface to support very flexible applications as follows:

- 2 banks, 8bits/16bits Nor Flash/SRAM interface
- 8 banks, 8bits/16bits async Nand Flash, LBA Nand Flash and 8bits sync ONFI Nand Flash, allup to 60bits hardware ECC
- Totally 2GB memory space for 2 ranks, 16bits/32bits DDR3-800, LPDDR2-800, LVDDR3-800
- Totally 3-channels SD/MMC interface to support MMC4.41, SD3.0, SDIO3.0 or eMMC
- 2-channels TFT LCD interface with 5-layers and 3D-display, 1920x1080 maximum display size
- HDMI tx interface(ver1.4) to support 3D-video1080p@30Hz
- 2-channels, 8bits CCIR656 interface and 10bits/12bits raw data interface with image preprocessor
- Lots of audio interface : two 2ch I2S/PCM interface, one 8ch I2S/PCM interface and SPDIF tx interface
- One USB OTG 2.0 and one USB Host2.0 interface
- 10M/100M RMII interface
- High-speed ADC interface and TS stream interface
- Lots of low-speed peripheral interface : 5I2C, 4UART, 2SPI,4PWM

This document will provide guideline on how to use RK30xx correctly and efficiently. The chapter 1 and chapter 2 will introduce the features, block diagram, signal descriptions and system usage of RK30xx, the chapter 3 through chapter 45 will describe the full function of each module in detail.

#### 1.1 Features

#### 1.1.1 MicroProcessor

- Dual-core ARM Cortex-A9 MPCore processor, a high-performance, low-power and cached application processor
- Full implementation of the ARM architecture v7-A instruction set, ARM Neon Advanced SIMD (single instruction, multiple data) support for accelerated media and signal processing computation
- Superscalar, variable length, out-of-order pipeline with dynamic branch prediction, 8-stage pipeline
- Include VFPv3 hardware to support single and double-precision add, subtract, divide, multiply and accumulate, and square root operations
- SCU ensures memory coherency between the two CPUs

- Integrated timer and watchdog timer per CPU
- Integrated 32KB L1 instruction cache, 32KB L1 data cache with 4-way set associative
- 512KB unified L2 Cache
- Trustzone technology support
- Full coresight debug solution
  - Debug and trace visibility of whole systems
  - ETM trace support
  - Invasive and non-invasive debug
- 4 separate power domain to support internal power switch and externally turn on/off based on different application scenario

  - PD\_A9\_0:  $1^{st}$  Cortex-A9 + Neon + FPU + L1 I/D Cache PD\_A9\_1:  $2^{nd}$  Cortex-A9 + Neon + FPU + L1 I/D Cache
  - PD\_DBG: CoreSight-DK for Cortex-A9
  - PD\_SCU: SCU + L2 Cache controller
- One isolated voltage domain to support DVFS
- Maximum frequency can be up to 750MHz@1.0V, worst case or 1.1GHz@1.1V,typical case

#### 1.1.2 Memory Organization

- Internal on-chip memory
  - 10KB BootRom
  - 64KB internal SRAM for security and non-security access, detailed size is programmable
  - 256KB or 512KB internal SRAM shared with L2 Cache Memory
- External off-chip memory<sup>®</sup>
  - DDR3-800, 16/32bits data widths, 2 ranks, totally 2GB(max) address space, maximum address space for one rank is also 2GB.
  - LPDDR-400, 32bits data width, 2 ranks, totally 2GB(max) address space, maximum address space for one rank is also 2GB.
  - LPDDR2-800, 32bits data width, 2 ranks, totally 2GB(max) address space, maximum address space for one rank is also 2GB.
  - Async SRAM/Nor Flash, 8/16bits data width, 2banks, 1MB(max) address space per bank
  - Async Nand Flash(include LBA Nand), 8/16bits data width,8 banks,60bits ECC
  - Sync ONFI Nand Flash, 8bits data width, 8 banks, 60bits ECC

#### 1.1.3 Internal Memory

- Internal BootRom
  - Size: 10KB
  - Support system boot from the following device:
    - 8bits/16bits Async Nand Flash
    - 8bits ONFI Nand Flash
    - SPI0 interface
    - eMMC interface
  - Support system code download by the following interface:
    - **USB OTG interface**
    - **UARTO Interface**
- Internal SRAM
  - Size: 64KB
  - Support security and non-security access
  - Security or non-security space is software programmable

- Security space can be 0KB,4KB,8KB,12KB,16KB,...,60KB,64KB continuous size
- 256KB or 512KB internal SRAM shared with L2 Cache for Cortex-A9, size is configurable by software.

#### 1.1.4 External Memory or Storage device

- Dynamic Memory Interface (DDR3/LPDDR/LPDDR2)
  - Compatible with JEDEC standard DDR3/LPDDR/LPDDR2 SDRAM
  - Data rates up to 800Mbps(400MHz) for DDR3/LPDDR2 and up to 400Mbps(200MHz) for LPDDR
  - Support up to 2 ranks (chip selects), totally 2GB(max) address space, maximum address space for one rank is also 2GB, which is software-configurable.
  - 16bits/32bits data width is software programmable
  - 5 host ports with 64bits AXI bus interface for system access, AXI bus clock is asynchronous with DDR clock
  - Programmable timing parameters to support DDR3/LPDDR/LPDDR2
     SDRAM from various vendor
  - Advanced command reordering and scheduling to maximize bus utilization
  - Low power modes, such as power-down and self-refresh for DDR3/LPDDR/LPDDR2 SDRAM; clock stop and deep power-down for LPDDR/LPDDR2 SDRAM
  - Compensation for board delays and variable latencies through programmable pipelines
  - Embedded dynamic drift detection in the PHY to get dynamic drift compensation with the controller
  - Programmable output and ODT impedance with dynamic PVT compensation
  - Support one low-power work mode: power down DDR PHY and most of DDR IO except two cs and two cke output signals, make SDRAM still in self-refresh state to prevent data missing.
- Static Memory Interface (ASRAM/Nor Flash)
  - Compatible with standard async SRAM or Nor Flash
  - Support up to 2 banks (chip selects), maximum 1MB address space per bank
  - For bank0, 8bits/16bits data width is software programmable; For bank1, 16bits data width is fixed
  - Support separately data and address bus, also support shared data and address bus to save IO numbers

#### Nand Flash Interface

- Support 8bits/16bits async nand flash, up to 8 banks
- Support 8bits sync DDR nand flash, up to 8 banks
- Support LBA nand flash in async or sync mode
- Up to 60bits hardware ECC
- For DDR nand flash, support DLL bypass and 1/4 or 1/8 clock adjust, maximum clock rate is 75MHz
- For async nand flash, support configurable interface timing , maximum data rate is 16bit/cycle
- Embedded special DMA interface to do data transfer
- Also support data transfer together with general DMAC1 in SoC system

#### eMMC Interface

- Compatible with standard iNAND interface
- Support MMC4.41 protocol
- Provide eMMC boot sequence to receive boot data from external eMMC device
- Support combined single FIFO(32x32bits) for both transmit and receive operations
- Support FIFO over-run and under-run prevention by stopping card clock automatically
- Support CRC generation and error detection
- Embedded clock frequency division control to provide programmable baud rate
- Support block size from 1 to 65535Bytes
- 8bits data bus width

#### SD/MMC Interface

- Compatible with SD3.0, MMC ver4.41
- Support combined single FIFO(32x32bits) for both transmit and receive operations
- Support FIFO over-run and under-run prevention by stopping card clock automatically
- Support CRC generation and error detection
- Embedded clock frequency division control to provide programmable baud rate
- Support block size from 1 to 65535Bytes
- Data bus width is 4bits

#### 1.1.5 System Component

- CRU (clock & reset unit)
  - Support clock gating control for individual components inside RK30xx
  - One oscillator with 24MHz clock input and 4 embedded PLLs
  - Up to 1.5GHz clock output for all PLLs
  - Support global soft-reset control for whole SOC, also individual soft-reset for every components

#### PMU(power management unit)

- 7 work modes(slow mode, normal mode, idle mode, deep-idle mode, stop mode, sleep mode, power-off mode) to save power by different frequency or automatical clock gating control or power domain on/off control
- Lots of wakeup sources in different mode
- 3 separate voltage domains
- 9 separate power domains, which can be power up/down by software based on different application scenes

#### Timer

- 3 on-chip 32bits Timersin SoC with interrupt-based operation
- Provide two operation modes: free-running and user-defined count
- Support timer work state checkable
- Fixed 24MHz clock input

#### P\W/M

- Four on-chip PWMs with interrupt-based operation
- Programmable 4-bit pre-scalar from apb bus clock

- Embedded 32-bit timer/counter facility
- Support single-run or continuous-run PWM mode
- Provides reference mode and output various duty-cycle waveform

#### WatchDog

- 32 bits watchdog counter width
- Counter clock is from apb bus clock
- 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
- Totally 16 defined-ranges of main timeout period

#### Bus Architecture

- 64-bit multi-layer AXI/AHB/APB composite bus architecture
- 5 embedded AXI interconnect
  - ◆ CPU interconnect with three 64-bits AXI masters, two 64-bits AXI slaves, one 32-bits AHB master and lots of 32-bits AHB/APB slaves
  - ◆ PERI interconnect with two 64-bits AXI masters, one 64-bits AXI slave, one 32-bits AXI slave, four 32-bits AHB masters and lots of 32-bits AHB/APB slaves
  - ◆ Display interconnect with six 64-bits AXI masters and one 32-bits AHB slave
  - ◆ GPU interconnect with one 128-bits AXI master and one 32-bits APB slave ,they are point-to-point AXI-lite architecture
  - ◆ VCODEC interconnect also with one 64-bits AXI master and one 32-bits AHB slave ,they are point-to-point AXI-lite architecture
- For each interconnect with AXI/AHB/APB composite bus, clocks for AXI/AHB/APB domains are always synchronous, and different integer ratio is supported for them.
- Flexible different QoS solution to improve the utility of bus bandwidth

#### Interrupt Controller

- Support 3 PPI interrupt source and 76 SPI interrupt sources input from different components inside RK30xx
- Support 16 softwre-triggered interrupts
- Input interrupt level is fixed , only high-level sensitive
- Two interrupt outputs (nFIQ and nIRQ) separatelyfor each Cortex-A9, both are low-level sensitive
- Support different interrupt priority for each interrupt source, and they are always software-programmable

#### DMAC

- Micro-code programming based DMA
- The specific instruction set provides flexibility for programming DMA transfers
- Linked list DMA function is supported to complete scatter-gather transfer
- Support internal instruction cache
- Embedded DMA manager thread

- Support data transfer types with memory-to-memory, memory-to-peripheral, peripheral-to-memory
- Signals the occurrence of various DMA events using the interrupt output signals
- Mapping relationship between each channel and different interrupt outputs is software-programmable
- Two embedded DMA controller , DMAC0 is for cpu system, DMAC1 is for peri system
- DMAC0 features:
  - ♦ 6 channels totally
  - ◆ 11 hardware request from peripherals
  - ◆ 2 interrupt output
  - ◆ Dual APB slave interface for register config, designated as secure and non-secure
  - Support trustzone technology and programmable secure state for each DMA channel
- DMAC1 features:
  - 7 channels totally
  - ♦ 13 hardware request from peripherals
  - ◆ 2 interrupt output
  - Not support trustzone technology

#### Security system

- Support trustzone technology for the following components inside RK30xx
  - Cortex-A9, support security and non-security mode, switch by software
  - ◆ DMAC0, support some dedicated channels work only in security mode
  - eFuse, only accessed by Cortex-A9 in security mode
  - Internal memory, part of space is addressed only in security mode, detailed size is software-programmable together with TZMA(trustzone memory adapter) and TZPC(trustzone protection controller)

#### 1.1.6 Video CODEC

- Shared internal memory and bus interface for video decoder and encoder<sup>®</sup>
- Video Decoder
  - Real-time video decoder of MPEG-1, MPEG-2, MPEG-4,H.263, H.264,AVS, VC-1, RV, VP6/VP8, Sorenson Spark, MVC
  - Error detection and concealment support for all video formats
  - Output data format is YUV420 semi-planar, and YUV400(monochrome) is also supported for H.264

H.264 up to HP level 4.2 : 1080p@60fps (1920x1088)<sup>®</sup>
 MPEG-4 up to ASP level 5 : 1080p@60fps (1920x1088)
 MPEG-2 up to MP : 1080p@60fps (1920x1088)

■ MPEG-1 up to MP : 1080p@60fps (1920x1088) ■ H.263 : 576p@60fps (720x576)

■ Sorenson Spark : 1080p@60fps (1920x1088)
■ VC-1 up to AP level 3 : 1080p@30fps (1920x1088)
■ RV8/RV9/RV10 : 1080p@60fps (1920x1088)

■ VP6/VP8 : 1080p@60fps (1920x1088)
■ AVS : 1080p@60fps (1920x1088)
■ MV6

■ MVC : 1080p@60fps (1920x1088)

## Rockchip RK30xxTechnical Reference ManualRev2.0

- For AVS, 4:4:4 sampling not supported
- For H.264, Image cropping not supported
- For MPEG-4,GMC(global motion compensation) not supported
- For VC-1, upscaling and range mapping are supported in image post-processor
- For MPEG-4 SP/H.263/Sorenson spark, using a modified H.264 in-loop filter to implement deblocking filter in post-processor unit

#### Video Encoder

- Support video encoder for H.264 (<u>BP@level4.0</u>, <u>MP@level4.0</u>, <u>HP@level4.0</u>), MVC and VP8
- Only support I and P slices, not B slices
- Support error resilience based on constrained intra prediction and slices
- Input data format :
  - ◆ YCbCr 4:2:0 planar
  - ♦ YCbCr 4:2:0 semi-planar
  - ◆ YCbYCr 4:2:2
  - ♦ CbYCrY 4:2:2 interleaved
  - ♦ RGB444 and BGR444
  - ◆ RGB555 and BGR555
  - ♦ RGB565 and BGR565
  - ◆ RGB888 and BRG888
  - ◆ RGB101010 and BRG101010
- Image size is from 96x96 to 1920x1088(Full HD)
- Maximum frame rate is up to 30fps@1920x1080®
- Bit rate supported is from 10Kbps to 20Mbps

#### 1.1.7 JPEG CODEC

- JPEG decoder
  - Input JPEG file: YCbCr 4:0:0, 4:2:0, 4:2:2, 4:4:0, 4:1:1 and 4:4:4 sampling formats
  - Output raw image: YCbCr 4:0:0, 4:2:0, 4:2:2, 4:4:0, 4:1:1 and 4:4:4 semi-planar
  - Decoder size is from 48x48 to 8176x8176(66.8Mpixels)
  - Maximum data rate<sup>®</sup> is up to 76million pixels per second

#### JPEG encoder

- Input raw image :
  - ◆ YCbCr 4:2:0 planar
  - ♦ YCbCr 4:2:0 semi-planar
  - ♦ YCbYCr 4:2:2
  - ◆ CbYCrY 4:2:2 interleaved
  - ◆ RGB444 and BGR444
  - ◆ RGB555 and BGR555
  - ◆ RGB565 and BGR565
  - ◆ RGB888 and BRG888
- ◆ RGB101010 and BRG101010
- Output JPEG file: JFIF file format 1.02 or Non-progressive JPEG
- Encoder image size up to 8192x8192(64million pixels) from 96x32
- Maximum data rate<sup>®</sup> up to 90million pixels per second

#### 1.1.8 Image Enhancement

Image pre-processor

- Only used together with HD video encoder inside RK30xx , not support stand-alone mode
- Provides RGB to YCbCr 4:2:0 color space conversion, compatible with BT.601 , BT.709 or user defined coefficients
- Provides YCbCr4:2:2 to YCbCr4:2:0 color space conversion
- Support cropping operation from 8192x8192 to any supported encoding size
- Support rotation with 90 or 270 degrees
- Video stabilization
  - Work in combined mode with HD video encoder inside RK30xx and stand-alone mode
  - Adaptive motion compensation filter
  - Support scene detection from video sequence, encodes key frame when scene change noticed
- Image post-processor(embedded inside video decoder)
  - Combined with HD video decoder and JPEG decoder, post-processor can read input data directly from decoder output to reduce bus bandwidth
  - Also work as a stand-alone mode, its input data is from a camera interface or other image data stored in external memory
  - Input data format :
    - ◆ any format generated by video decoder in combined mode
    - ♦ YCbCr 4:2:0 semi-planar
    - ◆ YCbCr 4:2:0 planar
    - ♦ YCbYCr 4:2:2
    - ♦ YCrYCb 4:2:2
    - ◆ CbYCrY 4:2:2
    - ◆ CrYCbY 4:2:2
  - Ouput data format:
    - ♦ YCbCr 4:2:0 semi-planar
    - ◆ YCbYCr 4:2:2
    - ◆ YCrYCb 4:2:2
    - ◆ CbYCrY 4:2:2
    - ◆ CrYCbY 4:2:2
    - Fully configurable ARGB channel lengths and locations inside 32bits, such as ARGB8888,RGB565,ARGB4444 etc.
  - Input image size:
    - ◆ Combined mode: from 48x48 to 8176x8176 (66.8Mpixels)
    - ◆ Stand-alone mode: width from 48 to 8176, height from 48 to 8176, and maximum size limited to 16.7 Mpixels
    - ♦ Step size is 16 pixels
  - Output image size: from 16x16 to 1920x1088 (horizontal step size 8,vertical step size 2)
  - Support image up-scaling:
    - Bicubic polynomial interpolation with a four-tap horizontal kernel and a two-tap vertical kernel
    - ◆ Arbitrary non-integer scaling ratio separately for both dimensions
    - ◆ Maximum output width is 3x input width
    - ◆ Maximum output height is 3x input height
  - Support image down-scaling:
    - ◆ Arbitrary non-integer scaling ratio separately for both dimensions
    - ◆ Unlimited down-scaling ratio
  - Support YUV to RGB color conversioin, compatible with BT.601-5,

BT.709 and user definable conversion coefficient

- Support dithering (2x2 ordered spatial dithering for 4,5,6bit RGB channel precision
- Support programmable alpha channel and alpha blending operation with the following overlay input formats:
  - ♦ 8bit alpha +YUV444, big endian channel order with AYUV8888
  - ♦ 8bit alpha +24bit RGB, big endian channel order with ARGB8888
- Support deinterlacing with conditional spatial deinterlace filtering, only compatible with YUV420 input format
- Support RGB image contrast / brightness / color saturation adjustment
- Support image cropping & digital zoom only for JPEG or stand-alone mode
- Support picture in pcture
- Support image rotation (horizontal flip, vertical flip, rotation 90,180 or 270 degrees)
- Image Post-Processor (IPP)(standalone)
  - memory to memory mode
  - input data format and size
    - ◆ RGB888 : 16x16 to 8191x8191
    - ◆ RGB565: 16x16 to 8191x8191
    - ♦ YUV422/YUV420 : 16x16 to 8190x8190
    - ◆ YUV444: 16x16 to 8190x8190
  - pre scaler
    - ♦ integer down-scaling(ratio: 1/2,1/3,1/4,1/5,1/6,1/7,1/8) with linear filter
    - ♦ deinterlace(up to 1080i) to support YUV422&YUV420 input format
  - nost scaler
    - ♦ down-scaling with 1/2 ~ 1 arbitary non-integer ratio
    - ◆ up-scaling with 1~4 arbitary non-integer ratio
    - ◆ 4-tap vertical, 2-tap horizontal filter
    - ◆ The max output image width of post scaler is 4096
  - Support rotation with 90/180/270 degrees and x-mirror,y-mirror

#### 1.1.9 Graphics Engine

- 3D Graphics Engine:
  - High performanceOpenGL ES1.1 and 2.0, OpenVG1.1 etc.
  - Embedded 4 shader cores with shared hierarchical tiler
  - Separate vertex(geometry) and fragment(pixel) processing for maximum parallel throughput
  - Provide MMU and L2 Cache with 128KB size
  - Triangle rate : 30M triangles/s
  - Pixel rate: 1.4G pixels/s @ 350MHz
- 2D Graphics Engine :
  - Pixel rate: 300M pixel/s without scale, 150M pixel/s with bilinear scale, 75M pixel/s with bicubic scale.
  - Bit Blit with Strength Blit, Simple Blit and Filter Blit
  - Color fill with gradient fill, and pattern fill
  - Line drawing with anti-aliasing and specified width
  - High-performance stretch and shrink
  - Monochrome expansion for text rendering
  - ROP2, ROP3, ROP4 full alpha blending and transparency
  - Alpha blending modes including Java 2 Porter-Duff compositing

blending rules, chroma key, and pattern mask

- 8K x 8K raster 2D coordinate system
- Arbitrary degrees rotation with anti-aliasing on every 2D primitive
- Programmable bicubic filter to support image scaling
- Blending, scaling and rotation are supported in one pass for stretch blit
- Source formats :
  - ◆ ABGR8888, XBGR888, ARGB8888, XRGB888
  - ◆ RGB888, RGB565
  - ◆ RGBA5551, RGBA4444
  - ♦ YUV420 planar, YUV420 semi-planar
  - ♦ YUV422 planar, YUV422 semi-planar
  - ♦ BPP8, BPP4, BPP2, BPP1
- Destination formats :
  - ABGR8888, XBGR888, ARGB8888, XRGB888
  - ◆ RGB888, RGB565
  - ◆ RGBA5551, RGBA4444
  - YUV420 planar, YUV420 semi-planar only in filter and pre-scale mode
  - YUV422 planar, YUV422 semi-planar only in filter and pre-scale mode

#### 1.1.10 Video IN/OUT

- Camera Interface
  - 2 independent camera interface controller
  - Support up to 5M pixels
  - 8bits CCIR656(PAL/NTSC) interface
  - 8bits/10bits/12bits raw data interface
  - YUV422 data input format with adjustable YUV sequence
  - YUV422,YUV420 output format with separately Y and UV space
  - Support picture in picture (PIP)
  - Support simple image effects such as Arbitrary(sepia), Negative, Art freeze, Embossing etc.
  - Support static histogram statistics and white balance statistics
  - Support image crop with arbitrary windows
  - Support scale up/down from 1/8 to 8 with arbitrary non-integer ratio

#### Display Interface

- 2 independent display controller
- Support LCD or TFT interfaces up to 1920x1080
- Support HDMI 1.4a output up to 1080p@30fps
- Support TV interface with ITU-R BT.656 (8bits, 480i/576i/1080i)
- Parallel RGB LCD Interface : RGB888(24bits),RGB666(18bits),RGB565(15bits)
- Serial RGB LCD Interface: 3x8bits with RGB delta support, 3x8bits followed by dummy data, 16bits followed by 8bits
- MCU LCD interface: i-8080 with up to 24bits RGB
- 5 display layers:
  - ◆ One background layer with programmable 24bits color
  - ◆ One video layer (win0)
    - RGB888, ARGB888, RGB565, YUV422, YUV420, AYUV
    - maximum resolution is 1920x1080
    - > 1/8 to 8 scaling up/down engine with arbitrary non-integer ratio
    - > 256 level alpha blending
    - Support transparency color key

- Support 3D display
- ♦ One video layer (win1)
  - RGB888, ARGB888, RGB565, YUV422, YUV420, AYUV
  - maximum resolution is 1920x1080
  - ► 1/8 to 8 scaling up/down engine with arbitrary non-integer ratio
  - > 256 level alpha blending
  - Support transparency color key
- One OSD layer(win2)
  - > RGB888, ARGB888, RGB565, 1/2/4/8BPP
  - > 256 level alpha blending
  - transparency color key
- Hardware cursor(win3)
  - ➤ 2BPP
  - Maximum resolution 64x64
  - > 3-color and transparent mode
  - 2-color + transparency + tran\_invert mode
  - 16 level alpha blending
- Support 180 rotation in combined mode with LCDC or separately mode
- 3 x 256 x 8 bits display LUTs
- Win0 and Win1 layer overlay exchangeable
- Support color space conversion :
  - YUV2RGB(rec601-mpeg/rec601-jpeg/rec709) and RGB2YUV
- Deflicker support for interlace output
- Support replication(16bits to 24bits) and dithering(24bits to 16bits/ 18bits) operation

#### HDMI TX Interface

- HDMI version 1.4a, HDCP revision 1.4 and DVI version 1.0 compliant transmitter
- Supports DTV from 480i to 1080i/p HD resolution, and PC from VGA to UXGA by LCDC0 or LCDC1 in RK30xx
- Supports 3D and 2k x 4k video resolution output
- Programmable 2-way color space converter
- Compliant with EIA/CEA-861D
- Deep color supported up to 12bit per pixel.
- xvYCC Enhanced Colorimetry
- Gamut Metadata transmission
- Supports RGB, YCbCr digital video input format includes ITU.656
- 36bit RGB/YCbCr 4:4:4
  - 16/20/24bit YCbCr 4:2:2
  - 8/10/12bit YCbCr 4:2:2 (ITU.601 and 656)
- Supports standard SPDIF for stereo or compressed audio up to 192KHz by SPDIF controller in RK30xx
- Support PCM, Dolby digital, DTS digital audio transmission through 8ch I2S controller in RK30xx
- Wide range channel speed up to 2.2Gbps

#### 1.1.11 Audio Interface

- I2S/PCM with 8ch
  - Up to 8 channels (4xTX, 2xRX)
  - Audio resolution from 16bits to 32bits
  - Sample rate up to 192KHz
  - Provides master and slave work mode, software configurable
  - Support 3 I2S formats (normal , left-justified , right-justified)

- Support 4 PCM formats(early , late1 , late2 , late3)
- I2S and PCM mode cannot be used at the same time
- I2S/PCM with 2ch
  - 2 independent I2S/PCM interface with 2 channels
  - Up to 2 channels (2xTX, 2xRX)
  - Audio resolution from 16bits to 32bits
  - Sample rate up to 192KHz
  - Provides master and slave work mode, software configurable
  - Support 3 I2S formats (normal, left-justified, right-justified)
  - Support 4 PCM formats(early , late1 , late2 , late3)
  - I2S and PCM mode cannot be used at the same time

#### SPDIF

- Audio resolution: 16bits/20bits/24bits
- Software configurable sample rates (48KHz, 44.1KHz, 32KHz)
- Stereo voice replay with 2 channels

#### 1.1.12 Connectivity

- SDIO interface
  - Compatible with SDIO 3.0 protocol
  - Support FIFO over-run and under-run prevention by stopping card clock automatically
  - 4bits data bus widths
- High-speed ADC & TS stream interface
  - Support single-channel 8bits/10bits interface
  - DMA-based and interrupt-based operation
  - Support 8bits TS stream interface
  - Support PID filter operation
    - Combined with high-speed ADC interface to implement filter from original TS data
    - ◆ Provide PID filter up to 64 channels PID simultaneously
    - ◆ Support sync-byte detection in transport packet head
    - ◆ Support packet lost mechanism in condition of limited bandwidth
- MAC 10/100MEthernet Controller
  - IEEE802.3u compliant Ethernet Media Access Controller(MAC)
  - Support only RMII(Reduced MII) mode
  - 10Mbps and 100Mbps compatible
  - Automatic retry and automatic collision frame deletion
  - Full duplex support with flow-control
  - Address filtering(broadcast, multicast, logical, physical)
  - Clock can be from RK30xx or external ethernet PHY

#### SPI Controller

- 2 on-chip SPI controller inside RK30xx
- Support serial-master and serial-slave mode, software-configurable
- DMA-based or interrupt-based operation
- Embedded two 32x16bits FIFO for TX and RX operation respectively
- Support 2 chip-selects output in serial-master mode

#### Uart Controller

■ 4 on-chip uart controller inside RK30xx

- DMA-based or interrupt-based operation
- For UART1/UART2/UART3, Embedded two 32Bytes FIFO for TX and RX operation respectively
- For UARTO, two 64Bytes FIFOs are embedded for TX/RX operation
- Support 5bit,6bit,7bit,8bit serial data transmit or receive
- Standard asynchronous communication bits such as start, stop and parity
- Support different input clock for uart operation to get up to 4Mbps or other special baud rate
- Support non-integer clock divides for baud clock generation
- Auto flow control mode is only for UART0, UART1, UART2

#### I2C controller

- 5 on-chip I2C controller in RK30xx
- Multi-master I2C operation
- Support 7bits and 10bits address mode
- Software programmable clock frequency and transfer rate up to 400Kbit/s in the fast mode
- Serial 8bits oriented and bidirectional data transfers can be made at up to 100Kbit/s in the standard mode

#### GPIO

- 6 groups of GPIO (GPIO0~GPIO4, GPIO6), 32 GPIOs per group in GPIO0~GPIO4, and 16GPIOs in GPIO6, totally have 176 GPIOs
- All of GPIOs can be used to generate interrupt to Cortex-A9
- GPIO6 can be used to wakeup system from stop/sleep/power-off mode
- All of pullup GPIOs are software-programmable for pullup resistor or not
- All of pulldown GPIOs are software-programmable for pulldown resistor or not
- All of GPIOs are always in input direction in default after power-on-reset

#### • USB Host2.0

- Compatible with USB Host2.0 specification
- Supports high-speed(480Mbps), full-speed(12Mbps) and low-speed(1.5Mbps) mode
- Provides 16 host mode channels
- Support periodic out channel in host mode

#### USB OTG2.0

- Compatible with USB OTG2.0 specification
- Supports high-speed(480Mbps), full-speed(12Mbps) and low-speed(1.5Mbps) mode
- Support up to 9 device mode endpoints in addition to control endpoint 0
- Support up to 6 device mode IN endpoints including control endpoint 0
- Endpoints 1/3/5/7 can be used only as data IN endpoint
- Endpoints 2/4/6 can be used only as data OUT endpoint
- Endpoints 8/9 can be used as data OUT and IN endpoint
- Provides 9 host mode channels

#### 1.1.13 Others

- Temperature Sensor
  - 2 bipolar-based temperature-sensing cell embedded

- 2-channel 12-bits SAR ADC
- Temperature accuracy sensed is  $\pm 5$  degree
- SAR-ADC clock must be less than 50KHz
- Standby Current is about 180uA for analog and 40uA for digital logic
- Power Down Current is about 1uA for anolog and 5uA for digital logic
- SAR-ADC(Successive Approximation Register)
  - 4-channel single-ended 10-bit SAR analog-to-digital converter
  - Conversion speed range is up to 1 MSPS
  - SAR-ADC clock must be less than 1MHz
  - DNL is less than  $\pm 1$  LSB , INL is less than  $\pm 2.0$  LSB
  - Power down current is about 0.5uA for analog and digital logic
  - Power supply is 2.5V ( $\pm 10\%$ ) for analog interface
- eFuse
  - 256bits (32x8) high-density electrical Fuse
  - Programming condition : VDDQ must be  $2.5V(\pm 10\%)$
  - Program time is about  $10us(\pm 1us)$
  - Read condition: VDDQ must be 0V or floating
  - Support power-down and standby mode
- Operation Temperature Range
  - -40°C to +85°C
- Operation Voltage Range
  - Core supply: 1.1V ( $\pm 10\%$ )
  - IO supply: 3.3V or 2.5V or 1.8V (±10%)
- Process
  - TSMC 40nm LP
- Package Type
  - TFBGA453LD (body: 19mm x 19mm; ball size: 0.4mm; ball pitch: 0.8mm)
- Power
  - TBA®
- Notes: DDR3/LPDDR/LPDDR2 are not used simultaneously as well as async and sync ddr nand flash
- In RK30xx, Video decoder and encoder are not used simultaneously because of shared internal buffer
- <sup>®</sup> Actual maximum frame rate will depend on the clock frequency and system bus performance
  - <sup>®</sup> Actual maximum data rate will depend on the clock frequency and JPEG compression rate

## 1.2 Block Diagram

The following diagram shows the basic block diagram for RK30xx.



Fig. 1-1 RK30xx Block Diagram

## 1.3 Pin Description

In this chapter, the pin description will be divided into two parts, one is all power/ground descriptions in Table 1-1, include analog power/ground, another is all the function signals descriptions in Table 1-2, also include analog power/ground.

### 1.3.1 RK30xx power/ground IO descriptions

Table 1-1 RK30xx Power/Ground IO informations

|       | Tubic 1 1 it | ILD OAK I OWEI | / diodila lo l | mormations | _            |
|-------|--------------|----------------|----------------|------------|--------------|
| Group | Ball #       | Min(V)         | Typ(V)         | Max(V)     | Descriptions |

# RK30xxTechnical Reference ManualRev2.0

| GND M15,M16,N8,N9,N10,N11,N12, N/A N/A N/A                              | rnal Core Ground<br>Digital IO Ground |
|-------------------------------------------------------------------------|---------------------------------------|
|                                                                         |                                       |
| 0.99   1.1   1.21                                                       | rnal CPU Power<br>frequency <= 1GHz)  |
| AVDD TBD TBD TBD                                                        | rnal CPU Power<br>requency <= 1.4GHz) |
| TBD TBD TBD                                                             | rnal CPU Power<br>requency <= 600MHz) |
|                                                                         |                                       |
| CVDD 0.99 1.1 1.21                                                      | rnal Core Power<br>PU and PMU logic   |
|                                                                         | 21112                                 |
| PVDD         U13         0.99         1.1         1.21         Internal | PMU Domain Power                      |
| PVCC         V13         3         3.3         3.6         Digital GPIO | Power for PMU Domain                  |
|                                                                         |                                       |
| VDDIO0 K17 3 3.3 3.6                                                    | Stal OBIO Bassas                      |
| VDDIO1 H17 3 3.3 3.6                                                    | ital GPIO Power                       |
|                                                                         |                                       |
| LCD0_VCC0 K7 3 3.3 3.6                                                  |                                       |
| 1.62 1.8 1.98 LCDC                                                      | 0 Digital IO Power                    |
| LCD0_VCC1 J7 3 3.3 3.6                                                  |                                       |
| 1.62 1.8 1.98                                                           |                                       |
| 3 3.3 3.6                                                               |                                       |
| LCD1_VCC L7                                                             | 1 Digital IO Power                    |
|                                                                         |                                       |
| 3 3.3 3.6                                                               |                                       |
| CIF0_VCC M7 1.62 1.8 1.98 Camer                                         | a0 Digital IO Power                   |
|                                                                         |                                       |
| CIF1_VCC         N6         3         3.3         3.6         Camera    | a1 Digital IO Power                   |

# RK30xxTechnical Reference ManualRev2.0

|              |                      | 1.62  | 1.8  | 1.98  |                                   |
|--------------|----------------------|-------|------|-------|-----------------------------------|
|              |                      |       |      |       |                                   |
|              |                      | 3     | 3.3  | 3.6   |                                   |
| SMC_VCC      | R17                  | 1.62  | 1.8  | 1.98  | SMC Digital IO Power              |
|              |                      |       |      |       |                                   |
| FLACIL VOC   | NAT                  | 3     | 3.3  | 3.6   | N 151 1 51 1 10 5                 |
| FLASH_VCC    | N17                  | 1.62  | 1.8  | 1.98  | Nand Flash Digital IO Power       |
|              |                      |       |      |       |                                   |
| ADO VCC      | U16                  | 3     | 3.3  | 3.6   | 1964/LIADTO/CDIO Digital IO Dawar |
| AP0_VCC      | 016                  | 1.62  | 1.8  | 1.98  | I2S1/UART0/SDIO Digital IO Power  |
|              |                      |       |      |       |                                   |
| 171 1/00     | )/40                 | 3     | 3.3  | 3.6   |                                   |
| AP1_VCC      | V16                  | 1.62  | 1.8  | 1.98  | SPI0/UART1 Digital IO Power       |
|              |                      |       | •    |       |                                   |
|              | F40 F44 F44 F40 F47  | 1.425 | 1.5  | 1.575 | DDR3 Digital IO Power             |
| MVDD         | F10,F11,F14,F16,F17, | 1.28  | 1.35 | 1.45  | LVDDR3 Digital IO Power           |
|              | G10,G13,G14          | 1.14  | 1.2  | 1.30  | LPDDR2 Digital IO Power           |
|              |                      |       |      |       |                                   |
| AVSS_APLL    | T11                  | N/A   | N/A  | N/A   | ARM PLLAnalog Ground              |
| AVDD_APLL    | U10                  | 0.99  | 1.1  | 1.21  | ARM PLL Analog Power              |
|              |                      |       |      |       |                                   |
| AVSS_DPLL    | T12                  | N/A   | N/A  | N/A   | DDR PLL Analog Ground             |
| AVDD_DPLL    | U11                  | 0.99  | 1.1  | 1.21  | DDR PLLAnalog Power               |
|              |                      |       |      |       |                                   |
| AVSS_CGPLL   | T13                  | N/A   | N/A  | N/A   | CODEC/GENERAL                     |
| 7.V00_001 EE | 110                  | 14//  | 14/7 | 1077  | PLL Analog Ground                 |
| AVDD_CGPLL   | U12                  | 0.99  | 1.1  | 1.21  | CODEC/GENERAL                     |
|              |                      |       |      |       | PLL Analog Power                  |
|              |                      | T     |      |       |                                   |
| VDDA_SARADC  | V11                  | 2.25  | 2.5  | 2.75  | SAR-ADC/TS-ADC Analog Power       |
| VDDA_TSADC   |                      |       |      |       |                                   |
|              | , _                  |       |      |       |                                   |
| OTG_DVDD     | U14                  | 1.023 | 1.2  | 1.32  | USB OTG2.0/Host2.0 Digital Power  |
| HOST_DVDD    | <b>y</b>             |       |      |       |                                   |
| OTG_VDD25    | U15                  | 2.325 | 2.5  | 2.75  | USB OTG2.0/Host2.0 Analog Power   |
| HOST_VDD25   |                      |       |      |       |                                   |
| OTG_VDD33    | V14                  | 3.069 | 3.3  | 3.63  | USB OTG2.0/Host2.0 Analog Power   |
| HOST_VDD33   |                      |       |      |       |                                   |
|              |                      | 0.05  | 0.5  | 0.75  | Drogrom Davier County (as a Fire  |
| EFUSE_VDDQ   | W14                  | 2.25  | 2.5  | 2.75  | Program Power Supply for eFuse    |
|              |                      | 0     | 0    | 0     | Read Power Supply for eFuse       |
| HDML AVCC    | P2 P6 O5 O0 O0       | NI/A  | NI/A | NI/A  | HDMI Apolog Carried               |
| HDMI_AVSS    | B3,B6,C5,G8,G9       | N/A   | N/A  | N/A   | HDMI Analog Ground                |

| HDMI_AVDD | F8 | 2.25 | 2.5 | 2.75 | HDMI Analog Power Supply |
|-----------|----|------|-----|------|--------------------------|
| HDMI_VDD  | F7 | 0.99 | 1.1 | 1.21 | HDMI Analog Power Supply |
|           |    |      |     |      |                          |



### 1.3.2 RK30xx function IO descriptions

Table 1-2 RK3066 IO descriptions

| Table 1-2 RK3066 IO descriptions |        |                |             |                        |       |                   |       |          |                    |                     |
|----------------------------------|--------|----------------|-------------|------------------------|-------|-------------------|-------|----------|--------------------|---------------------|
| Pin Name                         | Ball # | func0          | func1       | func2                  | func3 | Pad               | Drive | pull up/ | Reset              | Power               |
|                                  |        |                |             |                        |       | bype <sup>①</sup> | 8     | down     | State <sup>®</sup> | supply <sup>®</sup> |
|                                  |        |                |             | Left Side <sup>®</sup> |       |                   |       |          |                    |                     |
| LCDC0_DATA[7]                    | E4     | LCDC0_DATA[7]  |             |                        |       | I/O               | 8     | N/A      | ļ                  |                     |
| LCDC0_DATA[8]                    | F4     | LCDC0_DATA[8]  |             |                        |       | I/O               | 8     | N/A      | I                  |                     |
| LCDC0_DATA[9]                    | E3     | LCDC0_DATA[9]  |             |                        |       | I/O               | 8     | N/A      | I                  |                     |
| LCDC0_DATA[10]                   | E2     | LCDC0_DATA[10] |             |                        |       | I/O               | 8     | N/A      | I                  |                     |
| LCDC0_DATA[11]                   | F3     | LCDC0_DATA[11] |             |                        |       | I/O               | 8     | N/A      | I                  |                     |
| LCDC0_DATA[12]                   | E1     | LCDC0_DATA[12] |             |                        |       | I/O               | 8     | N/A      | I                  |                     |
| LCDC0_DATA[13]                   | G5     | LCDC0_DATA[13] |             |                        |       | I/O               | 8     | N/A      | I                  |                     |
| LCDC0_DATA[14]                   | G4     | LCDC0_DATA[14] |             |                        |       | I/O               | 8     | N/A      | I                  | 1.000.1/000         |
| LCDC0_DATA[15]                   | G6     | LCDC0_DATA[15] |             |                        |       | I/O               | 8     | N/A      | I                  | LCD0_VCC0           |
| LCDC0_DATA[16]                   | F2     | LCDC0_DATA[16] |             |                        |       | I/O               | 8     | N/A      | I                  | LCD0_VCC1           |
| LCDC0_DATA[17]                   | G3     | LCDC0_DATA[17] |             |                        |       | I/O               | 8     | N/A      | I                  |                     |
| LCDC0_DATA[18]                   | G2     | LCDC0_DATA[18] |             |                        |       | I/O               | 8     | N/A      | I                  |                     |
| LCDC0_DATA[19]                   | G1     | LCDC0_DATA[19] |             |                        |       | I/O               | 8     | N/A      | I                  |                     |
| LCDC0_DATA[20]                   | H4     | LCDC0_DATA[20] |             |                        |       | I/O               | 8     | N/A      | I                  |                     |
| LCDC0_DATA[21]                   | НЗ     | LCDC0_DATA[21] |             |                        |       | I/O               | 8     | N/A      | I                  |                     |
| LCDC0_DATA[22]                   | H2     | LCDC0_DATA[22] |             |                        |       | I/O               | 8     | N/A      | I                  |                     |
| LCDC0_DATA[23]                   | H5     | LCDC0_DATA[23] |             |                        |       | I/O               | 8     | N/A      | I                  |                     |
| GPIO2_A[0]                       | H6     | GPIO2_A[0]     | lcdc1_data0 | smc_addr4              |       | I/O               | 8     | down     | I                  |                     |
| GPIO2_A[1]                       | J2     | GPIO2_A[1]     | lcdc1_data1 | smc_addr5              |       | I/O               | 8     | down     | I                  | LCD1_VCC            |
| GPIO2_A[2]                       | H1     | GPIO2_A[2]     | lcdc1_data2 | smc_addr6              |       | I/O               | 8     | down     | I                  |                     |

| GPIO2_B[5]     | J3 | GPIO2_B[5]     | lcdc1_data13 | smc_addr17 | hsadc_data8  | I/O | 8 | down | - 1 |          |
|----------------|----|----------------|--------------|------------|--------------|-----|---|------|-----|----------|
| GPIO2_B[6]     | K6 | GPIO2_B[6]     | lcdc1_data14 | smc_addr18 | ts_sync      | I/O | 8 | down | I   |          |
| GPIO2_B[7]     | K5 | GPIO2_B[7]     | lcdc1_data15 | smc_addr19 | hsadc_data7  | I/O | 8 | down |     |          |
| GPIO2_C[0]     | L5 | GPIO2_C[0]     | lcdc1_data16 | gps_clk    | hsadc_clkout | I/O | 8 | down | I   |          |
| GPIO2_C[1]     | K4 | GPIO2_C[1]     | lcdc1_data17 | smc_bls_n0 | hsadc_data6  | I/O | 8 | down | I   |          |
| GPIO2_C[2]     | K3 | GPIO2_C[2]     | lcdc1_data18 | smc_bls_n1 | hsadc_data5  | I/O | 8 | down | I   |          |
| GPIO2_C[3]     | K2 | GPIO2_C[3]     | lcdc1_data19 | spi1_clk   | hsadc_data0  | I/O | 8 | down | I   |          |
| GPIO2_C[4]     | K1 | GPIO2_C[4]     | lcdc1_data20 | spi1_csn0  | hsadc_data1  | I/O | 8 | down | I   |          |
| GPIO2_C[5]     | L1 | GPIO2_C[5]     | lcdc1_data21 | spi1_txd   | hsadc_data2  | I/O | 8 | down | I   |          |
| GPIO2_C[6]     | L2 | GPIO2_C[6]     | lcdc1_data22 | spi1_rxd   | hsadc_data3  | I/O | 8 | down | I   |          |
| GPIO2_C[7]     | L3 | GPIO2_C[7]     | lcdc1_data23 | spi1_csn1  | hsadc_data4  | I/O | 8 | down | I   |          |
| CIF0_DATAIN[2] | L6 | CIF0_DATAIN[2] |              |            |              | I   | 8 | down | I   |          |
| CIF0_DATAIN[3] | L4 | CIF0_DATAIN[3] |              |            |              | I   | 8 | down | I   |          |
| CIF0_DATAIN[4] | М3 | CIF0_DATAIN[4] |              |            |              | I   | 8 | down | I   |          |
| CIF0_DATAIN[5] | M2 | CIF0_DATAIN[5] |              |            |              | I   | 8 | down | I   |          |
| CIF0_DATAIN[6] | N1 | CIF0_DATAIN[6] |              |            |              | ı   | 8 | down | I   |          |
| CIF0_DATAIN[7] | N2 | CIF0_DATAIN[7] |              |            |              | I   | 8 | down | I   |          |
| CIF0_DATAIN[8] | N3 | CIF0_DATAIN[8] |              |            |              | I   | 8 | down | I   | CIEO VCC |
| CIF0_DATAIN[9] | P1 | CIF0_DATAIN[9] |              |            |              | ı   | 8 | down | I   | CIF0_VCC |
| CIF0_VSYNC     | N4 | CIF0_VSYNC     |              |            |              | I   | 8 | down | I   |          |
| CIF0_HREF      | P2 | CIF0_HREF      |              |            |              | I   | 8 | down | I   |          |
| CIF0_CLKIN     | P3 | CIF0_CLKIN     |              |            |              | I   | 8 | down | I   |          |
| GPIO1_B[3]     | R2 | GPIO1_B[3]     | cif0_clkout  |            |              | I/O | 4 | down | I   |          |
| GPIO1_B[4]     | R3 | GPIO1_B[4]     | cif0_data0   |            |              | I/O | 8 | down | I   |          |
| GPIO1_B[5]     | P4 | GPIO1_B[5]     | cif0_data1   |            |              | I/O | 8 | down | I   |          |

| GPIO1_B[6]    | T1   | GPIO1_B[6]    | cif0_data10 |                 |            | I/O | 8    | down | I    |          |
|---------------|------|---------------|-------------|-----------------|------------|-----|------|------|------|----------|
| GPIO1_B[7]    | T2   | GPIO1_B[7]    | cif0_data11 |                 |            | I/O | 8    | down | I    |          |
| GPIO3_A[2]    | T3   | GPIO3_A[2]    | i2c3_sda    |                 |            | I/O | 8    | up   |      |          |
| GPIO3_A[3]    | U1   | GPIO3_A[3]    | i2c3_scl    |                 |            | I/O | 8    | up   | I    |          |
| GPIO1_C[0]    | U2   | GPIO1_C[0]    | cif1_data2  | rmii_clkout     | rmii_clkin | I/O | 4    | down | I    |          |
| GPIO1_C[1]    | U3   | GPIO1_C[1]    | cif1_data3  | rmii_tx_en      |            | I/O | 4    | down | I    |          |
| GPIO1_C[2]    | V2   | GPIO1_C[2]    | cif1_data4  | rmii_txd1       |            | I/O | 4    | down | I    |          |
| GPIO1_C[3]    | V3   | GPIO1_C[3]    | cif1_data5  | rmii_txd0       |            | I/O | 4    | down | I    |          |
| GPIO1_C[4]    | T4   | GPIO1_C[4]    | cif1_data6  | rmii_rx_err     |            | I/O | 8    | down | I    |          |
| GPIO1_C[5]    | U4   | GPIO1_C[5]    | cif1_data7  | rmii_crs_dvalid |            | I/O | 8    | down | I    |          |
| GPIO1_C[6]    | W1   | GPIO1_C[6]    | cif1_data8  | rmii_rxd1       |            | I/O | 8    | down | I    |          |
| GPIO1_C[7]    | V4   | GPIO1_C[7]    | cif1_data9  | rmii_rxd0       |            | I/O | 8    | down | I    | CIF1_VCC |
| GPIO1_D[0]    | W2   | GPIO1_D[0]    | cif1_vsync  | mii_md          |            | I/O | 8    | down | I    |          |
| GPIO1_D[1]    | W3   | GPIO1_D[1]    | cif1_href   | mii_mdclk       |            | I/O | 8    | down | I    |          |
| GPIO1_D[2]    | W4   | GPIO1_D[2]    | cif1_clkin  |                 |            | I/O | 8    | down | I    |          |
| GPIO1_D[7]    | Y1   | GPIO1_D[7]    | cif1_clkout |                 |            | I/O | 4    | down | I    |          |
| GPIO1_D[6]    | Y2   | GPIO1_D[6]    | cif1_data11 |                 |            | I/O | 8    | down | I    |          |
| GPIO3_A[4]    | Y4   | GPIO3_A[4]    | i2c4_sda    |                 |            | I/O | 8    | up   | I    |          |
| GPIO3_A[5]    | Y3   | GPIO3_A[5]    | i2c4_scl    |                 |            | I/O | 8    | up   | I    |          |
|               |      |               |             | Bottom Side     |            |     |      |      |      |          |
| ARMP_power_   | V10  | 1.1V          |             |                 |            | Р   | N/A  | N/A  | N/A  |          |
| feedback      | V 10 | 1.1 V         |             |                 |            | Г   | IN/A | IN/A | IN/A |          |
| VDDA_SARADC   | V11  | 2.5V          |             |                 |            | AP  | N/A  | N/A  | N/A  | SARADC   |
| SARADC_AIN[2] | W7   | SARADC_AIN[2] |             |                 |            | Α   | N/A  | N/A  | N/A  | Domain   |
| SARADC_AIN[1] | W8   | SARADC_AIN[1] |             |                 |            | Α   | N/A  | N/A  | N/A  | Domain   |

|               |      |               |  |     |     |      | _   |            |
|---------------|------|---------------|--|-----|-----|------|-----|------------|
| SARADC_AIN[0] | W6   | SARADC_AIN[0] |  | Α   | N/A | N/A  | N/A |            |
| AVSS_CGPLL    | T13  | Analog Ground |  | AG  | N/A | N/A  | N/A |            |
| AVDD_CGPLL    | U12  | 1.1V          |  | AP  | N/A | N/A  | N/A |            |
| AVSS_APLL     | T11  | Analog Ground |  | AG  | N/A | N/A  | N/A | DLI Domoin |
| AVDD_APLL     | U10  | 1.1V          |  | AP  | N/A | N/A  | N/A | PLL Domain |
| AVDD_DPLL     | U11  | 1.1V          |  | AP  | N/A | N/A  | N/A |            |
| AVSS_DPLL     | T12  | Analog Ground |  | AG  | N/A | N/A  | N/A |            |
| CPU_PWROFF    | AB1  | CPU_PWROFF    |  | 0   | 8   | down | 0   |            |
| CORE_PWROFF   | AC1  | CORE_PWROFF   |  | 0   | 8   | down | 0   |            |
| GPIO6_B[0]    | W10  | GPIO6_B[0]    |  | I/O | 8   | down | I   |            |
| GPIO6_B[1]    | AB2  | GPIO6_B[1]    |  | I/O | 8   | down | I   |            |
| GPIO6_B[2]    | AA2  | GPIO6_B[2]    |  | I/O | 8   | down | I   |            |
| GPIO6_B[3]    | AC2  | GPIO6_B[3]    |  | I/O | 8   | down | I   |            |
| GPIO6_A[0]    | W11  | GPIO6_A[0]    |  | I/O | 8   | up   | I   |            |
| GPIO6_A[1]    | AA3  | GPIO6_A[1]    |  | I/O | 8   | up   | I   |            |
| GPIO6_A[2]    | AB3  | GPIO6_A[2]    |  | I/O | 8   | up   | I   | PVCC       |
| GPIO6_A[3]    | AA5  | GPIO6_A[3]    |  | I/O | 8   | up   | I   | PVCC       |
| GPIO6_A[4]    | Y5   | GPIO6_A[4]    |  | I/O | 8   | up   | I   |            |
| GPIO6_A[5]    | Y6   | GPIO6_A[5]    |  | I/O | 8   | up   | I   |            |
| CLK32K        | AA4  | CLK32K        |  | I   | N/A | down | I   |            |
| XIN24M        | AC11 | XIN24M        |  | I   | N/A | N/A  | I   |            |
| XOUT24M       | AB11 | XOUT24M       |  | 0   | N/A | N/A  | 0   |            |
| GPIO6_A[6]    | Y8   | GPIO6_A[6]    |  | I/O | 8   | up   | I   |            |
| GPIO6_A[7]    | AC4  | GPIO6_A[7]    |  | I/O | 8   | up   | I   |            |
| NPOR          | Y7   | NPOR          |  | ı   | 8   | N/A  | I   |            |

|              |        | i i          |               |           | 1 |     | i i  |      |      | 1          |
|--------------|--------|--------------|---------------|-----------|---|-----|------|------|------|------------|
| OTG_DVDD     | U14    | OTG_DVDD     |               |           |   | DP  | N/A  | N/A  | N/A  |            |
| OTG_ID       | AB4    | OTG_ID       |               |           |   | Α   | N/A  | N/A  | N/A  |            |
| OTG_VBUS     | AB5    | OTG_VBUS     |               |           |   | Α   | N/A  | N/A  | N/A  |            |
| OTG_VDD33    | V14    | OTG_VDD33    |               |           |   | AP  | N/A  | N/A  | N/A  |            |
| OTG_DP       | AC16   | OTG_DP       |               |           |   | Α   | N/A  | N/A  | N/A  |            |
| OTG_DM       | AB16   | OTG_DM       |               |           |   | Α   | N/A  | N/A  | N/A  | USB Domain |
| OTG_RKELVIN  | AA6    | OTG_RKELVIN  |               |           |   | Α   | N/A  | N/A  | N/A  |            |
| OTG_VDD25    | U15    | OTG_VDD25    |               |           |   | AP  | N/A  | N/A  | N/A  |            |
| HOST_DP      | AC17   | HOST_DP      |               |           |   | Α   | N/A  | N/A  | N/A  |            |
| HOST_DM      | AB17   | HOST_DM      |               |           |   | Α   | N/A  | N/A  | N/A  |            |
| HOST_RKELVIN | W13    | HOST_RKELVIN |               |           |   | Α   | N/A  | N/A  | N/A  |            |
| EELIGE VIDDO | 10/4/4 | EELIGE VIDDO |               |           |   | 4 D | NI/A | N1/A | N1/A | EFUSE      |
| EFUSE_VDDQ   | W14    | EFUSE_VDDQ   |               |           |   | AP  | N/A  | N/A  | N/A  | Domain     |
| GPIO1_A[4]   | AA7    | GPIO1_A[4]   | uart1_sin     | spi0_csn0 |   | I/O | 8    | up   | I    |            |
| GPIO1_A[5]   | AC5    | GPIO1_A[5]   | uart1_sout    | spi0_clk  |   | I/O | 8    | down | I    |            |
| GPIO1_A[6]   | AB6    | GPIO1_A[6]   | uart1_cts_n   | spi0_rxd  |   | I/O | 8    | up   | I    | AP1_VCC    |
| GPIO1_A[7]   | AB7    | GPIO1_A[7]   | uart1_rts_n   | spi0_txd  |   | I/O | 8    | up   | I    |            |
| GPIO4_B[7]   | AC7    | GPIO4_B[7]   | spi0_csn1     |           |   | I/O | 8    | up   | I    |            |
| GPIO3_D[2]   | AA8    | GPIO3_D[2]   | sdmmc1_int_n  |           |   | I/O | 8    | up   | I    |            |
| GPIO3_C[0]   | AB8    | GPIO3_C[0]   | sdmmc1_cmd    |           |   | I/O | 4    | up   | I    |            |
| GPIO3_C[1]   | AC8    | GPIO3_C[1]   | sdmmc1_data0  |           |   | I/O | 4    | up   | I    |            |
| GPIO3_C[2]   | AB9    | GPIO3_C[2]   | sdmmc1_data1  |           |   | I/O | 4    | up   | I    | AP0_VCC    |
| GPIO3_C[3]   | AA9    | GPIO3_C[3]   | sdmmc1_data2  |           |   | I/O | 4    | up   | I    |            |
| GPIO3_C[4]   | AA10   | GPIO3_C[4]   | sdmmc1_data3  |           |   | I/O | 4    | up   | I    |            |
| GPIO3_C[5]   | AA12   | GPIO3_C[5]   | sdmmc1_clkout |           |   | I/O | 4    | down | I    |            |

|            | 1    |            | 1                  | 1           | ı ı |     | 1 _ | 1    | 1 . | 1       |
|------------|------|------------|--------------------|-------------|-----|-----|-----|------|-----|---------|
| GPIO3_C[6] | Y10  | GPIO3_C[6] | sdmmc1_detect_n    |             |     | I/O | 8   | up   | ı   |         |
| GPIO3_C[7] | AA13 | GPIO3_C[7] | sdmmc1_write_prt   |             |     | I/O | 8   | down | I   |         |
| GPIO3_D[0] | Y13  | GPIO3_D[0] | sdmmc1_pwr_en      |             |     | I/O | 8   | down | 1   |         |
| GPIO3_D[1] | AA14 | GPIO3_D[1] | sdmmc1_backend_pwr |             |     | I/O | 8   | down |     |         |
| GPIO0_C[4] | Y14  | GPIO0_C[4] | i2s1_sdi           |             |     | I/O | 8   | down | I   |         |
|            |      |            |                    | Right Side  |     |     |     |      |     |         |
| GPIO0_C[0] | AC13 | GPIO0_C[0] | i2s1_clk           |             |     | I/O | 4   | down | I   |         |
| GPIO0_C[1] | AB13 | GPIO0_C[1] | i2s1_sclk          |             |     | I/O | 4   | down | I   |         |
| GPIO0_C[2] | AC14 | GPIO0_C[2] | i2s1_lrck_rx       |             |     | I/O | 4   | down | I   |         |
| GPIO0_C[3] | AB14 | GPIO0_C[3] | i2s1_lrck_tx       |             |     | I/O | 4   | down | I   |         |
| GPIO0_C[5] | AB15 | GPIO0_C[5] | i2s1_sdo           |             |     | I/O | 4   | down | I   | AP0_VCC |
| GPIO1_A[0] | AB12 | GPIO1_A[0] | uart0_sin          |             |     | I/O | 8   | up   | I   |         |
| GPIO1_A[1] | Y11  | GPIO1_A[1] | uart0_sout         |             |     | I/O | 8   | down | I   |         |
| GPIO1_A[2] | AA11 | GPIO1_A[2] | uart0_cts_n        |             |     | I/O | 8   | up   | I   |         |
| GPIO1_A[3] | AC10 | GPIO1_A[3] | uart0_rts_n        |             |     | I/O | 8   | up   | I   |         |
| GPIO4_C[0] | Y17  | GPIO4_C[0] | smc_data0          | trace_data0 |     | I/O | 4   | up   | I   |         |
| GPIO4_C[1] | W17  | GPIO4_C[1] | smc_data1          | trace_data1 |     | I/O | 4   | up   | I   |         |
| GPIO4_C[2] | W16  | GPIO4_C[2] | smc_data2          | trace_data2 |     | I/O | 4   | up   | I   |         |
| GPIO4_C[3] | T19  | GPIO4_C[3] | smc_data3          | trace_data3 |     | I/O | 4   | up   | I   |         |
| GPIO4_C[4] | V17  | GPIO4_C[4] | smc_data4          | trace_data4 |     | I/O | 4   | up   | I   | CMC VCC |
| GPIO4_C[5] | U19  | GPIO4_C[5] | smc_data5          | trace_data5 |     | I/O | 4   | up   | I   | SMC_VCC |
| GPIO4_C[6] | V19  | GPIO4_C[6] | smc_data6          | trace_data6 |     | I/O | 4   | down | I   |         |
| GPIO4_C[7] | W18  | GPIO4_C[7] | smc_data7          | trace_data7 |     | I/O | 4   | down | I   |         |
| GPIO4_D[0] | Y18  | GPIO4_D[0] | smc_data8          | trace_data8 |     | I/O | 4   | down | I   |         |
| GPIO4_D[1] | AA18 | GPIO4_D[1] | smc_data9          | trace_data9 |     | I/O | 4   | down | I   |         |

|               |      |               |              |              |     | - | -    |   |           |
|---------------|------|---------------|--------------|--------------|-----|---|------|---|-----------|
| GPIO4_D[2]    | W20  | GPIO4_D[2]    | smc_data10   | trace_data10 | I/O | 4 | down | 1 |           |
| GPIO4_D[3]    | AB18 | GPIO4_D[3]    | smc_data11   | trace_data11 | I/O | 4 | down | 1 |           |
| GPIO4_D[4]    | U18  | GPIO4_D[4]    | smc_data12   | trace_data12 | I/O | 4 | down | I |           |
| GPIO4_D[5]    | AC19 | GPIO4_D[5]    | smc_data13   | trace_data13 | I/O | 4 | down | ļ |           |
| GPIO4_D[6]    | Y20  | GPIO4_D[6]    | smc_data14   | trace_data14 | I/O | 4 | down |   |           |
| GPIO4_D[7]    | AA20 | GPIO4_D[7]    | smc_data15   | trace_data15 | I/O | 4 | down |   |           |
| GPIO0_C[7]    | AB20 | GPIO0_C[7]    | trace_ctl    | smc_addr3    | I/O | 4 | down | I |           |
| GPIO0_C[6]    | T18  | GPIO0_C[6]    | trace_clk    | smc_addr2    | I/O | 4 | down | I |           |
| GPIO0_D[5]    | AC20 | GPIO0_D[5]    | i2s2_sdo     | smc_addr1    | I/O | 4 | down | I |           |
| GPIO0_D[4]    | V21  | GPIO0_D[4]    | i2s2_sdi     | smc_addr0    | I/O | 4 | down | I |           |
| GPIO0_D[3]    | W21  | GPIO0_D[3]    | i2s2_lrck_tx | smc_adv_n    | I/O | 4 | up   | I |           |
| GPIO0_D[2]    | Y21  | GPIO0_D[2]    | i2s2_lrck_rx | smc_oe_n     | I/O | 4 | up   | I |           |
| GPIO0_D[0]    | P19  | GPIO0_D[0]    | i2s2_clk     | smc_csn0     | I/O | 4 | up   | I |           |
| GPIO0_D[1]    | P20  | GPIO0_D[1]    | i2s2_sclk    | smc_we_n     | I/O | 4 | up   | I |           |
| FLASH_DATA[0] | P18  | FLASH_DATA[0] | emmc_data0   |              | I/O | 8 | down | I |           |
| FLASH_DATA[1] | AA21 | FLASH_DATA[1] | emmc_data1   |              | I/O | 8 | down | I |           |
| FLASH_DATA[2] | AB21 | FLASH_DATA[2] | emmc_data2   |              | I/O | 8 | down | I |           |
| FLASH_DATA[3] | W22  | FLASH_DATA[3] | emmc_data3   |              | I/O | 8 | down | I |           |
| FLASH_DATA[4] | Y22  | FLASH_DATA[4] | emmc_data4   |              | I/O | 8 | down | I |           |
| FLASH_DATA[5] | V20  | FLASH_DATA[5] | emmc_data5   |              | I/O | 8 | down | I | FLASH_VCC |
| FLASH_DATA[6] | AA22 | FLASH_DATA[6] | emmc_data6   |              | I/O | 8 | down | I |           |
| FLASH_DATA[7] | AB22 | FLASH_DATA[7] | emmc_data7   |              | I/O | 8 | down | I |           |
| FLASH_RDY     | U20  | FLASH_RDY     |              |              | I/O | 8 | up   | I |           |
| FLASH_ALE     | T20  | FLASH_ALE     |              |              | 0   | 4 | down | 0 |           |
| FLASH_CLE     | AC22 | FLASH_CLE     |              |              | 0   | 4 | down | 0 |           |

| FLASH_RDN  | N20  | FLASH_RDN  |                  |               | 0       | 8 | up   | 0 |                  |
|------------|------|------------|------------------|---------------|---------|---|------|---|------------------|
| FLASH_WRN  | AC23 | FLASH_WRN  |                  |               | 0       | 8 | up   | 0 |                  |
| FLASH_WP   | AB23 | FLASH_WP   | emmc_pwr_en      |               | 0       | 4 | down | 0 |                  |
| FLASH_CSN0 | Y23  | FLASH_CSN0 |                  |               | 0       | 4 | up   | 0 |                  |
| GPIO4_B[0] | N18  | GPIO4_B[0] | flash_csn1       |               | I/O     | 4 | up   | I |                  |
| GPIO4_B[1] | U21  | GPIO4_B[1] | flash_csn2       | emmc_cmd      | I/O     | 4 | up   | I |                  |
| GPIO4_B[2] | P21  | GPIO4_B[2] | flash_csn3       | emmc_rstn_out | I/O     | 4 | up   | ı |                  |
| GPIO3_D[7] | N21  | GPIO3_D[7] | flash_dqs        | emmc_clkout   | I/O     | 8 | up   | ı |                  |
| GPIO3_B[6] | L20  | GPIO3_B[6] | sdmmc0_detect_n  |               | I/O     | 8 | up   | I |                  |
| GPIO3_B[7] | N19  | GPIO3_B[7] | sdmmc0_write_prt |               | I/O     | 8 | down | ı |                  |
| GPIO3_A[6] | W23  | GPIO3_A[6] | sdmmc0_rstn_out  |               | I/O     | 8 | up   | ı |                  |
| GPIO3_A[7] | V22  | GPIO3_A[7] | sdmmc0_pwr_en    |               | I/O     | 8 | down | ı |                  |
| GPIO3_B[0] | U22  | GPIO3_B[0] | sdmmc0_clkout    |               | I/O     | 4 | down | ı |                  |
| GPIO3_B[1] | P22  | GPIO3_B[1] | sdmmc0_cmd       |               | I/O     | 4 | up   | I |                  |
| GPIO3_B[2] | M21  | GPIO3_B[2] | sdmmc0_data0     |               | I/O     | 4 | up   | I |                  |
| GPIO3_B[3] | U23  | GPIO3_B[3] | sdmmc0_data1     |               | I/O     | 4 | up   | I | VCCIO0           |
| GPIO3_B[4] | T21  | GPIO3_B[4] | sdmmc0_data2     |               | I/O     | 4 | up   | ı | VCCIO0<br>VCCIO1 |
| GPIO3_B[5] | K20  | GPIO3_B[5] | sdmmc0_data3     |               | I/O     | 4 | up   | ı | VCCIO1           |
| GPIO0_A[7] | L21  | GPIO0_A[7] | i2s0_sdi         |               | I/O     | 8 | down | I |                  |
| GPIO0_B[0] | T22  | GPIO0_B[0] | i2s0_clk         |               | I/O     | 4 | down | I |                  |
| GPIO0_B[1] | T23  | GPIO0_B[1] | i2s0_sclk        |               | I/O     | 4 | down | I |                  |
| GPIO0_B[2] | R22  | GPIO0_B[2] | i2s0_lrck_rx     |               | I/O     | 4 | down | ı |                  |
| GPIO0_B[3] | R21  | GPIO0_B[3] | i2s0_lrck_tx     |               | I/O     | 4 | down | I |                  |
| GPIO0_B[4] | K21  | GPIO0_B[4] | i2s0_sdo0        |               | I/O     | 4 | down | I |                  |
| GPIO0_B[5] | P23  | GPIO0_B[5] | i2s0_sdo1        |               | <br>I/O | 4 | down | ı |                  |

|            |      |            |                  |  |     | _ |      |   |
|------------|------|------------|------------------|--|-----|---|------|---|
| GPIO0_B[6] | N23  | GPIO0_B[6] | i2s0_sdo2        |  | I/O | 4 | up   | I |
| GPIO0_B[7] | M22  | GPIO0_B[7] | i2s0_sdo3        |  | I/O | 4 | up   | I |
| GPIO1_B[2] | L22  | GPIO1_B[2] | spdif_tx         |  | I/O | 4 | down | I |
| GPIO1_B[0] | N22  | GPIO1_B[0] | uart2_sin        |  | I/O | 8 | up   | I |
| GPIO1_B[1] | AB19 | GPIO1_B[1] | uart2_sout       |  | I/O | 8 | down | I |
| GPIO2_D[6] | L23  | GPIO2_D[6] | i2c1_sda         |  | I/O | 8 | up   | I |
| GPIO2_D[7] | K22  | GPIO2_D[7] | i2c1_scl         |  | I/O | 8 | up   | I |
| GPIO3_A[0] | K23  | GPIO3_A[0] | i2c2_sda         |  | I/O | 8 | up   | I |
| GPIO3_A[1] | Y19  | GPIO3_A[1] | i2c2_scl         |  | I/O | 8 | up   | I |
| GPIO3_D[3] | L19  | GPIO3_D[3] | uart3_sin        |  | I/O | 8 | up   | I |
| GPIO3_D[4] | K19  | GPIO3_D[4] | uart3_sout       |  | I/O | 8 | down | I |
| GPIO3_D[5] | K18  | GPIO3_D[5] | uart3_cts_n      |  | I/O | 8 | up   | I |
| GPIO3_D[6] | L18  | GPIO3_D[6] | uart3_rts_n      |  | I/O | 8 | up   | I |
| GPIO0_A[0] | AA19 | GPIO0_A[0] | hdmi_hot_plug_in |  | I/O | 8 | down | I |
| GPIO0_A[1] | Y16  | GPIO0_A[1] | hdmi_i2c_scl     |  | I/O | 8 | up   | I |
| GPIO0_A[2] | H19  | GPIO0_A[2] | hdmi_i2c_sda     |  | I/O | 8 | up   | I |
| GPIO0_A[3] | AA15 | GPIO0_A[3] | pwm0             |  | I/O | 8 | down | I |
| GPIO0_A[4] | H21  | GPIO0_A[4] | pwm1             |  | I/O | 8 | down | I |
| GPIO0_A[5] | J22  | GPIO0_A[5] | otg_drv_vbus     |  | I/O | 8 | down | I |
| GPIO0_A[6] | H18  | GPIO0_A[6] | host_drv_vbus    |  | I/O | 8 | down | I |
| GPIO0_D[6] | H20  | GPIO0_D[6] | pwm2             |  | I/O | 8 | down | I |
| GPIO0_D[7] | J21  | GPIO0_D[7] | pwm3             |  | I/O | 8 | down | I |
| TDO        | H22  | TDO        |                  |  | 0   | 8 | N/A  | 0 |
| TCK        | H23  | TCK        |                  |  | I   | 8 | up   | I |
| TRST_N     | G20  | TRST_N     |                  |  | I   | 8 | down | I |

|            |     |            |          |          |     | •     |     |     |      |
|------------|-----|------------|----------|----------|-----|-------|-----|-----|------|
| TDI        | G22 | TDI        |          |          |     | 8     | up  | I   |      |
| TMS        | G21 | TMS        |          |          | 1/9 | 8     | up  | I   |      |
| GPIO2_D[4] | G19 | GPIO2_D[4] | i2c0_sda |          | 1/0 | 8     | up  | I   |      |
| GPIO2_D[5] | G18 | GPIO2_D[5] | i2c0_scl |          | 1/0 | 8     | up  | I   |      |
| GPIO6_B[4] | G23 | GPIO6_B[4] |          |          | 1/0 | 8     | up  | I   |      |
|            |     |            |          | Top Side |     |       |     |     |      |
| DQ[7]      | F20 | DQ[7]      |          |          | 1/0 | ) N/A | N/A | I   |      |
| DQ[6]      | F22 | DQ[6]      |          |          | 1/0 | ) N/A | N/A | I   |      |
| DQ[5]      | F21 | DQ[5]      |          |          | 1/0 | ) N/A | N/A | I   |      |
| DQ[4]      | F19 | DQ[4]      |          |          | 1/0 | ) N/A | N/A | I   |      |
| DQS[0]     | E22 | DQS[0]     |          |          | 1/0 | ) N/A | N/A | ı   |      |
| DQS_B[0]   | E23 | DQS_B[0]   |          |          | 1/0 | ) N/A | N/A | ı   |      |
| DQ[3]      | E18 | DQ[3]      |          |          | 1/0 | ) N/A | N/A | ı   |      |
| DQ[2]      | E20 | DQ[2]      |          |          | 1/0 | ) N/A | N/A | I   |      |
| DQ[1]      | E21 | DQ[1]      |          |          | 1/0 | ) N/A | N/A | ı   |      |
| DQ[0]      | E17 | DQ[0]      |          |          | 1/0 | ) N/A | N/A | ı   | MVDD |
| DM[0]      | D23 | DM[0]      |          |          | 1/0 | ) N/A | N/A | ı   |      |
| VREF       | F13 | VREF       |          |          | F   | N/A   | N/A | N/A |      |
| DQ[23]     | D22 | DQ[23]     |          |          | 1/0 | ) N/A | N/A | ı   |      |
| DQ[22]     | D21 | DQ[22]     |          |          | 1/0 | ) N/A | N/A | ı   |      |
| DQ[21]     | B23 | DQ[21]     |          |          | 1/0 | ) N/A | N/A | I   |      |
| DQ[20]     | A23 | DQ[20]     |          |          | 1/0 | ) N/A | N/A | ı   |      |
| DQS[2]     | B22 | DQS[2]     |          |          | 1/0 | ) N/A | N/A | I   |      |
| DQS_B[2]   | A22 | DQS_B[2]   |          |          | 1/0 | ) N/A | N/A | I   | ]    |
| DQ[19]     | D17 | DQ[19]     |          |          | 1/0 | ) N/A | N/A | I   |      |

| DO[40] | 540 | DO[40] | 1 | 1 | I | l 40 | N/A | N1/A | Ι. |
|--------|-----|--------|---|---|---|------|-----|------|----|
| DQ[18] | E16 | DQ[18] |   |   |   | I/O  | N/A | N/A  | l  |
| DQ[17] | C22 | DQ[17] |   |   |   | I/O  | N/A | N/A  | I  |
| DQ[16] | B21 | DQ[16] |   |   |   | I/O  | N/A | N/A  | I  |
| DM[2]  | C21 | DM[2]  |   |   |   | I/O  | N/A | N/A  | I  |
| ZQ_PIN | G15 | ZQ_PIN |   |   |   | I/O  | N/A | N/A  | I  |
| ODT[1] | C20 | ODT[1] |   |   |   | 0    | N/A | N/A  | 0  |
| ODT[0] | B20 | ODT[0] |   |   |   | 0    | N/A | N/A  | 0  |
| A[14]  | D16 | A[14]  |   |   |   | 0    | N/A | N/A  | 0  |
| A[13]  | C19 | A[13]  |   |   |   | 0    | N/A | N/A  | 0  |
| A[12]  | D19 | A[12]  |   |   |   | 0    | N/A | N/A  | 0  |
| A[11]  | A20 | A[11]  |   |   |   | 0    | N/A | N/A  | 0  |
| A[10]  | D18 | A[10]  |   |   |   | 0    | N/A | N/A  | 0  |
| A[9]   | C18 | A[9]   |   |   |   | 0    | N/A | N/A  | 0  |
| A[8]   | B19 | A[8]   |   |   |   | 0    | N/A | N/A  | 0  |
| A[7]   | A19 | A[7]   |   |   |   | 0    | N/A | N/A  | 0  |
| A[6]   | B18 | A[6]   |   |   |   | 0    | N/A | N/A  | 0  |
| A[5]   | C17 | A[5]   |   |   |   | 0    | N/A | N/A  | 0  |
| CK     | B16 | CK     |   |   |   | 0    | N/A | N/A  | 0  |
| CK_B   | A16 | CK_B   |   |   |   | 0    | N/A | N/A  | 0  |
| A[4]   | B17 | A[4]   |   |   |   | 0    | N/A | N/A  | 0  |
| A[3]   | C15 | A[3]   |   |   |   | 0    | N/A | N/A  | 0  |
| A[2]   | E14 | A[2]   |   |   |   | 0    | N/A | N/A  | 0  |
| A[1]   | A17 | A[1]   |   |   |   | 0    | N/A | N/A  | 0  |
| A[0]   | B15 | A[0]   |   |   |   | 0    | N/A | N/A  | 0  |
| BA[2]  | C14 | BA[2]  |   |   |   | 0    | N/A | N/A  | 0  |

| BA[1]    | B14 | BA[1]    |  | 0   | N/A | N/A | 0 |
|----------|-----|----------|--|-----|-----|-----|---|
| BA[0]    | A14 | BA[0]    |  | 0   | N/A | N/A | 0 |
| RAS_B    | D14 | RAS_B    |  | 0   | N/A | N/A | 0 |
| CAS_B    | D13 | CAS_B    |  | 0   | N/A | N/A | 0 |
| WE_B     | C13 | WE_B     |  | 0   | N/A | N/A | 0 |
| CS_B[1]  | E13 | CS_B[1]  |  | 0   | N/A | N/A | 0 |
| CS_B[0]  | B13 | CS_B[0]  |  | 0   | N/A | N/A | 0 |
| CKE1     | D11 | CKE1     |  | 0   | N/A | N/A | 0 |
| CKE0     | A13 | CKE0     |  | 0   | N/A | N/A | 0 |
| RESET    | C12 | RESET    |  | 0   | N/A | N/A | 0 |
| DQ[15]   | B12 | DQ[15]   |  | I/O | N/A | N/A | I |
| DQ[14]   | C11 | DQ[14]   |  | I/O | N/A | N/A | I |
| DQ[13]   | E11 | DQ[13]   |  | I/O | N/A | N/A | I |
| DQ[12]   | D10 | DQ[12]   |  | I/O | N/A | N/A | I |
| DQS[1]   | B11 | DQS[1]   |  | I/O | N/A | N/A | I |
| DQS_B[1] | A11 | DQS_B[1] |  | I/O | N/A | N/A | I |
| DQ[11]   | B10 | DQ[11]   |  | I/O | N/A | N/A | I |
| DQ[10]   | A10 | DQ[10]   |  | I/O | N/A | N/A | I |
| DQ[9]    | C10 | DQ[9]    |  | I/O | N/A | N/A | I |
| DQ[8]    | В9  | DQ[8]    |  | I/O | N/A | N/A | I |
| DM[1]    | C9  | DM[1]    |  | I/O | N/A | N/A | I |
| DQ[31]   | C8  | DQ[31]   |  | I/O | N/A | N/A | I |
| DQ[30]   | E10 | DQ[30]   |  | I/O | N/A | N/A | I |
| DQ[29]   | D8  | DQ[29]   |  | I/O | N/A | N/A | I |
| DQ[28]   | E8  | DQ[28]   |  | I/O | N/A | N/A | I |

|               | •  |               |  | i . |     |     |     | •   | •           |
|---------------|----|---------------|--|-----|-----|-----|-----|-----|-------------|
| DQS[3]        | B8 | DQS[3]        |  |     | I/O | N/A | N/A | 1   |             |
| DQS_B[3]      | A8 | DQS_B[3]      |  |     | I/O | N/A | N/A | I   |             |
| DQ[27]        | A7 | DQ[27]        |  |     | I/O | N/A | N/A | ļ   |             |
| DQ[26]        | В7 | DQ[26]        |  |     | I/O | N/A | N/A |     |             |
| DQ[25]        | D7 | DQ[25]        |  |     | I/O | N/A | N/A | I   |             |
| DQ[24]        | C7 | DQ[24]        |  |     | I/O | N/A | N/A | I   |             |
| DM[3]         | E7 | DM[3]         |  |     | I/O | N/A | N/A | I   |             |
| HDMI_VDDLA    | F7 | 1.1V          |  |     | AP  | N/A | N/A | N/A |             |
| HDMI_PVDD     | F8 | 2.5V          |  |     | AP  | N/A | N/A | N/A |             |
| HDMI_REXT     | C6 | HDMI_REXT     |  |     | Α   | N/A | N/A | N/A |             |
| HDMI_TXC_N    | B5 | HDMI_TXC_N    |  |     | Α   | N/A | N/A | N/A |             |
| HDMI_TXC      | A5 | HDMI_TXC      |  |     | Α   | N/A | N/A | N/A |             |
| HDMI_AVDD25   | F8 | 2.5V          |  |     | AP  | N/A | N/A | N/A | HDMI Domain |
| HDMI_TX0_N    | B4 | HDMI_TX0_N    |  |     | Α   | N/A | N/A | N/A |             |
| HDMI_TX0      | A4 | HDMI_TX0      |  |     | Α   | N/A | N/A | N/A |             |
| HDMI_TX1_N    | B2 | HDMI_TX1_N    |  |     | Α   | N/A | N/A | N/A |             |
| HDMI_TX1      | A2 | HDMI_TX1      |  |     | Α   | N/A | N/A | N/A |             |
| HDMI_TX2_N    | B1 | HDMI_TX2_N    |  |     | Α   | N/A | N/A | N/A |             |
| HDMI_TX2      | A1 | HDMI_TX2      |  |     | Α   | N/A | N/A | N/A |             |
| LCDC0_HSYNC   | D6 | LCDC0_HSYNC   |  |     | I/O | 4   | N/A | I   |             |
| LCDC0_DCLK    | E6 | LCDC0_DCLK    |  |     | I/O | 12  | N/A | I   |             |
| LCDC0_VSYNC   | D5 | LCDC0_VSYNC   |  |     | I/O | 4   | N/A | I   | 1 CD0 VCC0  |
| LCDC0_DEN     | D4 | LCDC0_DEN     |  |     | I/O | 4   | N/A | I   | LCD0_VCC0   |
| LCDC0_DATA[0] | C4 | LCDC0_DATA[0] |  |     | I/O | 8   | N/A | I   | 1           |
| LCDC0_DATA[1] | C3 | LCDC0_DATA[1] |  |     | I/O | 8   | N/A | I   |             |

| LCDC0_DATA[2] | C2 | LCDC0_DATA[2] |  | I/O | 8 | N/A | I |
|---------------|----|---------------|--|-----|---|-----|---|
| LCDC0_DATA[3] | D3 | LCDC0_DATA[3] |  | I/O | 8 | N/A | I |
| LCDC0_DATA[4] | D1 | LCDC0_DATA[4] |  | I/O | 8 | N/A | I |
| LCDC0_DATA[5] | F5 | LCDC0_DATA[5] |  | I/O | 8 | N/A | I |
| LCDC0_DATA[6] | D2 | LCDC0_DATA[6] |  | I/O | 8 | N/A | I |

#### Notes:

Pad types: I = input, O = output, I/O = input/output (bidirectional),

AP = Analog Power, AG = Analog Ground

DP = Digital Power, DG = Digital Ground

A = Analog

②: Output Drive Unit is mA , only Digital IO have drive value

®: Reset state : I = input without any pull resistor , O = output without any pull resistor

(It is die location. For examples, "Left side" means that all the related IOs are always in left side of die

©: Power supply means that all the related IOs is in these IO power domain. If multiple powers is included, they are connected together in one IO power ring

### 1.3.3 IO pin name descriptions

This sub-chapter will focus on the detailed function description of every pins based on different interface.

Table 1-3 RK30xx IO function description list

| Interface | Pin Name    | Direction | Description                                    |
|-----------|-------------|-----------|------------------------------------------------|
|           | XIN24M      | I         | Clock input of 24MHz crystal                   |
|           | XOUT24M     | 0         | Clock output of 24MHz crystal                  |
|           | CLK32K      | I         | Clock input of 32.768KHz                       |
| Misc      | CPU PWROFF  | 0         | Request signal to external PMIC for power down |
| MISC      | CPU_PWROFF  | U         | CPU subsystem with dual-core Cortex-A9         |
|           | CODE DWDOEF | 0         | Request signal to external PMIC for SoC Core   |
|           | CORE_PWROFF | 0         | logic w/o Cortex-A9 subsystem and PMU logic    |
|           | BTMODE      | I         | Chip boot device select (BootRom or Nor Flash) |
|           | NPOR        | I         | Power on reset for chip                        |

| Interface | Pin Name | Direction | Description                                          |  |  |  |  |
|-----------|----------|-----------|------------------------------------------------------|--|--|--|--|
|           | TRST_N   | I         | JTAG interface reset input                           |  |  |  |  |
|           | тск      | I         | JTAG interface clock input/SWD interface clock input |  |  |  |  |
| Debug     | TDI      | I         | JTAG interface TDI input                             |  |  |  |  |
|           | TMS      | I/O       | JTAG interface TMS input/SWD interface data out      |  |  |  |  |
|           | TDO      | 0         | JTAG interface TDO output                            |  |  |  |  |

| Interface | Pin Name            | Direction | Description                      |
|-----------|---------------------|-----------|----------------------------------|
|           | trace_clk           | 0         | Cortex-A8 ETM trace port clk     |
| ETM Trace | trace_ctl           | 0         | Cortex-A8 ETM trace port control |
|           | trace_datai(i=0~15) | 0         | Cortex-A8 ETM trace port data    |

| Interface                    | Pin Name                             | Direction | Description                                                         |
|------------------------------|--------------------------------------|-----------|---------------------------------------------------------------------|
|                              | sdmmc_clkout                         | 0         | sdmmc card clock.                                                   |
|                              | sdmmc_cmd                            | I/O       | sdmmc card command output and reponse input.                        |
| CD/MMC                       | sdmmc_data <i>i</i> ( <i>i</i> =0~3) | I/O       | sdmmc card data input and output.                                   |
| SD/MMC<br>Host<br>Controller | sdmmc_detect_n                       | I         | sdmmc card detect signal, a 0 represents presence of card.          |
| Controller                   | sdmmc_write_prt                      | I         | sdmmc card write protect signal, a 1 represents write is protected. |
|                              | sdmmc_rstn_out                       | 0         | sdmmc card reset signal                                             |
|                              | sdmmc_pwr_en                         | 0         | sdmmc card power-enable control signal                              |

| Interface  | Pin Name           | Direction | Description                                      |
|------------|--------------------|-----------|--------------------------------------------------|
|            | sdio_clkout        | 0         | sdio card clock.                                 |
|            | sdio_cmd           | I/O       | sdio card command output and reponse input.      |
|            | sdio_data <i>i</i> | 1/0       | edia card data input and output                  |
|            | ( <i>i</i> =0~3)   | I/O       | sdio card data input and output.                 |
|            | sdio_detect_n      | I         | sdio card detect signal, a 0 represents presence |
| SDIO Host  |                    | 1         | of card.                                         |
| Controller | adia unita ant     | I         | sdio card write protect signal, a 1 represents   |
|            | sdio_write_prt     | 1         | write is protected.                              |
|            | sdio_pwr_en        | 0         | sdio card power-enable control signal            |
|            | sdio_int_n         | 0         | sdio card interrupt indication                   |
|            | sdio_backend       | 0         | the back-end power supply for embedded device    |

| Interface         | Pin Name                            | Direction | Description                                 |
|-------------------|-------------------------------------|-----------|---------------------------------------------|
|                   | emmc_clkout                         | 0         | emmc card clock.                            |
|                   | emmc_cmd                            | I/O       | emmc card command output and reponse input. |
| eMMC<br>Interface | emmc_data <i>i</i> ( <i>i</i> =0~7) | I/O       | emmc card data input and output.            |
|                   | emmc_pwr_en                         | 0         | emmc card power-enable control signal       |
|                   | emmc_rstn_out                       | 0         | emmc card reset signal                      |

| Interface | Pin Name                      | Direction | Description                                    |
|-----------|-------------------------------|-----------|------------------------------------------------|
|           | CK                            | 0         | Active-high clock signal to the memory device. |
|           | CK_B                          | 0         | Active-low clock signal to the memory device.  |
|           | CKE <i>i</i> ( <i>i</i> =0,1) | 0         | Active-high clock enable signal to the memory  |
|           | CKL/ (/=0,1)                  | O         | device for two chip select.                    |
|           | CS Bi (i=0.1)                 | 0         | Active-low chip select signal to the memory    |
|           | CS_Bi (i=0,1)                 | O         | device. AThere are two chip select.            |
|           | RAS B                         | 0         | Active-low row address strobe to the memory    |
|           | KAS_B                         | U         | device.                                        |
| DMC       | CAS_B                         | 0         | Active-low column address strobe to the memory |
|           |                               |           | device.                                        |
|           | WE_B                          | 0         | Active-low write enable strobe to the memory   |
|           |                               | O         | device.                                        |
|           | BA[2:0]                       | 0         | Bank address signal to the memory device.      |
|           | A[15:0]                       | 0         | Address signal to the memory device.           |
|           | DQ[31:0]                      | I/O       | Bidirectional data line to the memory device.  |
|           | DOC[3:0]                      | 1/0       | Active-high bidirectional data strobes to the  |
|           | DQS[3:0]                      | I/O       | memory device.                                 |

| DQS_B[3:0]                         | I/O | Active-low bidirectional data strobes to the memory device. |
|------------------------------------|-----|-------------------------------------------------------------|
| DM[3:0]                            | 0   | Active-low data mask signal to the memory device.           |
| ODTi (i=0,1)                       | 0   | On-Die Termination output signal for two chip select.       |
| RET_EN                             | I   | Active-low retention latch enable input                     |
| RESET                              | 0   | DDR3 reset signal to the memory device                      |
| VREF <i>i</i> ( <i>i</i> =0,1,2,3) | I/O | Reference Voltage input for three regions of DDR IO         |
| ZQ_PIN                             | I/O | ZQ calibration pad which connects 240ohm $\pm 1\%$ resistor |

| Interface | Pin Name                            | Direction | Description                                 |
|-----------|-------------------------------------|-----------|---------------------------------------------|
|           | smc_oe_n                            | 0         | SMC output enable signal.                   |
|           | smc_bls_n <i>i</i> ( <i>i</i> =0,1) | 0         | SMC byte lane strobe signal for two bytes.  |
|           | smc_we_n                            | 0         | SMC write enable signal.                    |
| SMC       | smc_csni (i=0,1)                    | 0         | SMC chip enable signal.                     |
|           | smc_adv_n                           | 0         | SMC address valid signal in shared mode     |
|           | smc_addr <i>i</i> ( <i>i</i> =0~19) | 0         | SMC address signal.                         |
|           | smc_data <i>i</i> ( <i>i</i> =0~15) | I/O       | SMC directional data line to memory device. |

| Interface | Pin Name             | Direction | Description                                     |
|-----------|----------------------|-----------|-------------------------------------------------|
|           | FLASH_WP             | 0         | Flash write-protected signal                    |
|           | FLASH_ALE            | 0         | Flash address latch enable signal               |
|           | FLASH_CLE            | 0         | Flash command latch enable signal               |
|           | FLASH_WRN            | 0         | Flash write enable and clock signal             |
|           | FLASH_RDN            | 0         | Flash read enable and write/read signal         |
| NandC     | FLASH_DATA[i](i=0~7) | I/O       | Low 8bits of flash data inputs/outputs signal   |
|           | flash_datai(i=8~15)  | I/O       | High 8bits of flash data inputs/outputs signal  |
|           | flash_dqs            | I/O       | Flash data strobe signal                        |
|           | FLASH_RDY            | I         | Flash ready/busy signal                         |
|           | FLASH0_CSN           | 0         | Flash chip enable signal for chip 0             |
|           | flash_csni(i=1~7)    | 0         | Flash chip enable signal for chip i, $i=1\sim7$ |

| Interface | Pin Name            | Direction | Description                                           |
|-----------|---------------------|-----------|-------------------------------------------------------|
|           | hsadc_clkout        | 0         | hsadc/tsi/gps reference clock                         |
| HSADC     | hsadc_data <i>i</i> | I         | h d-(; 0 0)/h-;(; 0 7)/ d-t-(; 0 1)                   |
| Interface | ( <i>i</i> =0~9)    |           | hsadc(i=0 $\sim$ 9)/tsi(i=0 $\sim$ 7)/gps data(i=0,1) |
|           | ts_sync             | I         | ts synchronizer signal                                |

| Interface   | Pin Name                                  | Direction | Description                                                                                                                                                                                         |
|-------------|-------------------------------------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | i2s0_clk                                  | 0         | I2S/PCM0 clock source                                                                                                                                                                               |
|             | i2s0_sclk                                 | I/O       | I2S/PCM0 serial clock                                                                                                                                                                               |
| I2S/PCM0    | i2s0_lrck_rx                              | I/O       | I2S/PCM0 left & right channel signal for receiving serial data, synchronous left & right channel in I2S mode and the beginning of a group of left & right channels in PCM mode                      |
| Controller  | i2s0_sdi                                  | I         | I2S/PCM0 serial data input                                                                                                                                                                          |
| (8 channel) | i2s0_sdo <i>i</i><br>( <i>i</i> =0,1,2,3) | 0         | I2S/PCM0 serial data ouput                                                                                                                                                                          |
|             | i2s0_lrck_tx                              | I/O       | I2S/PCM0 left & right channel signal for transmitting serial data, synchronous left & right channel in I2S mode $(i=0)$ and the beginning of a group of left & right channels in PCM mode $(i=0,1)$ |

| Interface   | Pin Name     | Direction | Description                                                                                                                                                                       |
|-------------|--------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | i2s1_clk     | 0         | I2S/PCM1 clock source                                                                                                                                                             |
|             | i2s1_sclk    | I/O       | I2S/PCM1 serial clock                                                                                                                                                             |
| I2S/PCM1    | i2s1_lrck_rx | I/O       | I2S/PCM1 left & right channel signal for receiving serial data, synchronous left & right channel in I2S mode and the beginning of a group of left & right channels in PCM mode    |
|             | i2s1_sdi     | I         | I2S/PCM1 serial data input                                                                                                                                                        |
| (2 channel) | i2s1_sdo     | 0         | I2S/PCM1 serial data ouput                                                                                                                                                        |
|             | i2s1_lrck_tx | I/O       | I2S/PCM1 left & right channel signal for transmitting serial data, synchronous left & right channel in I2S mode and the beginning of a group of left & right channels in PCM mode |

| Interface   | Pin Name     | Direction | Description                                                                                                                                                                       |
|-------------|--------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | i2s2_clk     | 0         | I2S/PCM2 clock source                                                                                                                                                             |
|             | i2s2_sclk    | I/O       | I2S/PCM2 serial clock                                                                                                                                                             |
| I2S/PCM2    | i2s2_lrck_rx | I/O       | I2S/PCM2 left & right channel signal for receiving serial data, synchronous left & right channel in I2S mode and the beginning of a group of left & right channels in PCM mode    |
| Controller  | i2s2_sdi     | I         | I2S/PCM2 serial data input                                                                                                                                                        |
| (2 channel) | i2s2_sdo     | 0         | I2S/PCM2 serial data ouput                                                                                                                                                        |
|             | i2s2_lrck_tx | I/O       | I2S/PCM2 left & right channel signal for transmitting serial data, synchronous left & right channel in I2S mode and the beginning of a group of left & right channels in PCM mode |

| Interface   | Pin Name | Direction | Description              |
|-------------|----------|-----------|--------------------------|
| SPDIF       | 110      |           |                          |
| transmitter | spdif_tx | O         | spdif biphase data ouput |

| Interface | Pin Name        | Direction | Description      |
|-----------|-----------------|-----------|------------------|
| SPI       | spix_clk(x=0,1) | I/O       | spi serial clock |

| Controller | $spix\_csny$ $(x=0,1)(y=0,1)$ | I/O | spi chip select signal,low active |
|------------|-------------------------------|-----|-----------------------------------|
|            | spix_txd(x=0,1)               | 0   | spi serial data output            |
|            | spix_rxd(x=0,1)               | I   | spi serial data input             |

| Interface | Pin Name         | Direction | Description                                     |
|-----------|------------------|-----------|-------------------------------------------------|
|           | LCDC0 DCLK       | 0         | LCDC0 RGB interface display clock out, MCU i80  |
|           | LCDC0_DCLK       | U         | interface RS signal                             |
|           | LCDC0 VCVNC      | 0         | LCDC0 RGB interface vertival sync pulse, MCU    |
|           | LCDC0_VSYNC      | U         | i80 interface CSN signal                        |
| LCDC0     | LCDC0_HSYNC      | 0         | LCDC0 RGB interface horizontial sync pulse, MCU |
|           |                  |           | i80 interface WEN signal                        |
|           | LCDCO DEN        | 0         | LCDC0 RGB interface data enable, MCU i80        |
|           | LCDC0_DEN        |           | interface REN signal                            |
|           | LCDC0_DATA[23:0] | I/O       | LCDC0 data output/input                         |

| Interface | Pin Name         | Direction | Description                                     |
|-----------|------------------|-----------|-------------------------------------------------|
|           |                  |           | LCDC1 RGB interface display clock out, MCU i80  |
|           | lcdc1_dclk       | 0         | interface RS signal                             |
|           | lede1 vevne      | 0         | LCDC1 RGB interface vertival sync pulse, MCU    |
|           | lcdc1_vsync      |           | i80 interface CSN signal                        |
| LCDC1     | lcdc1_hsync      | 0         | LCDC1 RGB interface horizontial sync pulse, MCU |
|           |                  |           | i80 interface WEN signal                        |
|           | lcdc1_den        | 0         | LCDC1 RGB interface data enable, MCU i80        |
|           |                  |           | interface REN signal                            |
|           | lcdc1_data[23:0] | I/O       | LCDC1 data output/input                         |

| Interface  | Pin Name         | Direction | Description                                     |
|------------|------------------|-----------|-------------------------------------------------|
|            | CIF0_CLKIN       | I         | Camera0 interface input pixel clock             |
|            | cif0_clkout      | 0         | Camera0 interface output work clock             |
|            | CIF0_VSYNC       | I         | Camera0 interface vertical sync signal          |
| Camera IF0 | CIF0_HREF        | I         | Camera0 interface horizontial sync signal       |
|            | cif0_data[1:0]   | I         | Camera0 interface low 2-bit input pixel data    |
|            | CIF0_DATAIN[9:2] | I         | Camera0 interface middle 8-bit input pixel data |
|            | cif0_data[11:10] | I         | Camera0 interface high 2-bit input pixel data   |

| Interface  | Pin Name    | Direction | Description                            |
|------------|-------------|-----------|----------------------------------------|
|            | cif1_clkin  | I         | Camera1 interface input pixel clock    |
| Camera IF1 | cif1_clkout | 0         | Camera1 interface output work clock    |
|            | cif1_vsync  | I         | Camera1 interface vertical sync signal |

| cif1_href       | I | Camera1 interface horizontial sync signal |
|-----------------|---|-------------------------------------------|
| cif1_data[11:0] | I | Camera1 interface 12-bit input pixel data |

| Interface | Pin Name        | Direction | Description                                   |
|-----------|-----------------|-----------|-----------------------------------------------|
|           | rmii_clkout     | 0         | RMII REC_CLK output                           |
|           | rmii_clkin      | I         | RMII REF_CLK input                            |
|           | rmii_tx_en      | 0         | rmii transfer enable                          |
|           | rmii_txd1       | 0         | rmii transfer data                            |
|           | rmii_txd0       | 0         | rmii transfer data                            |
| RMII      | rmii_rx_err     | I         | rmii receive error                            |
|           | rmii_crs_dvalid | I         | rmii carrier sense / receive data valid input |
|           | rmii_rxd1       | I         | rmii receive data                             |
|           | rmii_rxd0       | I         | rmii receive data                             |
|           | mii_md          | I/O       | mii management interface data                 |
|           | mii_mdclk       | 0         | mii management interface clock                |

| Interface | Pin Name | Direction | Description                   |
|-----------|----------|-----------|-------------------------------|
| PWM       | pwm3     | 0         | Pulse Width Modulation output |
|           | pwm2     | 0         | Pulse Width Modulation output |
|           | pwm1     | 0         | Pulse Width Modulation output |
|           | pwm0     | 0         | Pulse Width Modulation output |

| Interface | Pin Name | Direction | Description |
|-----------|----------|-----------|-------------|
|           | i2c0_sda | I/O       | I2C0 data   |
|           | i2c0_scl | I/O       | I2C0 clock  |
|           | i2c1_sda | I/O       | I2C1 data   |
|           | i2c1_scl | I/O       | I2C1 clock  |
| I2C       | i2c2_sda | I/O       | I2C2 data   |
| 120       | i2c2_scl | I/O       | I2C2 clock  |
|           | i2c3_sda | I/O       | I2C3 data   |
| 2         | i2c3_scl | I/O       | I2C3 clock  |
|           | i2c4_sda | I/O       | I2C4 data   |
|           | i2c4_scl | I/O       | I2C4 clock  |

| Interface | Pin Name    | Direction | Description               |
|-----------|-------------|-----------|---------------------------|
|           | uart0_sin   | I         | UARTO searial data input  |
|           | uart0_sout  | 0         | UARTO searial data output |
| UART      | uart0_cts_n | I         | UARTO clear to send       |
|           | uart0_rts_n | 0         | UART0 request to send     |
|           | uart1_sin   | I         | UART1 searial data input  |

|  | uart1_sout  | 0 | UART1 searial data output |
|--|-------------|---|---------------------------|
|  | uart1_cts_n | 0 | UART1 clear to send       |
|  | uart1_rts_n | I | UART1 request to send     |
|  | uart2_sin   | I | UART2 searial data input  |
|  | uart2_sout  | 0 | UART2 searial data output |
|  | uart3_sin   | I | UART3 searial data input  |
|  | uart3_sout  | 0 | UART3 searial data output |
|  | uart3_cts_n | I | UART3 clear to send       |
|  | uart3_rts_n | 0 | UART3 request to send     |

| Interface | Pin Name      | Direction | Description                                  |
|-----------|---------------|-----------|----------------------------------------------|
|           | OTG_DM        | N/A       | USB OTG 2.0 Data signal DM                   |
|           | OTO DIVELVIAN | N1 / A    | USB OTG 2.0 Transmitter Kelvin Connection to |
| USB OTG   | OTG_RKELVIN   | N/A       | Resistor Tune Pin                            |
| 2.0       | OTG_DP        | N/A       | USB OTG 2.0 Data signal DP                   |
|           | OTG_VBUS      | N/A       | USB OTG 2.0 5-V power supply pin             |
|           | otg_drv_vbus  | 0         | USB OTG 2.0 drive VBUS                       |

| Interface | Pin Name      | Direction | Description                                   |
|-----------|---------------|-----------|-----------------------------------------------|
|           | HOST_DM       | N/A       | USB HOST 2.0 Data signal DM                   |
|           | LIGOT DISTURN | 21/2      | USB HOST 2.0 Transmitter Kelvin Connection to |
| USB Host  | HOST_RKELVIN  | N/A       | Resistor Tune Pin                             |
| 2.0       | HOST_DP       | N/A       | USB HOST 2.0 Data signal DP                   |
|           | HOST_VBUS     | N/A       | USB HOST 2.0 5-V power supply pin             |
|           | host_drv_vbus | 0         | USB HOST 2.0 drive VBUS                       |

| Interface | Pin Name      | Direction | Description                        |
|-----------|---------------|-----------|------------------------------------|
| CAD ADC   | SARADC_AIN[i] | N1 / A    | CAR ARC insut since   for A should |
| SAR-ADC   | (i=0~3)       | N/A       | SAR-ADC input signal for 4 channel |

| Interface | Pin Name   | Direction | Description                   |  |  |  |
|-----------|------------|-----------|-------------------------------|--|--|--|
| eFuse     | EFUSE_VDDQ | N/A       | eFuse program and sense power |  |  |  |

### 1.3.4 RK30xx IO Type

The following list shows IO type except DDR IO and all of Power/Ground IO .

Table 1-4 RK30xx IO Type List

| Type | Diagram | Description | Pin Name |
|------|---------|-------------|----------|
|------|---------|-------------|----------|



## 1.4 Package information

RK3066 package is TFBGA453LD

(body: 19mm x 19mm; ball size: 0.4mm; ball pitch: 0.8mm)

### 1.4.1 Dimension



Fig. 1-2 RK3066 TFBGA453 Package Top View



Fig. 1-3 RK3066 TFBGA453 Package Side View



Fig. 1-4RK3066 TFBGA453 Package Bottom View

|        | Dime  | ension i | n mm  | Dimension in inch |       |       |  |  |  |  |
|--------|-------|----------|-------|-------------------|-------|-------|--|--|--|--|
| Symbol | MIN   | NOM      | MAX   | MIN               | NOM   | MAX   |  |  |  |  |
| Α      |       |          | 1.40  |                   |       | 0.055 |  |  |  |  |
| A1     | 0.25  | 0.30     | 0.35  | 0.010             | 0.012 | 0.014 |  |  |  |  |
| A2     | 0.91  | 0.96     | 1.01  | 0.036             | 0.038 | 0.040 |  |  |  |  |
| ь      | 0.35  | 0.40     | 0.45  | 0.014             | 0.016 | 0.018 |  |  |  |  |
| С      | 0.22  | 0.26     | 0.30  | 0.009             | 0.010 | 0.012 |  |  |  |  |
| D      | 18.90 | 19.00    | 19.10 | 0.744             | 0.748 | 0.752 |  |  |  |  |
| Ε      | 18.90 | 19.00    | 19.10 | 0.744             | 0.748 | 0.752 |  |  |  |  |
| D1     |       | 17.60    |       |                   | 0.693 |       |  |  |  |  |
| E1     |       | 17.60    |       |                   | 0.693 |       |  |  |  |  |
| е      |       | 0.80     |       |                   | 0.031 |       |  |  |  |  |
| aaa    |       | 0.15     |       |                   | 0.006 |       |  |  |  |  |
| bbb    |       | 0.20     |       | 0.008             |       |       |  |  |  |  |
| ddd    |       | 0.15     |       | 0.006             |       |       |  |  |  |  |
| eee    |       | 0.15     |       | 0.006             |       |       |  |  |  |  |
| fff    |       | 0.08     |       | 0.003             |       |       |  |  |  |  |
| MD/ME  |       | 23/23    |       | 23/23             |       |       |  |  |  |  |

Fig. 1-5 RK3066 TFBGA453 Package Dimension

## 1.4.2 Ball Map

|   |                                              |                                              |                                                |               |                                               |                                               |               |               |               |       |          |        |       |       |      |          | . •      |                                |                               |                             |                        |                               |                                |   |
|---|----------------------------------------------|----------------------------------------------|------------------------------------------------|---------------|-----------------------------------------------|-----------------------------------------------|---------------|---------------|---------------|-------|----------|--------|-------|-------|------|----------|----------|--------------------------------|-------------------------------|-----------------------------|------------------------|-------------------------------|--------------------------------|---|
|   | 1                                            | 2                                            | 3                                              | 4             | 5                                             | 6                                             | 7             | 8             | 9             | 10    | 11       | 12     | 13    | 14    | 15   | 16       | 17       | 18                             | 19                            | 20                          | 21                     | 22                            | 23                             |   |
| Α | HDMI_TX2                                     | HDMI_TX1                                     |                                                | HDMI_TX0      | номі_тхс                                      |                                               | MDQ27         | MDQS_B3       |               | MDQ10 | MDQS_B1  |        | MCKE0 | MBA0  |      | MCK_N    | MA1      |                                | MA7                           | MA11                        |                        | MDQS_B2                       | MDQ20                          | Α |
| В | HDMI_TX2<br>N                                | HDMI_TX1<br>N                                | HDMI_AVS<br>S                                  | HDMI_TX0<br>N | HDMI_TXC<br>N                                 | HDMI_AVS<br>S                                 | MDQ26         | MDQS_3        | MDQ8          | MDQ11 | MDQS_1   | MDQ15  | MCSN0 | MBA1  | MA0  | MCK      | MA4      | MA6                            | MAS                           | MODT0                       | MDQ16                  | MDQS_2                        | MDQ21                          | В |
| С |                                              | LCD0_D2                                      | LCD0_D1                                        | LCD0_D0       | HDMI_AVS<br>S                                 | HDMI_REX<br>T                                 | MDQ24         | MDQ31         | MDM1          | MDQ9  | MDQ14    | MRESET | MWEN  | MBA2  | MA3  | VSS      | MA5      | MA9                            | MA13                          | MODTI                       | MDM2                   | MDQ17                         |                                | С |
| D | LCD0_D4                                      | LCD0_D6                                      | LCD0_D3                                        | LCD0_DEN      | LCD0_VSY<br>NC                                | LCD0_HSY<br>NC                                | MDQ25         | MDQ29         |               | MDQ12 | MCKE1    |        | MCASN | MRASN |      | MA14     | MDQ19    | MA10                           | MA12                          | VSS                         | MDQ22                  | MDQ23                         | MDM0                           | D |
| E | LCD0_D12                                     | LCD0_D10                                     | LCD0_D9                                        | LCD0_D7       |                                               | LCD0_DCL<br>K                                 | MDM3          | MDQ28         |               | MDQ30 | MDQ13    |        | MCSN1 | MA2   |      | MDQ18    | MDQ0     | MDQ3                           |                               | MDQ2                        | MDQ1                   | MDQS_0                        | MDQS_B0                        | E |
| F |                                              | LCD0_D16                                     | LCD0_D11                                       | LCD0_D8       | LCD0_D5                                       | ١                                             | IDMIVDD_1V    | DMIAVDD_2     | V5            | MVDD  | MVDD     |        | MVREF | MVDD  |      | MVDD     | MVDD     |                                | MDQ4                          | MDQ7                        | MDQ5                   | MDQ6                          |                                | F |
| G | LCD0_D19                                     | LCD0_D18                                     | LCD0_D17                                       | LCD0_D14      | LCD0_D13                                      | LCD0_D15                                      |               | HDMI_AVS<br>S | HDMI_AVS<br>S | MVDD  | CVDD_1V1 | VSS    | MVDD  | MVDD  | MPZQ | CVDD_1V1 |          | GPIO2_D5/I<br>2C0_SCL          | GPIO2_D4/I<br>2C0_SDA         | TRSTN                       | TMS/PLL_B<br>YPASS     | TDI/CPR_B<br>YPASS            | GPIO6_B4                       | G |
| н | GPIO2_A2/L<br>CD1_D2/S<br>MC_A6              | LCD0_D22                                     | LCD0_D21                                       | LCD0_D20      | LCD0_D23                                      | GPIO2_A0/<br>LCD1_D0/8<br>MC_A4               | CVDD_1V1      | VSS           | VSS           | VSS   | VSS      | VSS    | VSS   | VSS   | VSS  | VSS      | VCCIO1   | GPIO0_A6/<br>HOST_DRV<br>_VBUS | GPICO_A2/<br>HDMI_I2C_<br>SDA | PWM2/GPI<br>O0_D6           | PWM1/GPI<br>CO_A4      | TDO                           | TCK/HSSCA<br>N_SHIFT_C<br>LOCK | Н |
| J |                                              | GPIO2_A1/L<br>CD1_D1/S<br>MC_A5              | GPIO2_B5/<br>LCD1_D13/<br>SMC_A17/T<br>S_VALID |               |                                               |                                               | LCD0_VCC<br>1 | VSS           | VSS           | VSS   | VSS      | VSS    | VSS   | VSS   | VSS  | VSS      | CVDD_1V1 |                                |                               |                             | PWM3/GPI<br>CO_D7      | GPIOO_A5/<br>OTG_DRV_<br>VBUS |                                | J |
| к | LCD1_D20/                                    | GPIO2_C3/<br>LCD1_D19/<br>SPI1_CLK/T<br>S_D0 | LCD1_D18/                                      | LCD1_D17/     | GPIO2_B7/<br>LCD1_D15/<br>SMC_A19/T<br>S_D7   | GPIO2_B6/<br>LCD1_D14/<br>SMC_A18/T<br>S_SYNC | LCD0_VCC      | VSS           | VSS           | VSS   | VSS      | VSS    | VSS   | VSS   | VSS  | VSS      | VCCI00   | GPIO3_D5/<br>UART3_CT<br>SN    | GPIO3_D4/<br>UART3_TX         | GPIO3_B5/S<br>DMMC0_D3      | GPIO0_B4/I<br>280_SDO0 | GPIO2_D7/I<br>2C1_SCL         | GPIO3_A0/I<br>2C2_SDA          | K |
| L | GPIO2_C5/<br>LCD1_D21/<br>SPI1_RXD/<br>TS_D2 | LCD1_D22/                                    | GPIO2_C7/<br>LCD1_D23/<br>SPI1_CSN1/<br>TS_D4  | CIFO_D3       | GPIO2_C0/<br>LCD1_D16/<br>GPS_CLK/T<br>S_CLKO | CIFO_D2                                       | LCD1_VCC      | VSS           | VSS           | VSS   | VSS      | VSS    | VSS   | VSS   | VSS  | VSS      | CVDD_1V1 | GPIO3_D6/<br>UART3_RT<br>SN    | GPIO3_D3/<br>UART3_RX         | GPIO3_B6/S<br>DMMC0_D<br>ET | GPIOO_A7/I<br>280_SDI  | GPIO1_B2/S<br>PDIF_TX         | GPIO2_D6/I<br>2C1_SDA          | L |

| M  |                                      | CIFO_D5                            | CIFO_D4                                  |                                              |                                    |                                          | CIF0_VCC                                 | VSS                         | VSS                    | VSS                         | VSS                         | VSS                          | VSS                           | VSS                             | VSS                   | VSS                              | VSS                              |                                    |                                    |                                    | GPIO3_B2/S<br>DMMC0_D0                     |                               |                               | М  |
|----|--------------------------------------|------------------------------------|------------------------------------------|----------------------------------------------|------------------------------------|------------------------------------------|------------------------------------------|-----------------------------|------------------------|-----------------------------|-----------------------------|------------------------------|-------------------------------|---------------------------------|-----------------------|----------------------------------|----------------------------------|------------------------------------|------------------------------------|------------------------------------|--------------------------------------------|-------------------------------|-------------------------------|----|
| N  | CIFO_D6                              | CIFO_D7                            | CIFO_DS                                  | CIFO_VSYN<br>C                               | AVDD                               | CIF1_VCC                                 | CVDD_1V1                                 | VSS                         | VSS                    | VSS                         | VSS                         | VSS                          | VSS                           | VSS                             | VSS                   | VSS                              | FLASH_VC<br>C                    | GPIO4_B0F<br>LASH_CSN<br>1         | GPIO3_B7/S<br>DMMC0_W<br>P         | FLASH_RD<br>N                      | GPIO3_D7/<br>FLASH_DQ<br>S/EMMC_C<br>LKO   | GPIO1_B0/<br>UART2_RX         | GPIO0_B6/I<br>280_SDO2        | N  |
| Р  | CIFO_D9                              | CIFO_HREF                          | CIFO_CLKI<br>N                           | GPIO1_B5/<br>CIF0_D1                         | AVDD                               | AVDD                                     | VSS                                      | VSS                         | VSS                    | VSS                         | VSS                         | VSS                          | VSS                           | VSS                             | VSS                   | VSS                              | CVDD_1V1                         | FLASH_DO/<br>EMIMC_DO              | 2S2 CLK/S                          | GPIO0_D1/I<br>282_SCLK/S<br>MC_WEN | GPIO4_B2/F<br>LASH_CSN<br>3/EMMC_RS<br>TNO | GPIO3_B1/S<br>DMMC0_C<br>MD   | GPIO0_B5/I<br>280_SDO1        | Р  |
| R  |                                      | GPIO1_B3/<br>CIF0_CLKO             | GPIO1_B4/<br>CIF0_D0                     |                                              |                                    |                                          | VSS                                      | VSS                         | VSS                    | VSS                         | VSS                         | VSS                          | VSS                           | VSS                             | VSS                   | VSS                              | SMC_VCC                          |                                    |                                    |                                    |                                            | GPIO0_B2/I<br>280_LRCK_<br>RX |                               | R  |
| Т  | GPIO1_B6/<br>CIF0_D10                | GPIO1_B7/<br>CIF0_D11              | GPIO3_A2/I<br>2C3_SDA                    | GPIO1_C4/<br>CIF1_D6/R<br>MII_RX_ER<br>R     | AVDD                               | AVDD                                     | VSS                                      | VSS                         | VSS                    | VSS                         | AVSS_APLL                   | AVSS_DPLL                    | AVSS_C/GP<br>LL               | VSS                             | VSS                   | VSS                              | CVDD_1V1                         | GPIO0_C6/<br>TRACE_CL<br>K/SMC_A2  | GPIO4_C3/S<br>MC_D3/TR<br>ACE_D3   | FLASH_AL<br>E                      | GPIO3_B4/S<br>DMMC0_D2                     | GPICO_BOI<br>280_CLK          | GPIOO_B1/I<br>280_SCLK        | Т  |
| U  | GPIO3_A3/I<br>2C3_SCL                | GPIO1_CO/<br>CIF1_D2/R<br>MII_CLKO | GPIO1_C1/<br>CIF1_D3/R<br>MII_TX_EN      | GPIO1_C5/<br>CIF1_D7/R<br>MII_CRS_D<br>VALID | AVDD                               | AVDD                                     |                                          | AVDD                        | AVDD                   | APLL_1V1                    | DPLL_1V1                    | C/GPLL_1V<br>1               | PVDD_1V1                      | USBVDD_1<br>V1                  | USBVDD_2<br>V5        | AP0_VCC                          |                                  | GPIO4_D4/<br>SMC_D12/T<br>RACE_D12 | GPIO4_C5/S<br>MC_D5/TR<br>ACE_D5   | FLASH_RD<br>Y                      | GPIO4_B1/F<br>LASH_CSN<br>2/EMMC_C<br>MD   | GPIO3_B0/S<br>DMMC0_CL<br>KO  | GPIO3_B3/S<br>DMMC0_D1        | U  |
| ٧  |                                      | GPIO1_C2/<br>CIF1_D4/R<br>MII_TXD1 | GPIO1_C3/<br>CIF1_D5/R<br>MII_TXD0       | GPIO1_C7/<br>CIF1_D9/R<br>MII_RXD0           | AVDD                               |                                          | AVDD                                     | AVDD                        |                        | AVDD_CO<br>M                | NDCVDD_2V                   | 5                            | PVCC_3V3                      | USBVDD_3<br>V3                  |                       | AP1_VCC                          | GPIO4_C4/S<br>MC_D4/TR<br>ACE_D4 |                                    | GPIO4_C6/S<br>MC_D6/TR<br>ACE_D6   | FLASH_D5/<br>EMMC_D5               | GPIO0_D4/I<br>282_SDI/SM<br>C_A0           | GPIO3_A7/<br>SDMMC0_P<br>WREN |                               | V  |
| W  | GPIO1_C6/<br>CIF1_D8/R<br>MII_RXD1   | GPIO1_DO/<br>CIF1_VSYN<br>C/MII_MD | GPIO1_D1/<br>CIF1_HREF/<br>MII_MDCL<br>K | GPIO1_D2/<br>CIF1_CLKI<br>N                  |                                    | ADC_IN0                                  | ADC_IN2                                  | ADC_IN1                     |                        | GPIO6_B0                    | GPIO6_A0                    |                              | HOST_RKE<br>LVIN              | EFUSE                           |                       | GPIO4_C2/S<br>MC_D2/TR<br>ACE_D2 | GPIO4_C1/S<br>MC_D1/TR<br>ACE_D1 | GPIO4_C7/S<br>MC_D7/TR<br>ACE_D7   |                                    | GPIO4_D2/<br>SMC_D10/T<br>RACE_D10 | GPIO0_D3/I<br>282_LRCK_<br>TX/SMC_A<br>DVN | FLASH_D3/<br>EMMC_D3          | GPIO3_A6/<br>SDMMC0_R<br>STNO | w  |
| Y  | GPIO1_D7/<br>CIF1_CLKO               | GPIO1_D6/<br>CIF1_D11              | GPIO3_A5/I<br>2C4_SCL                    | GPIO3_A4/I<br>2C4_SDA                        | GPIO6_A4                           | GPIO6_A5                                 | NPOR                                     | GPIO6_A6                    |                        | GPIO3_C6S<br>DMMC1_D<br>ET  | GPIO1_A1/<br>UART0_TX       |                              | GPIO3_D0/<br>SDMMC1_P<br>WREN | GPICO_C4/I<br>281_SDI           |                       | GPIOO_A1/<br>HDMI_I2C_<br>SCL    | GPIO4_C0/S<br>MC_D0/TR<br>ACE_D0 | GPIO4_D0/<br>SMC_D8/TR<br>ACE_D8   | GPIO3_A1/I<br>2C2_SCL              | GPIO4_D6/<br>SMC_D14/T<br>RACE_D14 | GPIO0_D2/I<br>282_LRCK_<br>RX/SMC_O<br>EN  | FLASH_D4/<br>EMMC_D4          | FLASH_CS<br>NO                | Y  |
| AA |                                      | GPIO6_B2                           | GPIO6_A1                                 | CLK32K_IN                                    | GPIO6_A3                           | OTG_RKEL<br>VIN                          | GPIO1_A4/<br>UART1_RX/<br>SPI0_CSN0      | GPIO3_D2/<br>SDMMC1_I<br>NT | GPIO3_C3/8<br>DMMC1_D2 | GPIO3_C4/8<br>DMMC1_D3      | GPIO1_A2/<br>UART0_CT<br>SN | GPIO3_C5/S<br>DMMC1_CL<br>KO | GPIO3_C7/S<br>DMMC1_W<br>P    | GPIO3_D1/<br>SDMMC1_B<br>ACKEND | PWM0/GPI<br>O0_A3     | VSS                              | VSS                              | GPIO4_D1/<br>SMC_D9/TR<br>ACE_D9   | GPIO0_A0/<br>HDMI_HPD              | GPIO4_D7/<br>SMC_D15/T<br>RACE_D15 | FLASH_D1/<br>EMMC_D1                       | FLASH_D6/<br>EMMC_D6          |                               | AA |
| AB | CPU_PWR<br>OFF                       | GPIO6_B1                           | GPIO6_A2                                 | OTG_ID                                       | OTG_VBUS                           | GPIO1_A6/<br>UART1_CT<br>SN/SPI0_RX<br>D | GPIO1_A7/<br>UART1_RT<br>SN/SPI0_TX<br>D | GPIO3_C0/S<br>DMMC1_C<br>MD | GPIO3_C2/S<br>DMMC1_D1 |                             | XOUT24M                     | GPIO1_A0/<br>UART0_RX        | GPICO_C1/I<br>281_SCLK        | GPIO0_C3/I<br>281_LRCK_<br>TX   | GPICO_C5/I<br>281_SDO | OTG_DM                           | HOST_DM                          | GPIO4_D3/<br>SMC_D11/T<br>RACE_D11 | GPIO1_B1/<br>UART2_TX              | GPIO0_C7/<br>TRACE_CT<br>L/SMC_A3  | FLASH_D2/<br>EMMC_D2                       | FLASH_D7/<br>EMMC_D7          | FLASH_WP<br>/EMMC_PW<br>REN   | AB |
| AC | CORE_PWR                             | GPIO6_B3                           |                                          | GPIO6_A7                                     | GPIO1_A5/<br>UART1_TX/<br>SPI0_CLK |                                          | GPIO4_B7/S<br>PIO_CSN1                   | GPIO3_C1/S<br>DMMC1_D0      |                        | GPIO1_A3/<br>UART0_RT<br>SN | XIN24M                      |                              | GPICO_COI<br>281_CLK          | GPIO0_C2/I<br>281_LRCK_<br>RX   |                       | OTG_DP                           | HOST_DP                          |                                    | GPIO4_D5/<br>SMC_D13/T<br>RACE_D13 | GPIO0_D5/I<br>282_SDO/S<br>MC_A1   |                                            | FLASH_CL<br>E                 | FLASH_WR<br>N                 | AC |
|    | 1                                    | 2                                  | 3                                        | 4                                            | 5                                  | 6                                        | 7                                        | 8                           | 9                      | 10                          | 11                          | 12                           | 13                            | 14                              | 15                    | 16                               | 17                               | 18                                 | 19                                 | 20                                 | 21                                         | 22                            | 23                            |    |
|    | Fig. 1-6 RK3066 Ball Mapping Diagram |                                    |                                          |                                              |                                    |                                          |                                          |                             |                        |                             |                             |                              |                               |                                 |                       |                                  |                                  |                                    |                                    |                                    |                                            |                               |                               |    |



### 1.4.3 Ball Pin Number Order

Table 1-5 RK3066Ball Pin Number Order Information

| Ball # | Ball Pin Name | Ball # | Ball Pin Name |
|--------|---------------|--------|---------------|
| A1     | HDMI_TX2      | B1     | HDMI_TX2N     |
| A2     | HDMI_TX1      | B2     | HDMI_TX1N     |
| A3     | NC            | B3     | HDMI_AVSS     |
| A4     | HDMI_TX0      | B4     | HDMI_TX0N     |
| A5     | HDMI_TXC      | B5     | HDMI_TXCN     |
| A6     | NC            | B6     | HDMI_AVSS     |
| A7     | MDQ27         | B7     | MDQ26         |
| A8     | MDQS_B3       | B8     | MDQS_3        |
| A9     | NC            | В9     | MDQ8          |
| A10    | MDQ10         | B10    | MDQ11         |
| A11    | MDQS_B1       | B11    | MDQS_1        |
| A12    | NC            | B12    | MDQ15         |
| A13    | MCKE0         | B13    | MCSN0         |
| A14    | MBA0          | B14    | MBA1          |
| A15    | NC            | B15    | MA0           |
| A16    | MCK_N         | B16    | MCK           |
| A17    | MA1           | B17    | MA4           |
| A18    | NC            | B18    | MA6           |
| A19    | MA7           | B19    | MA8           |
| A20    | MA11          | B20    | MODT0         |
| A21    | NC            | B21    | MDQ16         |
| A22    | MDQS_B2       | B22    | MDQS_2        |
| A23    | MDQ20         | B23    | MDQ21         |
| C1     | NC            | D1     | LCD0_D4       |
| C2     | LCD0_D2       | D2     | LCD0_D6       |
| C3     | LCD0_D1       | D3     | LCD0_D3       |
| C4     | LCD0_D0       | D4     | LCD0_DEN      |
| C5     | HDMI_AVSS     | D5     | LCD0_VSYNC    |
| C6     | HDMI_REXT     | D6     | LCD0_HSYNC    |
| C7     | MDQ24         | D7     | MDQ25         |
| C8     | MDQ31         | D8     | MDQ29         |
| C9     | MDM1          | D9     | NC            |
| C10    | MDQ9          | D10    | MDQ12         |
| C11    | MDQ14         | D11    | MCKE1         |
| C12    | MRESET        | D12    | NC            |
| C13    | MWEN          | D13    | MCASN         |
| C14    | MBA2          | D14    | MRASN         |
| C15    | MA3           | D15    | NC            |
| C16    | VSS           | D16    | MA14          |



| C17 | MA5       | D17 | MDQ19                   |
|-----|-----------|-----|-------------------------|
| C18 | MA9       | D18 | MA10                    |
| C19 | MA13      | D19 | MA12                    |
| C20 | MODT1     | D20 | VSS                     |
| C21 | MDM2      | D21 | MDQ22                   |
| C22 | MDQ17     | D22 | MDQ23                   |
| C23 | NC        | D23 | MDM0                    |
| E1  | LCD0_D12  | F1  | NC                      |
| E2  | LCD0_D10  | F2  | LCD0_D16                |
| E3  | LCD0_D9   | F3  | LCD0_D11                |
| E4  | LCD0_D7   | F4  | LCD0_D8                 |
| E5  | NC        | F5  | LCD0_D5                 |
| E6  | LCD0_DCLK | F6  | NC                      |
| E7  | MDM3      | F7  | HDMIVDD_1V1             |
| E8  | MDQ28     | F8  | HDMIAVDD_2V5            |
| E9  | NC        | F9  | NC                      |
| E10 | MDQ30     | F10 | MVDD                    |
| E11 | MDQ13     | F11 | MVDD                    |
| E12 | NC        | F12 | NC                      |
| E13 | MCSN1     | F13 | MVREF                   |
| E14 | MA2       | F14 | MVDD                    |
| E15 | NC        | F15 | NC                      |
| E16 | MDQ18     | F16 | MVDD                    |
| E17 | MDQ0      | F17 | MVDD                    |
| E18 | MDQ3      | F18 | NC                      |
| E19 | NC        | F19 | MDQ4                    |
| E20 | MDQ2      | F20 | MDQ7                    |
| E21 | MDQ1      | F21 | MDQ5                    |
| E22 | MDQS_0    | F22 | MDQ6                    |
| E23 | MDQS_B0   | F23 | NC                      |
| G1  | LCD0_D19  | H1  | GPIO2_A2/LCD1_D2/SMC_A6 |
| G2  | LCD0_D18  | H2  | LCD0_D22                |
| G3  | LCD0_D17  | НЗ  | LCD0_D21                |
| G4  | LCD0_D14  | H4  | LCD0_D20                |
| G5  | LCD0_D13  | H5  | LCD0_D23                |
| G6  | LCD0_D15  | H6  | GPIO2_A0/LCD1_D0/SMC_A4 |
| G7  | NC        | H7  | CVDD_1V1                |
| G8  | HDMI_AVSS | H8  | VSS                     |
| G9  | HDMI_AVSS | H9  | VSS                     |
| G10 | MVDD      | H10 | VSS                     |
| G11 | CVDD_1V1  | H11 | VSS                     |
| G12 | VSS       | H12 | VSS                     |



| G13 | MVDD                               | H13 | VSS                                |
|-----|------------------------------------|-----|------------------------------------|
| G14 | MVDD                               | H14 | VSS                                |
| G15 | MPZQ                               | H15 | VSS                                |
| G16 | CVDD_1V1                           | H16 | VSS                                |
| G17 | NC                                 | H17 | VCCIO1                             |
| G18 | GPIO2_D5/I2C0_SCL                  | H18 | GPIO0_A6/HOST_DRV_VBUS             |
| G19 | GPIO2_D4/I2C0_SDA                  | H19 | GPIO0_A2/HDMI_I2C_SDA              |
| G20 | TRSTN                              | H20 | PWM2/GPIO0_D6                      |
| G21 | TMS/PLL_BYPASS                     | H21 | PWM1/GPIO0_A4                      |
| G22 | TDI/CPR_BYPASS                     | H22 | TDO                                |
| G23 | GPIO6_B4                           | H23 | TCK/HSSCAN_SHIFT_CLOCK             |
| J1  | NC                                 | K1  | GPIO2_C4/LCD1_D20/SPI1_CSN0/TS_D1  |
| J2  | GPIO2_A1/LCD1_D1/SMC_A5            | K2  | GPIO2_C3/LCD1_D19/SPI1_CLK/TS_D0   |
| J3  | GPIO2_B5/LCD1_D13/SMC_A17/TS_VALID | K3  | GPIO2_C2/LCD1_D18/SMC_BIS_N1/TS_D5 |
| J4  | NC                                 | K4  | GPIO2_C1/LCD1_D17/SMC_BIS_N0/TS_D6 |
| J5  | NC                                 | K5  | GPIO2_B7/LCD1_D15/SMC_A19/TS_D7    |
| J6  | NC                                 | K6  | GPIO2_B6/LCD1_D14/SMC_A18/TS_SYNC  |
| J7  | LCD0_VCC1                          | K7  | LCD0_VCC0                          |
| J8  | VSS                                | K8  | VSS                                |
| J9  | VSS                                | K9  | VSS                                |
| J10 | VSS                                | K10 | VSS                                |
| J11 | VSS                                | K11 | VSS                                |
| J12 | VSS                                | K12 | VSS                                |
| J13 | VSS                                | K13 | VSS                                |
| J14 | VSS                                | K14 | VSS                                |
| J15 | VSS                                | K15 | VSS                                |
| J16 | VSS                                | K16 | VSS                                |
| J17 | CVDD_1V1                           | K17 | VCCIO0                             |
| J18 | NC                                 | K18 | GPIO3_D5/UART3_CTSN                |
| J19 | NC                                 | K19 | GPIO3_D4/UART3_TX                  |
| J20 | NC                                 | K20 | GPIO3_B5/SDMMC0_D3                 |
| J21 | PWM3/GPIO0_D7                      | K21 | GPIO0_B4/I2S0_SDO0                 |
| J22 | GPIO0_A5/OTG_DRV_VBUS              | K22 | GPIO2_D7/I2C1_SCL                  |
| J23 | NC                                 | K23 | GPIO3_A0/I2C2_SDA                  |
| L1  | GPIO2_C5/LCD1_D21/SPI1_RXD/TS_D2   | M1  | NC                                 |
| L2  | GPIO2_C6/LCD1_D22/SPI1_RXD/TS_D3   | M2  | CIF0_D5                            |
| L3  | GPIO2_C7/LCD1_D23/SPI1_CSN1/TS_D4  | M3  | CIF0_D4                            |
| L4  | CIF0_D3                            | M4  | NC                                 |
| L5  | GPIO2_C0/LCD1_D16/GPS_CLK/TS_CLKO  | M5  | NC                                 |
| L6  | CIF0_D2                            | M6  | NC                                 |
| L7  | LCD1_VCC                           | M7  | CIF0_VCC                           |
| L8  | VSS                                | M8  | VSS                                |



| L9  | VSS                          | M9  | VSS                            |
|-----|------------------------------|-----|--------------------------------|
| L10 | VSS                          | M10 | VSS                            |
| L11 | VSS                          | M11 | VSS                            |
| L12 | VSS                          | M12 | VSS                            |
| L13 | VSS                          | M13 | VSS                            |
| L14 | VSS                          | M14 | VSS                            |
| L15 | VSS                          | M15 | VSS                            |
| L16 | VSS                          | M16 | VSS                            |
| L17 | CVDD_1V1                     | M17 | VSS                            |
| L18 | GPIO3_D6/UART3_RTSN          | M18 | NC                             |
| L19 | GPIO3_D3/UART3_RX            | M19 | NC                             |
| L20 | GPIO3_B6/SDMMC0_DET          | M20 | NC                             |
| L21 | GPIO0_A7/I2S0_SDI            | M21 | GPIO3_B2/SDMMC0_D0             |
| L22 | GPIO1_B2/SPDIF_TX            | M22 | GPIO0_B7/I2S0_SDO3             |
| L23 | GPIO2_D6/I2C1_SDA            | M23 | NC                             |
| N1  | CIF0_D6                      | P1  | CIF0_D9                        |
| N2  | CIF0_D7                      | P2  | CIF0_HREF                      |
| N3  | CIF0_D8                      | P3  | CIF0_CLKIN                     |
| N4  | CIF0_VSYNC                   | P4  | GPIO1_B5/CIF0_D1               |
| N5  | AVDD                         | P5  | AVDD                           |
| N6  | CIF1_VCC                     | P6  | AVDD                           |
| N7  | CVDD_1V1                     | P7  | VSS                            |
| N8  | VSS                          | P8  | VSS                            |
| N9  | VSS                          | P9  | VSS                            |
| N10 | VSS                          | P10 | VSS                            |
| N11 | VSS                          | P11 | VSS                            |
| N12 | VSS                          | P12 | VSS                            |
| N13 | VSS                          | P13 | VSS                            |
| N14 | VSS                          | P14 | VSS                            |
| N15 | VSS                          | P15 | VSS                            |
| N16 | VSS                          | P16 | VSS                            |
| N17 | FLASH_VCC                    | P17 | CVDD_1V1                       |
| N18 | GPIO4_B0/FLASH_CSN1          | P18 | FLASH_D0/EMMC_D0               |
| N19 | GPIO3_B7/SDMMC0_WP           | P19 | GPIO0_D0/l2S2_CLK/SMC_CSN0     |
| N20 | FLASH_RDN                    | P20 | GPIO0_D1/I2S2_SCLK/SMC_WEN     |
| N21 | GPIO3_D7/FLASH_DQS/EMMC_CLKO | P21 | GPIO4_B2/FLASH_CSN3/EMMC_RSTNO |
| N22 | GPIO1_B0/UART2_RX            | P22 | GPIO3_B1/SDMMC0_CMD            |
| N23 | GPIO0_B6/I2S0_SDO2           | P23 | GPIO0_B5/I2S0_SDO1             |
| R1  | NC                           | T1  | GPIO1_B6/CIF0_D10              |
| R2  | GPIO1_B3/CIF0_CLKO           | T2  | GPIO1_B7/CIF0_D11              |
| R3  | GPIO1_B4/CIF0_D0             | Т3  | GPIO3_A2/I2C3_SDA              |
| R4  | NC                           | T4  | GPIO1_C4/CIF1_D6/RMII_RX_ERR   |



| R5  | NC                               | T5  | AVDD                       |
|-----|----------------------------------|-----|----------------------------|
| R6  | NC                               | T6  | AVDD                       |
| R7  | VSS                              | T7  | VSS                        |
| R8  | VSS                              | Т8  | VSS                        |
| R9  | VSS                              | Т9  | VSS                        |
| R10 | VSS                              | T10 | VSS                        |
| R11 | VSS                              | T11 | AVSS_APLL                  |
| R12 | VSS                              | T12 | AVSS_DPLL                  |
| R13 | VSS                              | T13 | AVSS_C/GPLL                |
| R14 | VSS                              | T14 | VSS                        |
| R15 | VSS                              | T15 | VSS                        |
| R16 | VSS                              | T16 | VSS                        |
| R17 | SMC_VCC                          | T17 | CVDD_1V1                   |
| R18 | NC                               | T18 | GPIO0_C6/TRACE_CLK/SMC_A2  |
| R19 | NC                               | T19 | GPIO4_C3/SMC_D3/TRACE_D3   |
| R20 | NC                               | T20 | FLASH_ALE                  |
| R21 | GPIO0_B3/I2S0_LRCK_TX            | T21 | GPIO3_B4/SDMMC0_D2         |
| R22 | GPIO0_B2/I2S0_LRCK_RX            | T22 | GPIO0_B0/I2S0_CLK          |
| R23 | NC                               | T23 | GPIO0_B1/I2S0_SCLK         |
| U1  | GPIO3_A3/I2C3_SCL                | V1  | NC                         |
| U2  | GPIO1_C0/CIF1_D2/RMII_CLKO       | V2  | GPIO1_C2/CIF1_D4/RMII_TXD1 |
| U3  | GPIO1_C1/CIF1_D3/RMII_TX_EN      | V3  | GPIO1_C3/CIF1_D5/RMII_TXD0 |
| U4  | GPIO1_C5/CIF1_D7/RMII_CRS_DVALID | V4  | GPIO1_C7/CIF1_D9/RMII_RXD0 |
| U5  | AVDD                             | V5  | AVDD                       |
| U6  | AVDD                             | V6  | NC                         |
| U7  | NC                               | V7  | AVDD                       |
| U8  | AVDD                             | V8  | AVDD                       |
| U9  | AVDD                             | V9  | NC                         |
| U10 | APLL_1V1                         | V10 | AVDD_COM                   |
| U11 | DPLL_1V1                         | V11 | ADCVDD_2V5                 |
| U12 | C/GPLL_1V1                       | V12 | NC                         |
| U13 | PVDD_1V1                         | V13 | PVCC_3V3                   |
| U14 | USBVDD_1V1                       | V14 | USBVDD_3V3                 |
| U15 | USBVDD_2V5                       | V15 | NC                         |
| U16 | AP0_VCC                          | V16 | AP1_VCC                    |
| U17 | NC                               | V17 | GPIO4_C4/SMC_D4/TRACE_D4   |
| U18 | GPIO4_D4/SMC_D12/TRACE_D12       | V18 | NC                         |
| U19 | GPIO4_C5/SMC_D5/TRACE_D5         | V19 | GPIO4_C6/SMC_D6/TRACE_D6   |
| U20 | FLASH_RDY                        | V20 | FLASH_D5/EMMC_D5           |
| U21 | GPIO4_B1/FLASH_CSN2/EMMC_CMD     | V21 | GPIO0_D4/I2S2_SDI/SMC_A0   |
| U22 | GPIO3_B0/SDMMC0_CLKO             | V22 | GPIO3_A7/SDMMC0_PWREN      |
| U23 | GPIO3_B3/SDMMC0_D1               | V23 | NC                         |



| W1   | GPIO1_C6/CIF1_D8/RMII_RXD1     | Y1   | GPIO1_D7/CIF1_CLKO            |
|------|--------------------------------|------|-------------------------------|
| W2   | GPIO1_D0/CIF1_VSYNC/MII_MD     | Y2   | GPIO1_D6/CIF1_D11             |
| W3   | GPIO1_D1/CIF1_HREF/MII_MDCLK   | Y3   | GPIO3_A5/I2C4_SCL             |
| W4   | GPIO1_D2/CIF1_CLKIN            | Y4   | GPIO3_A4/I2C4_SDA             |
| W5   | NC                             | Y5   | GPIO6_A4                      |
| W6   | ADC_IN0                        | Y6   | GPIO6_A5                      |
| W7   | ADC_IN2                        | Y7   | NPOR                          |
| W8   | ADC_IN1                        | Y8   | GPIO6_A6                      |
| W9   | NC                             | Y9   | NC                            |
| W10  | GPIO6_B0                       | Y10  | GPIO3_C6/SDMMC1_DET           |
| W11  | GPIO6_A0                       | Y11  | GPIO1_A1/UART0_TX             |
| W12  | NC                             | Y12  | NC                            |
| W13  | HOST_RKELVIN                   | Y13  | GPIO3_D0/SDMMC1_PWREN         |
| W14  | EFUSE                          | Y14  | GPIO0_C4/I2S1_SDI             |
| W15  | NC                             | Y15  | NC                            |
| W16  | GPIO4_C2/SMC_D2/TRACE_D2       | Y16  | GPIO0_A1/HDMI_I2C_SCL         |
| W17  | GPIO4_C1/SMC_D1/TRACE_D1       | Y17  | GPIO4_C0/SMC_D0/TRACE_D0      |
| W18  | GPIO4_C7/SMC_D7/TRACE_D7       | Y18  | GPIO4_D0/SMC_D8/TRACE_D8      |
| W19  | NC                             | Y19  | GPIO3_A1/I2C2_SCL             |
| W20  | GPIO4_D2/SMC_D10/TRACE_D10     | Y20  | GPIO4_D6/SMC_D14/TRACE_D14    |
| W21  | GPIO0_D3/I2S2_LRCK_TX/SMC_ADVN | Y21  | GPIO0_D2/I2S2_LRCK_RX/SMC_OEN |
| W22  | FLASH_D3/EMMC_D3               | Y22  | FLASH_D4/EMMC_D4              |
| W23  | GPIO3_A6/SDMMC0_RSTNO          | Y23  | FLASH_CSN0                    |
| AA1  | NC                             | AB1  | CPU_PWROFF                    |
| AA2  | GPIO6_B2                       | AB2  | GPIO6_B1                      |
| AA3  | GPIO6_A1                       | AB3  | GPIO6_A2                      |
| AA4  | CLK32K_IN                      | AB4  | OTG_ID                        |
| AA5  | GPIO6_A3                       | AB5  | OTG_VBUS                      |
| AA6  | OTG_RKELVIN                    | AB6  | GPIO1_A6/UART1_CTSN/SPI0_RXD  |
| AA7  | GPIO1_A4/UART1_RX/SPI0_CSN0    | AB7  | GPIO1_A7/UART1_RTSN/SPI0_TXD  |
| AA8  | GPIO3_D2/SDMMC1_INT            | AB8  | GPIO3_C0/SDMMC1_CMD           |
| AA9  | GPIO3_C3/SDMMC1_D2             | AB9  | GPIO3_C2/SDMMC1_D1            |
| AA10 | GPIO3_C4/SDMMC1_D3             | AB10 | VSS                           |
| AA11 | GPIO1_A2/UART0_CTSN            | AB11 | XOUT24M                       |
| AA12 | GPIO3_C5/SDMMC1_CLKO           | AB12 | GPIO1_A0/UART0_RX             |
| AA13 | GPIO3_C7/SDMMC1_WP             | AB13 | GPIO0_C1/I2S1_SCLK            |
| AA14 | GPIO3_D1/SDMMC1_BACKEND        | AB14 | GPIO0_C3/I2S1_LRCK_TX         |
| AA15 | PWM0/GPIO0_A3                  | AB15 | GPIO0_C5/l2S1_SDO             |
| AA16 | VSS                            | AB16 | OTG_DM                        |
| AA17 | VSS                            | AB17 | HOST_DM                       |
| AA18 | GPIO4_D1/SMC_D9/TRACE_D9       | AB18 | GPIO4_D3/SMC_D11/TRACE_D11    |
| AA19 | GPIO0_A0/HDMI_HPD              | AB19 | GPIO1_B1/UART2_TX             |



| AA20 | GPIO4_D7/SMC_D15/TRACE_D15 | AB20           | GPIO0_C7/TRACE_CTL/SMC_A3  |
|------|----------------------------|----------------|----------------------------|
| AA21 | FLASH_D1/EMMC_D1           | AB21           | FLASH_D2/EMMC_D2           |
| AA22 | FLASH_D6/EMMC_D6           | AB22           | FLASH_D7/EMMC_D7           |
| AA23 | NC                         | AB23           | FLASH_WP/EMMC_PWREN        |
| AC1  | CORE_PWROFF                | AC13           | GPIO0_C0/I2S1_CLK          |
| AC2  | GPIO6_B3                   | AC14           | GPIO0_C2/I2S1_LRCK_RX      |
| AC3  | NC                         | AC15           | NC                         |
| AC4  | GPIO6_A7                   | AC16           | OTG_DP                     |
| AC5  | GPIO1_A5/UART1_TX/SPI0_CLK | AC17           | HOST_DP                    |
| AC6  | NC                         | AC18           | NC                         |
| AC7  | GPIO4_B7/SPI0_CSN1         | AC19           | GPIO4_D5/SMC_D13/TRACE_D13 |
| AC8  | GPIO3_C1/SDMMC1_D0         | AC20           | GPIO0_D5/I2S2_SDO/SMC_A1   |
| AC9  | NC                         | AC21           | NC                         |
| AC10 | GPIO1_A3/UART0_RTSN        | AC22 FLASH_CLE |                            |
| AC11 | XIN24M                     | AC23           | FLASH_WRN                  |
| AC12 | NC                         | ,              |                            |

# 1.5 Electrical Specification

# 1.5.1 Absolute Maximum Ratings

Table 1-6 RK30xx absolute maximum ratings

| Paramerters                                          | Related Power Group            | Max  | Unit |
|------------------------------------------------------|--------------------------------|------|------|
|                                                      | AVDD,                          |      |      |
| DC supply voltage for Internal digital logic         | CVDD,                          | 1.21 | V    |
| DC supply voltage for internal digital logic         | PVDD,                          | 1.21 | V    |
|                                                      | OTG_DVDD, HOST_DVDD            |      |      |
|                                                      | LCD0_VCC0,LCD0_VCC1, LCD1_VCC, |      |      |
| (°) ×                                                | CIF0_VCC,CIF1_VCC,             |      |      |
| DC supply voltage for Digital GPIO                   | PVCC,                          | 3.6  | V    |
| (except for SAR-ADC, TS-ADC, PLL, USB, DDR IO)       | AP0_VCC,AP1_VCC,               | 3.6  | V    |
|                                                      | SMC_VCC,FLASH_VCC,             |      |      |
|                                                      | VCCIO_0,VCCIO_1                |      |      |
| DC supply voltage for DDR IO                         | MVDD                           | 1.65 | ٧    |
| DC supply voltage for Analog part of SAR-ADC/TS-ADC  | VDDA_SARADC, VDDA_TSADC        | 2.75 | V    |
| DC supply voltage for Analog part of PLL             | AVDD_APLL,AVDD_DPLL,           | 1.21 | V    |
| DC supply voltage for Analog part of FLL             | AVDD_CGPLL                     | 1.21 | V    |
| DC cumply voltage for Angles port of UCD OTC/Ucot2 0 | OTG_VDD25,HOST_VDD25           | 2.75 | V    |
| DC supply voltage for Analog part of USB OTG/Host2.0 | OTG_VDD33,HOST_VDD33           | 3.63 | V    |
| DC aumphy valtage for Angles part of LIDMI           | HDMIVDD                        | 1.21 | V    |
| DC supply voltage for Analog part of HDMI            | HDMIAVDD                       | 2.75 | V    |
| DC supply voltage for Analog part of EFUSE           | EFUSE_VDDQ                     | 2.75 | V    |
| Analog Input voltage for SAR-ADC                     |                                | 2.75 | V    |

| Analog Input voltage for TS-ADC                        | 2.75 | ٧                      |
|--------------------------------------------------------|------|------------------------|
| Analog Input voltage for DP/DM/VBUS of USB OTG/Host2.0 | 5    | V                      |
| Analog input voltage for RKELVIN/ID of USB OTG/Host2.0 | 2.75 | V                      |
| Digital input voltage for input buffer of GPIO         | 3.6  | V                      |
| Digital output voltage for output buffer of GPIO       | 3.6  | V                      |
| Storage Temperature                                    | 125  | $^{\circ}\!\mathbb{C}$ |

Absolute maximum ratings specify the values beyond which the device may be damaged permanently. Long-term exposure to absolute maximum ratings conditions may affect device reliability.

# 1.5.2 Recommended Operating Conditions

Table 1-7 RK30xx recommended operating conditions

| Parameters                                    | Symbol                                                                                        | Min         | Тур        | Max         | Units |
|-----------------------------------------------|-----------------------------------------------------------------------------------------------|-------------|------------|-------------|-------|
| Internal digital logic Power (except USB OTG) | AVDD,<br>CVDD,<br>PVDD                                                                        | 0.99        | 1.10       | 1.21        | ٧     |
| Digital GPIO Power(3.3V)                      | VCCIO0,VCCIO1, EFUSE_VDDQ                                                                     | 3           | 3.3        | 3.6         | V     |
| Digital GPIO Power(3.3V/1.8V)                 | LCD0_VCC0, LCD0_VCC1, LCD1_VCC, SMC_VCC, CIF0_VCC,CIF1_VCC, PVCC, FLASH_VCC, AP0_VCC, AP1_VCC | 3<br>1.62   | 3.3<br>1.8 | 3.6<br>1.98 | V     |
| DDR IO (DDR3 mode) Power                      | MVDD                                                                                          | 1.425       | 1.5        | 1.575       | V     |
| DDR IO (LPDDR2 mode) Power                    | MVDD                                                                                          | 1.14        | 1.2        | 1.30        | V     |
| DDR IO (LVDDR3 mode) Power                    | MVDD                                                                                          | 1.28        | 1.35       | 1.45        | V     |
| DDR reference supply (VREF) Input             | VREF                                                                                          | 0.49*MVDD   | 0.5*MVDD   | 0.51*MVDD   | V     |
| DDR External termination voltage              |                                                                                               | VREF - 40mV | VREF       | VREF + 40mV | V     |
| PLLAnalog Power                               | AVDD_APLL, AVDD_DPLL, AVDD_CGPLL                                                              | 0.99        | 1.1        | 1.21        | V     |
| SAR-ADC Analog Power                          | VDDA_SARADC                                                                                   | 2.25        | 2.5        | 2.75        | V     |
| TS-ADC Analog Power                           | VDDA_TSADC                                                                                    | 2.25        | 2.5        | 2.75        | V     |
| USB OTG/Host2.0 Digital Power                 | OTG_DVDD, HOST_DVDD                                                                           | 1.023       | 1.1        | 1.21        | V     |
| USB OTG/Host2.0 Analog<br>Power(2.5V)         | OTG_VDD25,HOST_VDD25                                                                          | 2.325       | 2.5        | 2.75        | V     |
| USB OTG/Host2.0 Analog<br>Power(3.3V)         | OTG_VDD33,HOST_VDD33                                                                          | 3.069       | 3.3        | 3.63        | V     |
| USB OTG/Host2.0 external resistor             | REXT                                                                                          | 42.768      | 43.2       | 43.632      | Ohm   |

| PLL input clock frequency | N/A | 24 | N/A | MHz          |
|---------------------------|-----|----|-----|--------------|
| Operating Temperature     | -40 | 25 | 85  | $^{\circ}$ C |

# 1.5.3 DC Characteristics

Table 1-8 RK30xx DC Characteristics

| P                     | Parameters                | Symbol              | Min         | Тур  | Max                                   | Units |
|-----------------------|---------------------------|---------------------|-------------|------|---------------------------------------|-------|
|                       | Input Low Voltage         | V <sub>il</sub>     | -0.3        | 0    | 0.8                                   | V     |
|                       | Input High Voltage        | Vih                 | 2           | 3.3  | 3.6                                   | V     |
|                       | Output Low Voltage        | Vol                 | N/A         | 0    | 0.4                                   | V     |
|                       | Output High Voltage       | V <sub>oh</sub>     | 2.4         | 3.3  | N/A                                   | V     |
| Dimital CDIO          | Threshold Point           | $V_t$               | 1.34        | 1.46 | 1.6                                   | V     |
| Digital GPIO<br>@3.3V | Threshold Point with      | .,                  | 4.0         | 4.04 | , , , , , , , , , , , , , , , , , , , | V     |
| <b>⊌</b> 3.3√         | Pullup Resistor Enabled   | V <sub>tpu</sub>    | 1.2         | 1.31 | 1.45                                  | V     |
|                       | Threshold Point with      | .,                  | 1.71        | 1.94 | 1.07                                  | V     |
|                       | Pulldown Resistor Enabled | V <sub>tpd</sub>    | 1.71        | 1.84 | 1.97                                  | V     |
|                       | Pullup Resistor           | R <sub>pu</sub>     | 41          | 60   | 91                                    | Kohm  |
|                       | Pulldown Resistor         | R <sub>pd</sub>     | 43          | 63   | 103                                   | Kohm  |
|                       | Input Low Voltage         | Vil                 | -0.3        | 0    | 0.63                                  | V     |
|                       | Input High Voltage        | V <sub>ih</sub>     | 1.17        | 1.8  | 3.6                                   | V     |
|                       | Output Low Voltage        | Vol                 | N/A         | 0    | 0.45                                  | V     |
|                       | Output High Voltage       | V <sub>oh</sub>     | 1.35        | 1.8  | N/A                                   | V     |
| Digital GPIO          | Threshold Point           | $V_t$               | 0.77        | 0.84 | 0.92                                  | V     |
| @1.8V                 | Threshold Point with      | V <sub>tpu</sub>    | 0.77        | 0.04 | 0.91                                  | V     |
| @1.8V                 | Pullup Resistor Enabled   |                     |             | 0.84 |                                       | V     |
|                       | Threshold Point with      | <i>Y</i>            | 0.77        | 0.85 | 0.92                                  | V     |
|                       | Pulldown Resistor Enabled | $V_{tpd}$           | 0.77        | 0.65 | 0.92                                  | v     |
|                       | Pullup Resistor           | R <sub>pu</sub>     | 79          | 129  | 218                                   | Kohm  |
|                       | Pulldown Resistor         | R <sub>pd</sub>     | 73          | 127  | 233                                   | Kohm  |
|                       | Input High Voltage        | V <sub>ih_ddr</sub> | VREF + 0.1  | 1.5  | MVDD                                  | V     |
|                       | Input Low Voltage         | V <sub>il_ddr</sub> | -0.3        | 0    | VREF - 0.1                            | V     |
| DDR IO                | Output High Voltage       | V <sub>oh_ddr</sub> | 0.8 * MVDD  | 1.5  | N/A                                   | V     |
| @DDR3 mode            | Output Low Voltage        | V <sub>ol_ddr</sub> | N/A         | 0    | 0.2 * MVDD                            | V     |
| @DDN3 mode            | Input termination         |                     | 100         | 120  | 140                                   |       |
|                       | resistance(ODT) to        | R <sub>tt</sub>     | 54          | 60   | 66                                    | Ohm   |
|                       | VDDIO_BLi/2 (i=0~3)       |                     | 36          | 40   | 44                                    |       |
|                       | Input High Voltage        | V <sub>ih_ddr</sub> | VREF + 0.13 | 1.2  | MVDD                                  | V     |
| DDR IO                | Input Low Voltage         | V <sub>il_ddr</sub> | -0.3        | 0    | VREF- 0.13                            | V     |
| @LPDDR2 mode          | Output High Voltage       | V <sub>oh_ddr</sub> | 0.9 * MVDD  | 1.2  | N/A                                   | V     |
|                       | Output Low Voltage        | V <sub>ol_ddr</sub> | N/A         | 0    | 0.1 * MVDD                            | V     |

# 1.5.4 Recommended Operating Frequency

Table 1-9 Recommended operating frequency for PD\_ALIVE domain

| Parameter      | Condition      | Symbol          | MIN | TYP | MAX  | Unit |
|----------------|----------------|-----------------|-----|-----|------|------|
|                | 1.1V , 25 ℃    |                 | 24  | 24  | 24   |      |
| XIN Oscillator | 1.21V , -40 °C | IO_XIN24M       | 24  | 24  | 24   | MHz  |
|                | 0.99V , 125 °C |                 | 24  | 24  | 24   |      |
|                | 1.1V , 25 ℃    |                 | N/A | N/A | 1333 |      |
| DDR PLL        | 1.21V , -40 °C | ddr_pll_clk     | N/A | N/A | 1976 | MHz  |
|                | 0.99V , 125 °C |                 | N/A | N/A | 835  |      |
|                | 1.1V , 25 °C   |                 | N/A | N/A | 1250 |      |
| ARM PLL        | 1.21V , -40 °C | arm_pll_clk     | N/A | N/A | 1683 | MHz  |
|                | 0.99V , 125 °C |                 | N/A | N/A | 800  |      |
|                | 1.1V , 25 ℃    |                 | N/A | N/A | 1108 |      |
| CODEC PLL      | 1.21V , -40 °C | cocec_pll_clk   | N/A | N/A | 1572 | MHz  |
|                | 0.99V , 125 °C |                 | N/A | N/A | 734  |      |
|                | 1.1V , 25 °C   |                 | N/A | N/A | 1392 |      |
| GENERAL PLL    | 1.21V , -40 °C | general_pll_clk | N/A | N/A | 1529 | MHz  |
|                | 0.99V , 125 °C |                 | N/A | N/A | 717  |      |
|                | 1.1V , 25 °C   |                 | N/A | N/A | 273  |      |
| UART1CLK       | 1.21V , -40 °C | clk_uart1       | N/A | N/A | 304  | MHz  |
|                | 0.99V , 125 °C |                 | N/A | N/A | 200  |      |
|                | 1.1V , 25 °C   |                 | N/A | N/A | 211  |      |
| TIMER2 CLK     | 1.21V , -40 °C | clk_timer2      | N/A | N/A | 349  | MHz  |
|                | 0.99V , 125 °C |                 | N/A | N/A | 132  |      |

Table 1-10 Recommended operating frequency for A9 core

| Parameter  | Condition      | Symbol        | MIN | TYP | MAX  | Unit |
|------------|----------------|---------------|-----|-----|------|------|
|            | 1.1V , 25 ℃    | clk_core_pre  | N/A | N/A | 1131 |      |
| 11         | 1.21V , -40 ℃  |               | N/A | N/A | 1333 | MHz  |
| Contact AO | 0.99V , 125 °C |               | N/A | N/A | 758  |      |
| Cortex-A9  | 1.1V , 25 ℃    | clk_core_peri | N/A | N/A | 178  |      |
|            | 1.21V , -40 ℃  |               | N/A | N/A | 269  | MHz  |
|            | 0.99V , 125 ℃  |               | N/A | N/A | 122  |      |

Table 1-11 Recommended operating frequency for PD\_CPU domain

| Parameter    | Condition      | Symbol   | MIN | TYP | MAX | Unit |
|--------------|----------------|----------|-----|-----|-----|------|
|              | 1.1V , 25 ℃    |          | N/A | N/A | 540 |      |
|              | 1.21V , -40 °C | aclk_cpu | N/A | N/A | 877 | MHz  |
| CDLLAVI      | 0.99V , 125 ℃  |          | N/A | N/A | 358 |      |
| CPU AXI      | 1.1V , 25 ℃    | hclk_cpu | N/A | N/A | 467 |      |
| interconnect | 1.21V , -40 °C |          | N/A | N/A | 300 | MHz  |
|              | 0.99V , 125 ℃  |          | N/A | N/A | 198 |      |
|              | 1.1V , 25 ℃    | pclk_cpu | N/A | N/A | 136 | MHz  |



|                | 1.21V , -40 ℃  |                           | N/A | N/A | 205  |     |
|----------------|----------------|---------------------------|-----|-----|------|-----|
|                | 0.99V , 125 °C |                           | N/A | N/A | 95   |     |
|                | 1.1V , 25 ℃    |                           | N/A | N/A | 588  |     |
| DMC            | 1.21V , -40 °C | clk_ddr                   | N/A | N/A | 909  | MHz |
|                | 0.99V , 125 °C |                           | N/A | N/A | 394  |     |
|                | 1.1V , 25 ℃    |                           | N/A | N/A | 322  |     |
| Embedded SRAM  | 1.21V , -40 °C | aclk_intmem               | N/A | N/A | 500  | MHz |
|                | 0.99V , 125 °C |                           | N/A | N/A | 216  |     |
|                | 1.1V , 25 ℃    |                           | N/A | N/A | 356  |     |
| SPDIF          | 1.21V , -40 °C | clk_spdif                 | N/A | N/A | 588  | MHz |
|                | 0.99V , 125 °C |                           | N/A | N/A | 219  |     |
|                | 1.1V , 25 ℃    | alle timarO/              | N/A | N/A | 177  | (V) |
| Timer0/1       | 1.21V , -40 °C | clk_timer0/<br>clk_timer1 | N/A | N/A | 108  | MHz |
|                | 0.99V , 125 °C | cik_timer i               | N/A | N/A | 2500 | Y   |
|                | 1.1V , 25 ℃    |                           | N/A | N/A | 263  |     |
| UART0          | 1.21V , -40 °C | clk_uart0                 | N/A | N/A | 301  | MHz |
|                | 0.99V , 125 °C |                           | N/A | N/A | 218  |     |
|                | 1.1V , 25 °C   | clk_i2s0/                 | N/A | N/A | 60   |     |
| I2S0/I2S1/I2S2 | 1.21V , -40 ℃  | clk_i2s1/                 | N/A | N/A | 69   | MHz |
|                | 0.99V , 125 °C | clk_i2s2                  | N/A | N/A | 52   |     |

Table 1-12 Recommended operating frequency for PD\_PERI domain

| Parameter             | Condition      | Symbol       | MIN | TYP | MAX | Unit   |  |
|-----------------------|----------------|--------------|-----|-----|-----|--------|--|
|                       | 1.1V , 25 ℃    |              | N/A | N/A | 480 |        |  |
|                       | 1.21V , -40 °C | aclk_periph  | N/A | N/A | 725 | MHz    |  |
|                       | 0.99V , 125 ℃  |              | N/A | N/A | 314 |        |  |
| PERI AXI interconnect | 1.1V , 25 ℃    |              | N/A | N/A | 237 |        |  |
|                       | 1.21V , -40 °C | hclk_periph  | N/A | N/A | 370 | MHz    |  |
|                       | 0.99V , 125 ℃  |              | N/A | N/A | 150 |        |  |
|                       | 1.1V , 25 ℃    |              | N/A | N/A | 135 |        |  |
| C >                   | 1.21V , -40 ℃  | pclk_periph  | N/A | N/A | 213 | MHz    |  |
|                       | 0.99V , 125 ℃  |              | N/A | N/A | 94  |        |  |
|                       | 1.1V , 25 ℃    | clk_smc      | N/A | N/A | 234 | MHz    |  |
| SMC                   | 1.21V , -40 ℃  |              | N/A | N/A | 395 |        |  |
|                       | 0.99V , 125 ℃  |              | N/A | N/A | 159 |        |  |
|                       | 1.1V , 25 ℃    |              | N/A | N/A | 251 |        |  |
| NANDC                 | 1.21V , -40 °C | hclk_nandc   | N/A | N/A | 395 | MHz    |  |
|                       | 0.99V , 125 ℃  |              | N/A | N/A | 162 |        |  |
|                       | 1.1V , 25 ℃    |              | N/A | N/A | 161 |        |  |
| USB Host              | 1.21V , -40 °C | clk_otgphy1  | N/A | N/A | 266 | MHz    |  |
|                       | 0.99V , 125 °C |              | N/A | N/A | 101 |        |  |
| LICE OTC              | 1.1V , 25 °C   | alls atambus | N/A | N/A | 128 | NAL I— |  |
| USB OTG               | 1.21V , -40 °C | clk_otgphy0  | N/A | N/A | 212 | MHz    |  |



|            | 0.001/ 405.90  |             |     |     |     |          |
|------------|----------------|-------------|-----|-----|-----|----------|
|            | 0.99V , 125 °C |             | N/A | N/A | 80  |          |
|            | 1.1V , 25 ℃    | " 10/       | N/A | N/A | 278 |          |
| UART2/3    | 1.21V , -40 ℃  | clk_uart2/  | N/A | N/A | 304 | MHz      |
|            | 0.99V , 125 ℃  | clk_uart3   | N/A | N/A | 250 |          |
|            | 1.1V , 25 ℃    |             | N/A | N/A | 192 |          |
| SDMMC/SDIO | 1.21V , -40 °C | clk_sdmmc0/ | N/A | N/A | 311 | MHz      |
|            | 0.99V , 125 °C | clk_sdio    | N/A | N/A | 121 |          |
|            | 1.1V , 25 ℃    |             | N/A | N/A | 185 |          |
| EMMC       | 1.21V , -40 °C | clk_emmc    | N/A | N/A | 299 | MHz      |
|            | 0.99V , 125 °C |             | N/A | N/A | 117 |          |
|            | 1.1V , 25 ℃    |             | N/A | N/A | 54  |          |
| MAC        | 1.21V , -40 °C | clk_mac_ref | N/A | N/A | 58  | MHz      |
|            | 0.99V , 125 °C |             | N/A | N/A | 52  |          |
|            | 1.1V , 25 ℃    | -U:0/       | N/A | N/A | 91  | <b>Y</b> |
| SPI0/1     | 1.21V , -40 °C | clk_spi0/   | N/A | N/A | 100 | MHz      |
|            | 0.99V , 125 °C | clk_spi1    | N/A | N/A | 86  |          |
|            | 1.1V , 25 ℃    |             | N/A | N/A | 69  |          |
| SAR-ADC    | 1.21V , -40 °C | clk_saradc  | N/A | N/A | 78  | MHz      |
|            | 0.99V , 125 °C |             | N/A | N/A | 59  |          |
|            | 1.1V , 25 ℃    |             | N/A | N/A | 22  |          |
| TS-ADC     | 1.21V , -40 °C | clk_tsadc   | N/A | N/A | 23  | MHz      |
|            | 0.99V , 125 °C |             | N/A | N/A | 21  |          |
|            | 1.1V , 25 ℃    |             | N/A | N/A | 68  |          |
| HSADC      | 1.21V , -40 °C | clk_hsadc   | N/A | N/A | 77  | MHz      |
|            | 0.99V , 125 °C |             | N/A | N/A | 58  |          |

Table 1-13 Recommended operating frequency for PD\_VIO domain

| Parameter                   | Condition      | Symbol                    | MIN | TYP | MAX | Unit     |  |
|-----------------------------|----------------|---------------------------|-----|-----|-----|----------|--|
|                             | 1.1V , 25 ℃    |                           | N/A | N/A | 482 |          |  |
|                             | 1.21V , -40 °C | aclk_lcdc0                | N/A | N/A | 739 | MHz      |  |
|                             | 0.99V , 125 ℃  |                           | N/A | N/A | 314 |          |  |
| Disalau AVI                 | 1.1V , 25 ℃    |                           | N/A | N/A | 476 |          |  |
| Display AXI interconnection | 1.21V , -40 °C | aclk_lcdc1                | N/A | N/A | 736 | MHz      |  |
|                             | 0.99V , 125 ℃  |                           | N/A | N/A | 310 | <u> </u> |  |
|                             | 1.1V , 25 ℃    |                           | N/A | N/A | 377 | MHz      |  |
|                             | 1.21V , -40 °C | hclk_lcdc                 | N/A | N/A | 648 |          |  |
|                             | 0.99V , 125 °C |                           | N/A | N/A | 235 |          |  |
|                             | 1.1V , 25 ℃    | dells lade0/              | N/A | N/A | 269 |          |  |
| LCDC0/1                     | 1.21V , -40 °C | dclk_lcdc0/<br>dclk_lcdc1 | N/A | N/A | 448 | MHz      |  |
|                             | 0.99V , 125 °C | dcik_icdc i               | N/A | N/A | 168 |          |  |
|                             | 1.1V , 25 °C   | nollsin oifO/             | N/A | N/A | 101 |          |  |
| CIF0/1                      | 1.21V , -40 °C | pclkin_cif0/              | N/A | N/A | 103 | MHz      |  |
|                             | 0.99V , 125 ℃  | pclkin_cif1               | N/A | N/A | 103 |          |  |



|      | 1.1V , 25 °C   |          | N/A | N/A | 417 |     |
|------|----------------|----------|-----|-----|-----|-----|
| HDMI | 1.21V , -40 °C | clk_hdmi | N/A | N/A | 648 | MHz |
|      | 0.99V , 125 °C |          | N/A | N/A | 258 |     |

Table 1-14 Recommended operating frequency PD\_GPU domain

| Parameter | Condition      | Symbol   | MIN | TYP | MAX | Unit |
|-----------|----------------|----------|-----|-----|-----|------|
| GPU       | 1.1V , 25 ℃    |          | N/A | N/A | 480 |      |
|           | 1.21V , -40 °C | aclk_gpu | N/A | N/A | 717 | MHz  |
|           | 0.99V , 125 °C |          | N/A | N/A | 318 |      |

Table 1-15 Recommended operating frequency for PD VIDEO domain

| Parameter | Condition      | Symbol    | MIN | TYP | MAX | Unit |
|-----------|----------------|-----------|-----|-----|-----|------|
|           | 1.1V , 25 ℃    |           | N/A | N/A | 479 |      |
|           | 1.21V , -40 °C | aclk_vepu | N/A | N/A | 738 | MHz  |
|           | 0.99V , 125 ℃  |           | N/A | N/A | 316 |      |
|           | 1.1V , 25 ℃    |           | N/A | N/A | 126 |      |
|           | 1.21V , -40 °C | hclk_vepu | N/A | N/A | 197 | MHz  |
| VIDEO     | 0.99V , 125 ℃  |           | N/A | N/A | 86  |      |
| VIDEO     | 1.1V , 25 ℃    |           | N/A | N/A | 417 |      |
|           | 1.21V , -40 °C | aclk_vdpu | N/A | N/A | 648 | MHz  |
|           | 0.99V , 125 ℃  |           | N/A | N/A | 275 |      |
|           | 1.1V , 25 ℃    |           | N/A | N/A | 115 |      |
|           | 1.21V , -40 °C | hclk_vdpu | N/A | N/A | 179 | MHz  |
|           | 0.99V , 125 ℃  |           | N/A | N/A | 78  |      |

# 1.5.5 Electrical Characteristics for General IO

Table 1-16RK30xx Electrical Characteristics for Digital General IO

|                 | Parameters                                | Symbol          | Test condition                | Min | Тур | Max | Units |
|-----------------|-------------------------------------------|-----------------|-------------------------------|-----|-----|-----|-------|
|                 | Input leakage current                     | l <sub>i</sub>  | Vin = 3.3V or 0V              | -10 | N/A | 10  | uA    |
| Digital         | Tri-state output leakage current  Digital | l <sub>oz</sub> | Vout = 3.3V or 0V             | -10 | N/A | 10  | uA    |
| GPIO            | High level input current                  |                 | Vin = 3.3V, pulldown disabled | TBD | N/A | TBD | uA    |
| @3.3V           |                                           | l <sub>ih</sub> | Vin = 3.3V, pulldown enabled  | 32  | 52  | 77  | uA    |
|                 |                                           | I <sub>il</sub> | Vin = 0V, pullup disabled     | TBD | N/A | TBD | uA    |
|                 | Low level input current                   |                 | Vin = 0V, pullup enabled      | 36  | 55  | 80  | uA    |
|                 | Input leakage current                     | $I_j$           | Vin = 1.8V or 0V              | -10 | N/A | 10  | uA    |
|                 | Tri-state output leakage current          | l <sub>oz</sub> | Vout = 1.8V or 0V             | -10 | N/A | 10  | uA    |
| Digital<br>GPIO | High level input current                  |                 | Vin = 1.8V, pulldown disabled | TBD | N/A | TBD | uA    |
| @1.8V           | r light level input current               | l <sub>ih</sub> | Vin = 1.8V, pulldown enabled  | 7.7 | 14  | 25  | uA    |
|                 | Low lovel input current                   |                 | Vin = 0V, pullup disabled     | TBD | N/A | TBD | uA    |
|                 | Low level input current                   | l <sub>il</sub> | Vin = 0V, pullup enabled      | 8.3 | 14  | 23  | uA    |



# 1.5.6 Electrical Characteristics for PLL

Table 1-17 RK30xx Electrical Characteristics for PLL

| Parameters             | Symbol        | Test condition                                                         | Min   | Тур | Max  | Units |
|------------------------|---------------|------------------------------------------------------------------------|-------|-----|------|-------|
| Input clock frequency  | Fin           | $F_{in} = F_{ref}^* NR^{\oplus}$ @1.1V                                 | 0.183 | 24  | 1500 | MHz   |
| Comparison frequency   | Fref          | Fref = Fin / NR @1.1V                                                  | 0.183 | N/A | 1500 | MHz   |
| VCO operating range    | F <i>v</i> co | $F_{VCO} = F_{ref} * NF^{\oplus}$ @1.1V                                | 300   | N/A | 1500 | MHz   |
| Output clock frequency | Fout          | $F_{out} = F_{VCO} / NO^{\textcircled{1}} \qquad \textcircled{2} 1.1V$ | 18.75 | N/A | 1500 | MHz   |
| Lock time              | T/t           | (NR * 500)/ Fin @1.1V                                                  | N/A   | N/A | N/A  | N/A   |
| Power consumption      | N/A           | Fout = 750MHz, NO = 1 @1.1V                                            | N/A   | 3   | N/A  | mA    |

Notes: <sup>①</sup> NR is the input divider value;

NF is the feedback divider value; NO is the output divider value

### 1.5.7 Electrical Characteristics for SAR-ADC

Table 1-18 RK30xx Electrical Characteristics for SAR-ADC

| Parameters                 | Symbol              | Test condition                           | Min  | Тур | Max  | Units            |
|----------------------------|---------------------|------------------------------------------|------|-----|------|------------------|
| ADC resolution             | N                   | . ()                                     | N/A  | 10  | N/A  | bits             |
| Analog Supply Voltage      | VDDio               |                                          | 2.25 | 2.5 | 2.75 | V                |
| Digital Supply Voltage     | VDDCore             | X                                        | 1.0  | 1.1 | 1.2  | V                |
| Conversion speed           | F <sub>s</sub>      | The duty cycle should be between 40%~60% | N/A  | N/A | 1    | MSPS             |
| Analog Supply Current      | lavdd               |                                          | N/A  | 200 | N/A  | uA               |
| Digital Supply Current     | IDVDD               |                                          | N/A  | 50  | N/A  | uA               |
| Number of Channels         | NCH AVDD            |                                          | N/A  | 8   | N/A  | N/A              |
| Differential Non Linearity | DNL                 |                                          | N/A  | ±1  | N/A  | LSB              |
| Integral Non Linearity     | INL                 | 7.7                                      | N/A  | ±2  | N/A  | LSB              |
| Gain Error                 | E <sub>gain</sub>   | ,                                        | -8   | N/A | 8    | LSB              |
| Offset Error               | E <sub>offset</sub> |                                          | -8   | N/A | 8    | mV               |
| Power Down Current         | ISHDN               | From AVDD                                | N/A  | 0.5 | N/A  | uA               |
| Fower Down Current         | ISHDIN              | From DVDD                                | N/A  | 0.5 | N/A  | uA               |
| Power up time              |                     |                                          | N/A  | 7   | N/A  | 1/F <sub>s</sub> |

# 1.5.8 Electrical Characteristics for TS-ADC

Table 1-19 RK30xx Electrical Characteristics for TS-ADC

| Parameters             | Symbol | Test condition | Min  | Тур | Max  | Units |
|------------------------|--------|----------------|------|-----|------|-------|
| Analog Supply Voltage  | AVDD   |                | 2.25 | 2.5 | 2.75 | V     |
| Digital Supply Voltage | DVDD   |                | 1.0  | 1.1 | 1.2  | V     |
| TSADC Accuracy         |        |                | N/A  | N/A | ±5   | С     |
| Online and Onese at    | IQ     | From AVDD      | N/A  | 180 | N/A  | uA    |
| Quiescent Current      | IQ     | From DVDD      | N/A  | 40  | N/A  | uA    |
| Power Down Current     | ISHDN  | From AVDD      | N/A  | 1   | N/A  | uA    |
| Fower Down Cultent     | ISHDIN | From DVDD      | N/A  | 5   | N/A  | uA    |



| Number of Channels (Differential) |      | 7 external, 1 internal | N/A | 8   | N/A  | N/A  |
|-----------------------------------|------|------------------------|-----|-----|------|------|
| Clock Frequency                   | Fclk |                        | N/A | N/A | 50.0 | KHz  |
| Power up time                     |      |                        | N/A | N/A | 7    | TCLK |
| Latency                           |      |                        | N/A | N/A | 1    | TCLK |

# 1.5.9 Electrical Characteristics for USB OTG/Host2.0 Interface

Table 1-20 RK30xx Electrical Characteristics for USB OTG/Host2 0 Interface

| Para                    | ameters                | Test condition                    | Min | Тур   | Max | Units |
|-------------------------|------------------------|-----------------------------------|-----|-------|-----|-------|
| HS transmit, maximum    | Current From OTG_DVDD  |                                   | N/A | 5.35  | N/A | mA    |
| transition density      | Current From OTG_VDD33 |                                   | N/A | 2.50  | N/A | mA    |
| (all 0's data in DP/DM) | Current From OTG_VDD25 |                                   | N/A | 21.2  | N/A | mA    |
| HS transmit, minimum    | Current From OTG_DVDD  |                                   | N/A | 4.07  | N/A | mA    |
| transition density      | Current From OTG_VDD33 |                                   | N/A | 2.25  | N/A | mA    |
| (all 1's data in DP/DM) | Current From OTG_VDD25 |                                   | N/A | 17    | N/A | mA    |
|                         | Current From OTG_DVDD  |                                   | N/A | 5.4   | N/A | mA    |
| HS idle mode            | Current From OTG_VDD33 | <b>^</b>                          | N/A | 2.22  | N/A | mA    |
|                         | Current From OTG_VDD25 | <b>75</b> ℃ ,                     | N/A | 6.23  | N/A | mA    |
| FS transmit, maximum    | Current From OTG_DVDD  | OTG_VDD25 = HOST_VDD25 = 2.5V,    | N/A | 3.25  | N/A | mA    |
| transition density      | Current From OTG_VDD33 | OTG_VDD33 = HOST_VDD33 = 3.3V,    | N/A | 16.5  | N/A | mA    |
| (all 0's data in DP/DM) | Current From OTG_VDD25 | OTG_DVDD = HOST_DVDD = 1.1V ,     | N/A | 6.47  | N/A | mA    |
| LS transmit, maximum    | Current From OTG_DVDD  | 15-cm USB cable attached to DP/DM | N/A | 3.62  | N/A | mA    |
| transition density      | Current From OTG_VDD33 |                                   | N/A | 16.9  | N/A | mA    |
| (all 0's data in DP/DM) | Current From OTG_VDD25 |                                   | N/A | 6.39  | N/A | mA    |
|                         | Current From OTG_DVDD  |                                   | N/A | 61.2  | N/A | uA    |
| Suspend mode            | Current From OTG_VDD33 |                                   | N/A | 0.1   | N/A | uA    |
|                         | Current From OTG_VDD25 | · >                               | N/A | 17.0  | N/A | uA    |
|                         | Current From OTG_DVDD  |                                   | N/A | 0.2   | N/A | mA    |
| Sleep mode              | Current From OTG_VDD33 |                                   | N/A | 0.1   | N/A | uA    |
|                         | Current From OTG_VDD25 |                                   | N/A | 0.348 | N/A | mA    |

# 1.5.10 Electrical Characteristics for HDMI

Table 1-21 RK30xx Electrical Characteristics for HDMI

| Parameters               | Symbol | Test condition    | Min  | Тур  | Max  | Units |
|--------------------------|--------|-------------------|------|------|------|-------|
| 2.5V Supply Voltage      | VDDH   | 2.5±10%           | 2.25 | 2.5  | 2.75 | V     |
| 1.1V Supply Voltage      | VDDL   | 1.1±10%           | 0.99 | 1.1  | 1.21 | V     |
| REXT Resistance Error    | DREXT  | 470ohms           | -1   | 0    | 1    | %     |
| D2-0[9:0] Setup Time     | TSU    | To TMDS_CK        | 700  | N/A  | N/A  | ps    |
| D2-0[9:0] Hold Time      | THLD   | To TMDS_CK        | 700  | N/A  | N/A  | ps    |
| MSENS detect voltage for | VCNCT  | (VTXC+VTXC_N) / 2 | 2    | N/A  | N/A  | V     |
| monitor connection       |        | · - /             |      |      |      |       |
| MSENS detect voltage for | VDISC  | (VTXC+VTXC_N) / 2 | N/A  | N/A  | 0.4  | V     |
| monitor disconnection    | VDIGO  | (VIXO+VIXO_N)/2   | IN/A | IN/A | 0.4  | V     |



| MSENS response time        | TMSENS    |        | 3   | N/A | 15  | us     |
|----------------------------|-----------|--------|-----|-----|-----|--------|
| OSC minimum oscillation    | FMINDDC   | IDCK=L | 20  | 30  | 40  | MHz    |
| frequency when f(IDCK)=0Hz | FIVIINDDC | IDCK=L | 20  | 30  | 40  | IVIITZ |
| Supply Current (2.5V)      | IDDH      |        | N/A | N/A | TBD | mA     |
| Supply Current (1.1V)      | IDDL      |        | N/A | N/A | TBD | mA     |
| Activation Time From Sleep | TACT      |        | N/A | N/A | 1   | ms     |

#### 1.5.11 Electrical Characteristics for DDR IO

Table 1-22 RK30xx Electrical Characteristics for DDR IO

| F            | Parameters                  | Symbol | Test condition | Min  | Тур  | Max   | Units |
|--------------|-----------------------------|--------|----------------|------|------|-------|-------|
|              | DDR IO power standby        |        | @ 1.5V , 125℃  | N/A  | 0.02 | 14.47 | uA    |
| DDR IO       | current, ODT OFF            |        | @ 1.5V , 125 C | IN/A | 0.02 | 14.47 | uA    |
| @DDR3 mode   | Input leakage current, SSTL |        | @ 1.5V , 125℃  | N/A  | 0.02 | 5.06  | uA    |
|              | mode, unterminated          |        | @ 1.5V , 125 C | IN/A | 0.02 | 5.06  | uA    |
|              | Input leakage current       |        | @ 1.2V , 125℃  | N/A  | 0.01 | 4.51  | uA    |
| DDR IO       | VDD quiescent current       |        | @ 1.1V , 125℃  | N/A  | 0.02 | 4.21  | uA    |
| @LPDDR2 mode | DDR IO power quiescent      |        | @ 4.3V 435°C   | N/A  | 0.02 | 12.31 |       |
|              | current                     |        | @ 1.2V , 125℃  | IN/A | 0.02 | 12.31 | uA    |

# 1.5.12 Electrical Characteristics for eFuse

Table 1-23 RK30xx Electrical Characteristics for eFuse

|         | Parameters                | Symbol       | Test condition | Min   | Тур   | Max   | Units |
|---------|---------------------------|--------------|----------------|-------|-------|-------|-------|
|         | read current for eFuse    |              | STROBE high    | 2.537 | 4.049 | 5.695 | mA    |
| Active  | digital core logic(1.1V)  | I load_vdd   | 31KOBE nign    | 2.557 | 4.049 | 5.095 | IIIA  |
| mode    | read current for eFuse    | _            | normal read    | 1.498 | 2.368 | 3.308 | mA    |
|         | digital core logic (1.1V) | lactive_vdd  | 10MHz          | 1.490 | 2.300 | 3.306 | mA    |
| standby | standby current for eFuse | <b>X</b>     |                | 0.057 | 0.255 | 0.492 |       |
| mode    | digital core logic (1.1V) | 1standby_vdd |                | 0.057 | 0.255 | 0.492 | uA    |

# 1.6 Hardware Guideline

# 1.6.1 Reference design for RK30xx oscillator PCB connection

RK30xx only use one oscillator, and its typical clock frequency is 24MHz. The oscillator will provide input clock to four on-chip PLLs.

External reference circuit for oscillators with 24MHz input

In the following diagram, the value for Rf,Rd,C1,C2 must be adjusted a little to improve performance of oscillator based on real crystal model . Especially C1 and C2 value is advised to meet formula (C1 \* C2)/(C1+C2) =  $\sim$ 8pF





Fig. 1-7 External Reference Circuit for 24MHzOscillators

#### 1.6.2 Reference design for PLL PCB connection

The following reference design is suitable for PLL in RK30xx.

The PLL's two analog supplies should be filtered with two series ferritebeads and two shunt 0.1uF and 0.01uF capacitors. The ferrite on VSS ispreferred but optional. Adding the ferrite on VSS converts supply noiseto substrate noise as seen by the PLL. The PLLs are designed to berelatively insensitive to supply and substrate noise, so the presence of this ferrite is a second order issue.

The VDD/VSS is mapped to VDD\_APLL/VSS\_APLL, VDD\_DPLL/VSS\_DPLL and VDD\_CGPLL/VSS\_CGPLL.

The AVDD/AVSS is mapped to AVDD\_APLL/AVSS\_APLL, AVDD\_DPLL/ AVSS\_DPLL and AVDD\_CGPLL/AVSS\_CGPLL.



Fig. 1-8 External reference circuit for PLL

The ferrite beads should be similar one of the following from Murata: Table 1-24 Ferrite Bead Selection

| Part number   | R@DC | Z@10MHz | Z@100MHz | size |
|---------------|------|---------|----------|------|
| BLM18EG601SN1 | 0.35 | 200     | 600      | 0603 |
| BLM18PG471SN1 | 0.2  | 130     | 470      | 0603 |
| BLM18KG601SN1 | 0.15 | 160     | 600      | 0603 |
| BLM18AG601SN1 | 0.38 | 180     | 600      | 0603 |
| BLM18AG102SN1 | 0.5  | 280     | 1000     | 0603 |

| Rockchip<br><sup>瑞芯微电子</sup> | RK3 | 0xx |
|------------------------------|-----|-----|
|------------------------------|-----|-----|

| BLM18TG601TN1 | 0.45 | 190 | 600  | 0603 |
|---------------|------|-----|------|------|
| BLM15AG601SN1 | 0.6  | 200 | 600  | 0402 |
| BLM15AX601SN1 | 0.34 | 190 | 600  | 0402 |
| BLM15AX102SN1 | 0.49 | 250 | 1000 | 0402 |
| BLM03AX601SN1 | 0.85 | 120 | 600  | 0201 |

Similar ferrite beads are also available from Panasonic. The keycharacteristics to select are:

- DC resistance less than 0.40 ohms
- impedance at 10MHz equal to or greater 180 ohms
- impedance at 100MHz equal to or greater than 600 ohms
  The capacitors should be mounted as close to the package balls aspossible.

# 1.6.3 Reference design for USB OTG/Host2.0 connection

In RK30xx there are USB OTG and USB Host2.0 interface, in fact, same interface is for them. The following diagram shows external reference design. Of course, for USB Host2.0 some signals can be removed based on different application.



Fig. 1-9 RK30xx USB OTG/Host2.0 interface reference connection

### 1.6.4 Reference design for HDMI Tx PHY connection

In RK30xx, the following diagram shows external PCB reference design for HDMI Tx PHY.



Fig. 1-10RK30xx HDMI interface reference connection

### 1.6.5 RK30xx Power up/down sequence requirement

For all of the power supply in RK30xx, there is no any specific requirement of power up/down sequence except power supply between core logic and DDR3/LPDDR2 IO or digital GPIO, between USB OTG/Host2.0 power supply.

Power supply sequence for core logic(CVDD/AVDD/PVDD) and DDR3/LPDDR2 IO (MVDD)

It is generally recommended that the core logic and DDR IO be powered-up together, and it is also acceptable for core logic supply to power-up a very short time before the DDR IO supply. If DDR IO supply must power-up before the core logic supply, it is advised to keep the time between these two events less than 100ms to limit excessive DDR IO current draws.

Power supply sequence for core logic(CVDD/AVDD/PVDD) and digital GPIO

It is generally recommended that "turn on the higher GPIO voltage first and then the lower core voltage" so that the crowbar current would not occur on the power-up stage.

Also it is acceptable that "turn on the lower core voltage first and then higher GPIO voltage" only if the GPIO control pins are set to a fixed state. However, the ramp-up time for them can not be less than 10us.

There is no requirement on the power-down sequence for two above groups. Customers can decide which voltage to be down first based on the application need.

Power supply sequence for USB OTG/Host2.0

Please follow the following sequence for power up and recommended ramp-up time is more than 10us

OTG\_DVDD (1.1V)->OTG\_VDD25 (2.5V)->OTG\_VDD33 (3.3V) HOST\_DVDD (1.1V)->HOST\_VDD25 (2.5V)->HOST\_VDD33 (3.3V) For power down sequence, just reverse with power up sequence. OTG\_VDD33 (3.3V)->OTG\_VDD25 (2.5V)->OTG\_DVDD (1.1V) HOST VDD33 (3.3V)->HOST VDD25 (2.5V)->HOST DVDD (1.1V) Notes: <sup>©</sup> digital GPIO power include LCD0\_VCCj, LCD1\_VCC, CIFj\_VCC, PVCC, APj\_VCC, SMC\_VCC, FLASH\_VCC, VCCIOj.

### 1.6.6 RK30xx Power on reset descriptions

The following figure shows power-on-reset sequence. External power-on-reset input signal NPOR is released after stabilization of oscillator input clock XIN24M. Internal signal sysrstn is generated after NPOR is filtered glitch , which can filter out 5 clock cycles(24MHz) for low pulse of NPOR, so 208ns low pulse of NPOR will not be recognized as valid power-on-reset signal for RK30xx.

To make PLLs work normally, the internal power down signal(pllpd) for PLLs must be high after power-on-reset, and maintains high level for more than 1us after sysrstn is deasserted. Then PLL reset signals(pllrstn) are asserted for about 10.6us, and PLLs start to lock when pllrstn deassert, and consume about to 1330us to lock.

So the system will wait about 1330us, then deactive internal reset signal chiprstn, which is used to control generation logic of all the clock inside CRU.

After 256 cycles or about 10.7us , rstn\_pre for reset signal of all internal IPs will be deasserted , in other words, about 10.7us of clock has been generated before reset of every internal module is released.



Fig. 1-11 RK30xx reset signals sequence

# **Chapter 2 System Overview**

# 2.1 Address Mapping

Since RK30xx support to boot from internal bootrom, embedded SRAM or external nor flash , they have two types of address mapping, which is decided by BTMODE off-chip input signal .

Also they always support remap function by software programming. In the following description, remap is value for GRF\_SOC\_CON0 bit[12] .

BTMODE=Low Level , remap function is disabled (default state)



Fig. 2-1 RK30xx Address Mapping when BTMODE=low before remap



# BTMODE=Low Level , remap function is enable



Fig. 2-2 RK30xx Address Mapping when BTMODE=lowafter remap



#### 1013\_E000 1013 D00 1013\_C60 Core Global Tir (1K) 1013 C200 1013\_C100 Core SCU (256B) 1013\_C000 L2C Controlle (16K) Reserved (15M) 2004 4000 1013 800 1210\_000 DDR\_PUBL (16K) SMC Bank1 (1M) Reserved (32K) 2004 000 1013\_0000 APB GPIO2 CPU AXI BUS (32K) Reserved (15M) 1110\_0000 000F\_FFFF/110F\_FFFF 2003\_E000 1012\_8000 6000 0000 APB GPIO1 (8K) APB UART1 SMC Bank0 (1M) 0000\_0000/1100\_000 2003\_C00 1012\_6000 APB UARTO (8K) APB Timer1 (8K) 2003\_A00 1050 400 1012\_4000 APB Timer0 NandC (16K) Reserved (16K) Reserved (80K) 2003 8000 2008 C000 APB GPIOO (16K) SPDIF (8K) 1040\_0000 2003\_400 I2S2/PCM(2ch) (8K) APB PWM0/1 (16K) Peri AXI BUS APB GPIO4 (16K) 1011 C000 2003\_000 2008\_400 APB I2C1 (8K) I2S1/PCM(2ch) (8K) APB GPIO3 2002 E000 I2S0/PCM(8ch) (8K) AHB Arbiter1 (16K) APB 12C0 (8K) APB SMC Reg (16K) 1011 8000 1022\_8000 2002\_C00 2007\_C00 AHB Arbiter0 (16K) APB DMAC2 Reg 1011 6000 1022 4000 2002 4000 RGA (8K) PID\_FILTER DDR\_PCTL (16K) APB SPI1 (16K) 1011 4000 1022 0000 2002 000 2007\_4000 APB DMAC1 Reg (16K) IPP (16K) APB SPIO 2001 C00 1021\_C00 LCDC1 SDIO (16K) APB SAR-ADC 2001\_8000 1010 E000 1021\_8000 SD/MMC0 (16K) APB UART3 (16K) 2001\_400 1010 C000 CIF1 (8K) HSADC/TSI (16K) APB eFuse (16K) APB UART2 (16K) 1010 A000 1021 0000 2001 0000 APB TSADC (16K) GPS (16K) APB Timer3 (8K) 1010 8000 2000 E000 2006\_0000 VCodeo (16K) APB I2C4 (16K) Reserved (16K) 1010\_4000 1020 8000 2000\_C00 ROM (16K) APB GPIO6 (8K) APB I2C3 (16K) MAC (16K) 1010\_0000 2000 A00 APB GRE Reserved (384K) Reserved (16K) 100a 000 1020\_000 2000 8000 2005\_4000 APB PWM2/3 (16K) USB HOST2.0 (256K) APB PMU (16K) 1009\_000 101C\_0000 2000 4000 2005\_0000 Internal Mem (64K) APB WDT USB OTG (256K) APB CRU (16K) 1008 0000 1018 0000 2000 0000 2004 C000 CPU Debug (128K) Reserved (32K) 1FFE\_0000 1013 E000 1000 0000

#### BTMODE = High Level

Fig. 2-3 RK30xx Address Mapping when BTMODE=high

# 2.2 System Boot

RK30xx provides system boot from off-chip devices such as 8bits/16bits async nand flash, spi and emmc memory. When boot code is not ready in these devices, also provide system code download into them by usb otg and uart interface. All of the boot code will be stored in internal boot rom or external 8bits nor flash device, which is decided by input level of external input pin BTMODE. The following is the whole boot procedure for boot code, which will be stored in bootrom or nor flash in advance.



Fig. 2-4 RK30xx boot procedure flow

# 2.3 System Interrupt connection

RK30xx provides an general interrupt controller(GIC) for Cortex-A9 MPCore processor, which has 76 SPI interrupt sources and 3 PPI interrupt source and separately generates one nIRQ and one nFIQ to CPU. The triggered type for each interrupts is high level sensitive, not programmable. The detailed interrupt sources connection is in the following table. For detailed GIC setting, please refer to Chapter 12.



Table 2-1 RK30xx Interrupt connection list

| Table 2-1 RK30xx Interrupt connection list |        |                |            |
|--------------------------------------------|--------|----------------|------------|
| IRQ Type                                   | IRQ ID | Source(spi)    | Polarity   |
|                                            | 27     | Golbal Timer   | High level |
| PPI                                        | 29     | Private Timer  | High level |
|                                            | 30     | WDT            | High level |
|                                            | 32     | DMAC1(0)       | High level |
|                                            | 33     | DMAC1(1)       | High level |
|                                            | 34     | DMAC2(0)       | High level |
|                                            | 35     | DMAC2(1)       | High level |
|                                            | 36     | DDR Controller | High level |
|                                            | 37     | GPU(irqgp)     | High level |
|                                            | 38     | GPU(irqmmu)    | High level |
|                                            | 39     | GPU(irqpp)     | High level |
|                                            | 40     | Reserved       | High level |
|                                            | 41     | Video encoder  | High level |
|                                            | 42     | Video decoder  | High level |
|                                            | 43     | Camera IF0     | High level |
|                                            | 44     | Camera IF1     | High level |
|                                            | 45     | LCDC0          | High level |
|                                            | 46     | LCDC1          | High level |
|                                            | 47     | IPP            | High level |
|                                            | 48     | USB OTG        | High level |
|                                            | 49     | USB Host2.0    | High level |
|                                            | 50     | Reserved       | High level |
| SPI                                        | 51     | MAC            | High level |
|                                            | 52     | I2S2/PCM(2ch)  | High level |
|                                            | 53     | TSADC          | High level |
|                                            | 54     | HS-ADC/TSI     | High level |
|                                            | 55     | SD/MMC0        | High level |
| 41                                         | 56     | SDIO           | High level |
|                                            | 57     | eMMC           | High level |
|                                            | 58     | SAR-ADC        | High level |
|                                            | 59     | NandC          |            |
| ,                                          |        |                | High level |
|                                            | 60     | Reserved       | High level |
|                                            | 61     | SMC            | High level |
|                                            | 62     | PID_FILTER     | High level |
|                                            | 63     | I2S0/PCM (8ch) | High level |
|                                            | 64     | I2S1/PCM (2ch) | High level |
|                                            | 65     | SPDIF          | High level |
|                                            | 66     | UART0          | High level |
|                                            | 67     | UART1          | High level |
|                                            | 68     | UART2          | High level |
|                                            | 69     | UART3          | High level |



| 70  | SPI0                  | High level |
|-----|-----------------------|------------|
| 71  | SPI1                  | High level |
| 72  | I2C0                  | High level |
| 73  | I2C1                  | High level |
| 74  | I2C2                  | High level |
| 75  | I2C3                  | High level |
| 76  | Timer0                | High level |
| 77  | Timer1                | High level |
| 78  | Timer2                | High level |
| 79  | PWM0                  | High level |
| 80  | PWM1                  | High level |
| 81  | PWM2                  | High level |
| 82  | PWM3                  | High level |
| 83  | WDT                   | High level |
| 84  | I2C4                  | High level |
| 85  | PMU(int)              | High level |
| 86  | GPIO0                 | High level |
| 87  | GPIO1                 | High level |
| 88  | GPIO2                 | High level |
| 89  | GPIO3                 | High level |
| 90  | GPIO4                 | High level |
| 91  | Reserved              | High level |
| 92  | GPIO6                 | High level |
| 93  | peri_ahb_usb arbiter  | High level |
| 94  | peri_ahb_emem arbiter | High level |
| 95  | RGA                   | High level |
| 96  | HDMI                  | High level |
| 97  | Reserved              | High level |
| 98  | SD/MMC detect         | High level |
| 99  | SDIO detect           | High level |
| 100 | gpu_obsrv_mainfault   | High level |
| 101 | PMU(stop_exit_int)    | High level |
| 102 | observer_mainfault    | High level |
| 103 | vpu_obsrv_mainfault   | High level |
| 104 | peri_obsrv_mainfault  | High level |
| 105 | vio1_obsrv_mainfault  | High level |
| 106 | vio0_obsrv_mainfault  | High level |
| 107 | dmac_obsrv_mainfault  | High level |
|     |                       |            |

# 2.4 System DMA hardware request connection

RK30xx provides 2 DMA controllers : DMAC0 inside cpu system and DMAC1 inside peri system. As for DMACO, there are 11 hardware request ports . Another, 14 hardware request ports are used in DMAC1, the trigger type for each of them

is high level, not programmable. For detailed descriptions of DMAC0 and DMAC1, please refer to Chapter 10 and Chapter 11.

Table 2-2 RK30xx DMAC0 Hardware request connection list

| Req Number | Source           | Polarity   |
|------------|------------------|------------|
| 0          | Uart0 tx         | High level |
| 1          | Uart0 rx         | High level |
| 2          | Uart1 tx         | High level |
| 3          | Uart1 rx         | High level |
| 4          | I2S0/PCM(8ch) tx | High level |
| 5          | I2S0/PCM(8ch) rx | High level |
| 6          | I2S1/PCM(2ch) tx | High level |
| 7          | I2S1/PCM(2ch) rx | High level |
| 8          | SPDIF tx         | High level |
| 9          | I2S2/PCM(2ch) tx | High level |
| 10         | I2S2/PCM(2ch) rx | High level |

Table 2-3 RK30xx DMAC1 Hardware request connection list

| Req Number | Source     | Polarity   |
|------------|------------|------------|
| 0          | HS-ADC/TSI | High level |
| 1          | SD/MMC(0)  | High level |
| 2          | N/A        | High level |
| 3          | SDIO       | High level |
| 4          | eMMC       | High level |
| 5          | PID_FILTER | High level |
| 6          | Uart2 tx   | High level |
| 7          | Uart2 rx   | High level |
| 8          | Uart3 tx   | High level |
| 9          | Uart3 rx   | High level |
| 10         | SPI0 tx    | High level |
| 11         | SPI0 rx    | High level |
| 12         | SPI1 tx    | High level |
| 13         | SPI1 rx    | High level |

# **Chapter 3 CRU (Clock & Reset Unit)**

# 3.1 Overview

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

CRU supports the following features:

- Compliance to the AMBA APB interface
- Embedded four PLL
- Support only one crystals
- Flexible selection of clock source
- Supports the respectivegating of all clocks
- Supports the respective software reset of all modules

For detailed information about CRU, please refer to RK30xx CRU.pdf.

# **Chapter 4 PMU (Power Management Unit)**

### 4.1 Overview

The PMU focuses on the power on/off switch for different power domain, which support the different system power saved mode to meet the chip high performance and lower power application requirement.

#### 4.1.1 Features

- Support 3 voltage domains
- Support 8 separate power domains, which can be power up/down by software based on different application scenes
- Support seven work modes(normal mode, slow mode, idle mode, deep idle mode, stop mode, sleep mode and power off mode) to save power
- Support idle mode which only Cortex-A9 core clock gated, and wakeup by any interrupt from every on-chip component
- Support deep idle mode which only Cortex-A9 core power off, and wakeup by any interrupt from every on-chip component
- Support stop mode which almost modules clock gated, and wakeup by some periphrals or 16 different GPIOs
- Support sleep mode which the internal power is power off, and wakeup by some periphrals or 16 different GPIOs
- Support PD\_SCU domain is externally turned off in sleep mode
- Support power off mode which the internal power is externally turned off, and wakeup by 16 different GPIOs
- Support clock of PD\_ALIVE and PD\_RTC switch to 32.768kHz optionally in some low power modes
- Support PLLs off in some low power modes
- Support OSC disable optionally in some low power modes
- Support hardware DDR self-refresh optionally in some low power modes
- Support select to boot from SRAM or ROM after wakeup in deep idle mode and sleep mode

For detailed information about PMU, please refer to **RK30xx PMU.pdf**.

# **Chapter 5 System Security**

# 5.1 cOverview

The RK30xx use the TrustZone access control scheme to support the system security application requirement.

For detailed information about system security, please refer to RK30xx system security.pdf.



# **Chapter 6 System Debug**

# 6.1 Overview

The RK30xx use the CoreSight Technology to support real-time debug access and trace for the multi-core. A standard infrastructure is implemented for the capture and transmission of trace data, combination of multiple data streams by funneling together, and then output of data to a trace port.

#### 6.1.1 Features

- Invasive debug with core halted
- cross-triggering, the ECT provide a standard interconnect mechanism to pass debug or profiling events around the SOC
- Trace, capture and transmission trace data using PTM and TPIU
- Real-time access system memory and peripheral register without halting the CPU, using DAP AHB master
- 6.1.2 Debug components address map

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

| Module       | Base Address |
|--------------|--------------|
| DAP_ROM      | 0x1ffe0000   |
| CTI4         | 0x1ffe1000   |
| TPIU         | 0x1ffe2000   |
| Trace Funnel | 0x1ffe3000   |
| CPUDBG0      | 0x1ffe4000   |
| CPUPMU0      | 0x1fff0000   |
| CPUDBG1      | 0x1fff2000   |
| CPUPMU1      | 0x1fff3000   |
| CTI0         | 0x1fff8000   |
| CTI1         | 0x1fff9000   |
| PTM0         | 0x1fffc000   |
| PTM1         | 0x1fffd000   |

# 6.2 Block Diagram



Fig. 6-1 RK30xx Debug system structure

# 6.3 Function description

#### 6.3.1 DAP

The Debug Access Port (DAP) is an implementation of an ARM Debug Interface version 5.1 (ADIv5.1) comprising a number of components supplied in a single configuration. All the supplied components fit into the various architectural components for Debug Ports (DPs), which are used to access the DAP from an external debugger and Access Ports (APs), to access on-chip system resources.

The RK30xx DAP has following components:

- Serial Wire JTAG Debug Port(SWJ-DP)
- APB Access Port(APB-AP)
- APB-Mux
- AHB Access Port(AHB-AP)
- ROM table

The debug port is the host tools interface to access the DAP-Lit. This interface controls any access ports provided within the DAP-Lite. The DAP-Lite support a combined debug port which includes both JTAG and Serial Wire Debug(SWD), with a mechanism that supports switching between them.

The APB-AP acts as a bridge between SWJ-DP and APB bus which translate the Debug request to APB bus.

The APB-Mux enables external tools and system access to the debug APB. The APB-Mux encapsulates the multiple interface into a single deliverable



component, enable multi-master access to the Debug APB.

The AHB-AP implements the MEM-AP architecture to directly connect to an AHB based memory system. Connection to other memory systems is possible through suitable bridging local.

The DAP provides an internal ROM table connected to the master Debug APB port of the APB-Mux. The Debug ROM table is loaded at address 0x00000000 and 0x80000000 of this bus and is accessible from both APB-AP and the system APB input. Bit [31] of the address bus is not connected to the ROM Table, ensuring that both views read the same value. The ROM table stores the locations of the components on the Debug APB. 6.3.2 PTM

The PTM is a module that performs real-time instruction flow tracing based on the Program Flow Trace (PFT) architecture. The PTM generates information that trace tools use to reconstruct the execution of all or part of a program.

The PFT architecture assumes that the trace tools can access a copy of the codebeing traced. For this reason, the PTM generates trace only at certain points in program execution, called waypoints. This reduces the amount of trace data generated by the PTM compared to the ETM protocol. Waypoints are changes in the program flow or events, such as an exception. The trace tools use waypoints to follow the flow of program execution.

### 6.3.3 Trace funnel

The CSTF is used when there is more than one trace source. The CSTF combines multiple trace streams onto a single ATB bus.



#### 6.3.4 TPIU

The TPIU acts as a bridge between the on-chip trace data, with separate IDs, to a data stream, encapsulating IDs where required, that is then captured by a Trace Port Analyzer (TPA). Figure 8-1 shows the main blocks of the TPIU and the clock domains.

The TPIU contains the following components:

- Formatter
  - Inserts source ID signals into the data packet stream so that trace data can be re-associated with its trace source. See TPIU formatter and FIFO.
- Asynchronous FIFO

Enables trace data to be driven out at a speed that is not dependent on theon-chip bus clock.

Register bank

Contains the management, control and status registers for triggers, flushing behavior and external control.



#### Trace out

The trace out block serializes formatted data before it goes off-chip.

#### Pattern Generator

The pattern generator unit provides a simple set of defined bit sequences or patterns that can be output over the Trace Port and be detected by the TPA or other associated Trace Capture Device (TCD). The TCD can use these patterns to indicate if it is possible to increase or to decrease the trace port clock speed.

#### ATB interface

The TPIU accepts trace data from a trace source, either direct from a trace source or using a Trace Funnel.

#### APB interface

The APB interface is the programming interface for the TPIU.

### 6.3.5 ECT (CTI & CTM)

The ECT for CoreSight consists of a number of CTIs and CTMs connected together. This enables ARM/ETM subsystems to interact. That is cross trigger, with each other. The debug system enables debug support for multiple cores, together with cross triggering between the cores and their respective ETMs.

The main function of the ECT (CTI and CTM) is to pass debug events from onecore to another. For example, the ECT can communicate debug state information from one core to another, so that program execution on both processors can be stopped at the same time if required.

### CTI (Cross Trigger Interface)

The CTI combines and maps the trigger requests, and broadcasts them to all other interfaces on the ECT as channel events. When the CTI receives a channel event it maps this onto a trigger output. This enables subsystems to cross trigger with each other. The receiving and transmitting of triggers is performed through the trigger interface.

# CTM (Cross Trigger Matrix)

This block controls the distribution of channel events. It provides Channel Interfaces (CIs) for connection to either CTIs or CTMs. This enables multiple CTIs to be linked together.

# 6.4 Register description

# 6.4.1 DAP APB-AP register summary

| Name         | Offset    | Size | Reset<br>Value | Description                  |
|--------------|-----------|------|----------------|------------------------------|
| DAP_CSW      | 0x000     | W    | 0x00000002     | Control/Status Word, CSW     |
| DAP_TAR      | 0x004     | W    | 0x00000000     | Transfer Address, TAR        |
| Reserved     | 0x008     | W    | NA             | Reserved                     |
| DAP_DRW      | 0x00c     | W    | NA             | Data Read/Write, DRW         |
| DAP_BD0      | 0x010     | W    | NA             | Bank Data 0, BD0             |
| DAP_BD1      | 0x014     | W    | NA             | Bank Data 1, BD1             |
| DAP_BD2      | 0x018     | W    | NA             | Bank Data 2, BD2             |
| DAP_BD3      | 0x01c     | W    | NA             | Bank Data 3, BD3             |
| Reserved     | 0x20-0xf4 | W    | NA             | Reserved                     |
| DAP_ROM_ADDR | 0xf8      | W    | NA             | Debug ROM Address, ROM       |
| DAP_IDR      | 0xfc      | W    | 0x14770002     | Identification Register, IDR |



# 6.4.2 DAP APB-AP Detailed Register Description

DAP\_CSW

Address: APBAP\_BASE + offset(0x000)

| Control/S<br><b>Bits</b> | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------------------------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31                       | RW   | 0x0         | Software access enable.  Drives DBGSWENABLE to enable or disable software access to the Debug APBbus in the APB multiplexor.  b1 = Enable software access  b0 = Disable software access.  Reset value = b0. On exit from reset, defaults to b1 to enable software access.                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 31:12                    | RW   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 11:8                     | R    | 0x0         | Specifies the mode of operation.  b0000 = Normal download/upload model  b0001-b1111 = Reserved  Reset value = b0000.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 7                        | R    | 0x0         | Transfer in progress. This field indicates if a transfer is currently in progress on the APB master port.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 6                        | R    | 0×0         | Transfer in progress. This field indicates if a transfer is currently in progress on the APB master port.  Indicates the status of the DEVICEEN input.  If APB-AP is connected to the Debug APB, that is, a bus connected only todebug and trace components, it must be permanently enabled by tyingDEVICEEN HIGH. This ensures that trace components can still beprogrammed when DBGEN is LOW. In practice, it is expected that theAPB-AP is almost always used in this way.  If APB-AP is connected to a system APB dedicated to the non-secure world, DEVICEEN must be connected to DBGEN.  If APB-AP is connected to a system APB dedicated to the secure world, DEVICEEN must be connected to SPIDEN. |
| 5:4                      | RW   | 0×0         | Auto address increment and packing mode on Read or Write data access. Does not increment if the transaction completes with an error response or the transaction isaborted. Auto address incrementing is not performed on access to banked data registers0x10-0x1C. The status of these bits is ignored in these cases. b11 = Reserved b10 = Reserved b01 = Increment b00 = Auto increment OFF. Increment occurs in word steps.                                                                                                                                                                                                                                                                             |



|     |   |     | Reset value = b00.                                                          |
|-----|---|-----|-----------------------------------------------------------------------------|
| 3   | R | 0x0 | Reserved                                                                    |
| 2:0 | R | 0x2 | Size of the access to perform. Fixed at b010 = 32 bits. Reset value = b010. |

# DAP\_TAR

Address:  $APBAP_BASE + offset(0x004)$ 

Transfer Address

| Bits | Attr | Reset Value | Description                                                                                                                                                                                                       |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | RW   | 0x0         | Address[31:2] of the current transfer PADDR[31:2]=TAR[31:2] for accesses from Data Read/Write Register at 0x0C. PADDR[31:2]=TAR[31:4]+DAPADDR[3:2] for accesses from Banked Data Registers at 0x10-0x1C and 0x0C. |
| 1:0  | R    | 0x0         | Reserved                                                                                                                                                                                                          |

# DAP\_DRW

Address: APBAP\_BASE + offset(0x00c)

Data Read/Write

| Bits | Attr | Reset Value | Description                                                                                                     |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0×0         | Write mode: Data value to write for the current transfer. Read mode: Data value read from the current transfer. |

# DAP\_BD0-DAP\_BD3

Address: APBAP\_BASE + offset(0x010) - APBAP\_BASE + offset(0x01c)

Bank Data 0-3

| Bits | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0×0         | If DAPADDR[7:4] = 0x0001, so accessing APB-AP registers in the range 0x10-0x1C, then thederived PADDR[31:0] is:  • Write mode: Data value to write for the current transfer to external address TAR[31:4]+ DAPADDR[3:2] + 2'b00.  • Read mode: Data value read from the current transfer from external address TAR[31:4]+ DAPADDR[3:2] + 2'b00.  Auto address incrementing is not performed on DAP accesses to BD0-BD3.  Reset value = 0x00000000 |

# DAP\_ROM\_ADDR

Address: 0xf8 ROM address

| Bits  | Attr | Reset Value | Description                                                                                                                                                                                    |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12 | R    | 0×800000    | Base address of the ROM Table The ROM provides a look-up table of allCoreSight Debug APB components. Read only. Set to 0xFFFFF if no ROM ispresent. In the initial CoreSight release this must |



|      |   |       | be set to 0x80000.                                                                                                                    |
|------|---|-------|---------------------------------------------------------------------------------------------------------------------------------------|
| 11:0 | R | 0x000 | Set to 0x000 if ROM is present. Set to 0xFFF if ROM table is not present. In the initial CoreSight release this must be set to 0x000. |

# DAP\_IDR

Address: APBAP BASE + offset(0x0fc)

| Bits  | Attr | Reset Value Description |                                                           |
|-------|------|-------------------------|-----------------------------------------------------------|
| 31:28 | R    | 0x1                     | Revision. Reset value is 0x1 for APB-AP.                  |
| 27:24 | R    | 0x4                     | JEDEC bank. 0x4 indicates ARM Limited.                    |
| 23:17 | R    | 0x3b                    | JEDEC code. 0x3B indicates ARM Limited.                   |
| 16    | R    | 0x1                     | Memory AP. 0x1 indicates a standard register map is used. |
| 15:8  | R    | 0x00                    | Reserved                                                  |
| 7:0   | R    | 0x02                    | Identity value. Reset value is 0x02 for APB-AP.           |

# 6.4.3 DAP AHB-AP register summary

| Name              | Offset    | Size | Reset<br>Value | Description                  |
|-------------------|-----------|------|----------------|------------------------------|
| DAP_AHB_CSW       | 0x000     | W    | 0x00000002     | Control/Status Word, CSW     |
| DAP_AHB_TAR       | 0x004     | W    | 0x00000000     | Transfer Address, TAR        |
| Reserved          | 0x008     | W    | NA             | Reserved                     |
| DAP_AHB_DRW       | 0x00c     | W    | NA             | Data Read/Write, DRW         |
| DAP_AHB_BD0       | 0x010     | W    | NA             | Bank Data 0, BD0             |
| DAP_AHB_BD1       | 0x014     | W)   | NA             | Bank Data 1, BD1             |
| DAP_AHB_BD2       | 0x018     | W    | NA             | Bank Data 2, BD2             |
| DAP_AHB_BD3       | 0x01c     | W    | NA             | Bank Data 3, BD3             |
| Reserved          | 0x20-0xf7 | W    | NA             | Reserved                     |
| DAP_DEBUG_RO<br>M | 0xf8      | W    | NA             | Debug ROM table              |
| DAP_AHB_IDR       | 0xfc      | W    | 0x14770002     | Identification Register, IDR |

# 6.4.4 DAP AHB-AP Detailed Register Description

# DAP\_AHB\_CSW

Address: AHBAP\_BASE + offset(0x000)

Control/Status Word

| Bits | Attr | Reset Value Description |                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | -    | -                       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                       |
| 30   | RW   | 0×0                     | Specifies that a secure transfer is requested. SProt HIGH indicates a non-secure transfer. SProt LOW indicates a secure transfer.  • If this bit is LOW, and SPIDEN is HIGH, HPROT[6] is asserted LOW on an AHB transfer.  • If this bit is LOW, and SPIDEN is LOW, HPROT[6] is asserted HIGH and the AHB transfer is not initiated.  • If this bit is HIGH, the state of SPIDEN is ignored. HPROT[6] is HIGH. |



|       |    |     | Reset value = b1. Non-secure                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29    | -  | -   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 28:24 | RW | 0x0 | Specifies the protection signal encoding to be output on HPROT[4:0].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 23    | RO | 0x0 | Indicates the status of the SPIDEN port. If SPIStatus is LOW, no secure AHB transfers are carried out.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 22:12 | -  | -   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 11:8  | RW | 0x0 | Specifies the mode of operation. b0000 = Normal download/upload model b0001-b1111 = Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 7     | RO | 0x0 | Transfer in progress. This field indicates if a transfer is currently in progress on the AHB master port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 6     | RO | 0x0 | Indicates the status of the DBGEN port. If DbgStatus is LOW, no AHB transfers are carried out.  1 = AHB transfers permitted.  0 = AHB transfers not permitted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 5:4   | RW | 0×0 | Auto address increment and packing mode on Read or Write data access. Only increments if the current transaction completes without an Error response and the transaction is not aborted.  Auto address incrementing and packed transfers are not performed on access to Banked Data registers 0x10-0x1C. The status of these bits is ignored in these cases.  Increments and wraps within a 1KB address boundary, for example, for word incrementing from 0x1400-0x17FC. If the start is at 0x14A0, then the counter increments to 0x17FC, wraps to 0x1400, then continues incrementing to 0x149C. b00 = Auto increment OFF. b01 = Increment, single. Single transfer from corresponding byte lane. b10 = Increment, packed Word = Same effect as single increment. Byte/Halfword: Packs four 8-bit transfers or two 16-bit transfers into a 32-bit DAP transfer. Multiple transactions are carried out on the AHB interface. b11 = Reserved SBZ, no transfer. Size of address increment is defined by the Size field, bits [2:0]. |
| 3     | _  | -   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 2:0   | RW | 0x2 | Size of the data access to perform:<br>b000 = 8 bits<br>b001 = 16 bits<br>b010 = 32 bits<br>b011-b111 = Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

# DAP\_AHB\_TAR

Address: AHBAP\_BASE + offset(0x004)

Control/Status Word



| Bits | Attr | Reset Value | Description                      |
|------|------|-------------|----------------------------------|
| 31:0 | RW   | 0x0         | Address of the current transfer. |

# DAP\_AHB\_DRW

Address: AHBAP\_BASE + offset(0x00c)

Control/Status Word

| Bits | Attr | Reset Value | Description                                                                                                     |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0×0         | Write mode: Data value to write for the current transfer. Read mode: Data value read from the current transfer. |

# DAP\_AHB\_BD0- DAP\_AHB\_BD3

Address: APBAP\_BASE + offset(0x010) - APBAP\_BASE + offset(0x01c)

Bank Data 0-3

| Dalik Data 0-3 |      |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits           | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:0           | RW   | 0x0         | If DAPADDR[7:4] = 0x0001, so accessing AHB-AP registers in the range 0x10-0x1C, then thederived HADDR[31:0] is:  • Write mode: Data value to write for the current transfer to external address TAR[31:4]+ DAPADDR[3:2] + 2'b00.  • Read mode: Data value read from the current transfer from external address TAR[31:4]+ DAPADDR[3:2] + 2'b00.  Auto address incrementing is not performed on DAP accesses to BD0-BD3.  Banked transfers are only supported for word transfers. Non-word banked transfers are reserved and unpredictable. Transfer size is currently ignored for banked transfers |

# DAP\_DEBUG\_ROM

Address: 0xf8 ROM address

| Bits | Attr | Reset Value | Description                                                                                                                                 |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | -           | Base address of a ROM table. The ROM provides a look-up table for system components. Set to 0xFFFFFFFF in the AHB-AP in the initial release |

# DAP\_AHB\_IDR

Address: APBAP\_BASE + offset(0x0fc)

| Bits  | Attr | Reset Value Description                      |                                                           |
|-------|------|----------------------------------------------|-----------------------------------------------------------|
| 31:28 | R    | 0x4                                          | Revision. Reset value is 0x4 for AHB-AP.                  |
| 27:24 | R    | 0x4                                          | JEDEC bank. 0x4 indicates ARM Limited.                    |
| 23:17 | R    | 0x3b JEDEC code. 0x3B indicates ARM Limited. |                                                           |
| 16    | R    | 0x1                                          | Memory AP. 0x1 indicates a standard register map is used. |
| 15:8  | R    | 0x00 Reserved                                |                                                           |



| 7:0 | R | 0x01 | Identity value. Reset value is 0x01 for AHB-AP. |
|-----|---|------|-------------------------------------------------|
|-----|---|------|-------------------------------------------------|

# 6.4.5 DAP-ROM register summary

| Name              | Offset | Size | Reset<br>Value | Description                  |
|-------------------|--------|------|----------------|------------------------------|
| DAP_ROMENTRY0     | 0x0000 | W    | 0x00001003     | CTI4 entry register          |
| DAP_ROMENTRY1     | 0x0004 | W    | 0x00002003     | TPIU entry register          |
| DAP_ROMENTRY2     | 0x0008 | W    | 0x00003003     | Trace Funnel register        |
| DAP_ROMENTRY3     | 0x000c | W    | 0x00004003     | Cortex-A9 ROM entry register |
| DAP_ROM_PERIPHID4 | 0x0fd0 | W    | 0x00000004     | Peripheral ID4               |
| DAP_ROM_PERIPHID5 | 0x0fd4 | W    | 0x00000000     | Peripheral ID5               |
| DAP_ROM_PERIPHID6 | 0x0fd8 | W    | 0x00000000     | Peripheral ID6               |
| DAP_ROM_PERIPHID7 | 0x0fdc | W    | 0x00000000     | Peripheral ID7               |
| DAP_ROM_PERIPHID0 | 0x0fe0 | W    | 0x000000c4     | Peripheral ID0               |
| DAP_ROM_PERIPHID1 | 0x0fe4 | W    | 0x000000b4     | Peripheral ID1               |
| DAP_ROM_PERIPHID2 | 0x0fe8 | W    | 0x0000006b     | Peripheral ID2               |
| DAP_ROM_PERIPHID3 | 0x0fec | W    | 0x00000020     | Peripheral ID3               |
| DAP_ROM_COMPONID0 | 0x0ff0 | W    | 0x000000d      | Component ID0                |
| DAP_ROM_COMPONID1 | 0x0ff4 | W    | 0x0000010      | Component ID1                |
| DAP_ROM_COMPONID2 | 0x0ff8 | W    | 0x00000005     | Component ID2                |
| DAP_ROM_COMPONID3 | 0x0ffc | W    | 0x000000b1     | Component ID3                |

# 6.4.6 DAP-ROM Detailed Register Description

# **DAP\_ROMENTRY0**

Address: DAPROM\_BASE + offset(0x0000)

TPIU entry register

| Bits | Attr | Reset Value | Description         |
|------|------|-------------|---------------------|
| 31:0 | R    | 0x00001003  | TPIU entry register |

### DAP\_ROMENTRY1

Address: DAPROM\_BASE + offset(0x0004)

Cortex-A9 Debug entry register

| Bits Attr Reset Value |   | Reset Value | Description                    |
|-----------------------|---|-------------|--------------------------------|
| 31:0                  | R | 0x00002003  | Cortex-A9 Debug entry register |

### **DAP ROMENTRY2**

Address: DAPROM\_BASE + offset(0x0008)

Cortex-A9 ETM entry register

| Bits | Attr | Reset Value | Description                  |
|------|------|-------------|------------------------------|
| 31:0 | R    | 0x00003003  | Cortex-A9 ETM entry register |

# **DAP\_ROMENTRY3**

Address: DAPROM\_BASE + offset(0x000c)

Cortex-A9 CTI entry register

| Bits | Attr | Reset Value | Description                  |
|------|------|-------------|------------------------------|
| 31:0 | R    | 0x00004003  | Cortex-A9 CTI entry register |



#### DAP\_ROM\_PERIPHID4

Address: DAPROM\_BASE + offset(0x0fd0)

Peripheral ID4

| Bits | Attr | Reset Value | Description    |
|------|------|-------------|----------------|
| 31:0 | R    | 0x00000004  | Peripheral ID4 |

#### DAP\_ROM\_PERIPHID5

Address: DAPROM\_BASE + offset(0x0fd4)

Peripheral ID5

| Bits | Attr | Reset Value |                | Description |
|------|------|-------------|----------------|-------------|
| 31:0 | R    | 0x00000000  | Peripheral ID5 |             |

#### DAP\_ROM\_PERIPHID6

Address: DAPROM\_BASE + offset(0x0fd8)

Peripheral ID6

| Bits | Attr | Reset Value |                | Description |
|------|------|-------------|----------------|-------------|
| 31:0 | R    | 0x00000000  | Peripheral ID6 |             |

# DAP\_ROM\_PERIPHID7

Address: DAPROM\_BASE + offset(0x0fdc)

Peripheral ID7

| Bits | Attr | Reset Value | Description    |
|------|------|-------------|----------------|
| 31:0 | R    | 0x00000000  | Peripheral ID7 |

#### DAP\_ROM\_PERIPHID0

Address: DAPROM\_BASE + offset(0x0fe0)

Peripheral ID0

| Bits | Attr | Reset Value | Description    |
|------|------|-------------|----------------|
| 31:0 | R    | 0x000000c4  | Peripheral ID0 |

#### DAP ROM PERIPHID1

Address: DAPROM\_BASE + offset(0x0fe4)

Peripheral ID1

| Bits | Attr | Reset Value | Description    |
|------|------|-------------|----------------|
| 31:0 | R    | 0x000000b4  | Peripheral ID1 |

#### DAP ROM PERIPHID2

Address: DAPROM\_BASE + offset(0x0fe8)

Peripheral ID2

| Bits | Attr | Reset Value | Description    |
|------|------|-------------|----------------|
| 31:0 | R    | 0x0000006b  | Peripheral ID2 |

#### DAP\_ROM\_PERIPHID3

Address: DAPROM\_BASE + offset(0x0fec)

Peripheral ID3

| Bits | Attr | Reset Value | Description    |
|------|------|-------------|----------------|
| 31:0 | R    | 0x00000020  | Peripheral ID3 |

# DAP\_ROM\_COMPONIDO



Address: DAPROM\_BASE + offset(0x0ff0)

Component ID0

| Bits | Attr | Reset Value | Description   |
|------|------|-------------|---------------|
| 31:0 | R    | 0x000000d   | Component ID0 |

# DAP\_ROM\_COMPONID1

Address: DAPROM\_BASE + offset(0x0ff4)

Component ID0

| Bits | Attr | Reset Value | Description   |
|------|------|-------------|---------------|
| 31:0 | R    | 0x0000010   | Component ID1 |

### DAP\_ROM\_COMPONID2

Address: DAPROM\_BASE + offset(0x0ff8)

Component ID0

| Bits | Attr | Reset Value | Description   |  |
|------|------|-------------|---------------|--|
| 31:0 | R    | 0x00000005  | Component ID2 |  |

# DAP\_ROM\_COMPONID3

Address: DAPROM\_BASE + offset(0x0ffc)

Component ID0

| Bits | Attr | Reset Value | Description   |
|------|------|-------------|---------------|
| 31:0 | R    | 0x000000b1  | Component ID3 |

# 6.4.7 PTM register summary

| Name                   | Offset          | Size | Reset<br>Value | Description                       |
|------------------------|-----------------|------|----------------|-----------------------------------|
| PTM_ETMCR              | 0x0             | W    | 0x401          | Main control                      |
| PTM_ETMCCR             | 0x4             | W    | 0x8d294004     | Configuration code                |
| PTM_ETMTE              | 0x8             | W    | 0x0            | Trigger event                     |
| PTM_ETMSR              | 0x10            | W    | 0x0            | Status                            |
| PTM_ETMSCR             | 0x14            | W    | 0x0            | System configuration              |
| PTM_ETMTSSCR           | 0x18            | W    | 0x0            | TraceEnable Start/Stop control    |
| PTM_ETMTEE             | 0x20            | W    | 0x0            | TraceEnable event                 |
| PTM_ETMTECR1           | 0x24            | W    | 0x0            | TraceEnable Control               |
| PTM_ETMACVR1-8         | 0x40-0<br>x5c   | W    | 0x0            | Address comparator value          |
| PTM_ETMACTR1-8         | 0x80-0<br>x9c   | W    | 0x0            | Address comparator access type    |
| PTM_ETMCNTRLDV<br>R1-2 | 0x140-<br>0x144 | W    | 0x0            | Counter load value                |
| PTM_ETMCNTENR1 -2      | 0x150-<br>0x154 | W    | 0x0            | Counter enable                    |
| PTM_ETMCNTRLDE VR1-2   | 0x160-<br>0x164 | W    | 0x0            | Counter reload event              |
| PTM_ETMCNTVR1-<br>2    | 0x170-<br>0x174 | W    | 0x0            | Counter value                     |
| PTM_SSTE1-SSTE6        | 0x180-<br>0x194 | W    | 0x0            | Sequencer status transition event |
| PTM_CSS                | 0x19c           | W    | 0x0            | Current sequencer state           |



| PTM_EOE1-<br>PTM EOE2 | 0x1a0-<br>0x1a4 | W   | 0x0        | External output event        |
|-----------------------|-----------------|-----|------------|------------------------------|
| PTM CICV1             | 0x1b0           | W   | 0x0        | Context ID comparator value  |
| PTM CICM              | 0x1bc           | W   | 0x0        | Context ID comparator mask   |
| PTM_ETMSYNCFR         | 0x1e0           | W   | 0x0        | Synchronization frequency    |
| PTM ETMIDR            | 0x1e4           | W   | 0x411cf301 | ID register                  |
| PTM_ETMCCER           | 0x1e8           | W   | 0x00c019a2 | Configuration code extension |
| PTM_ETMEXTINSEL       |                 |     |            | Extended external input      |
| R                     | 0x1ec           | W   | 0x0        | selection                    |
| PTM TE                | 0x1f8           | W   | 0x0        | Timestamp Event              |
| PTM ETMAUXCR          | 0x1fc           | W   | 0x0        | Auxiliary control register   |
| PTM ETMTRACEID        | 0200            | \A/ | 00         | ,                            |
| R                     | 0x200           | W   | 0x0        | CoreSight trace ID           |
| PTM_OSLSR             | 0x304           | W   | 0x0        | OS lock status               |
| PTM_ETMPDSR           | 0x314           | W   | 0x1        | Device power-down status     |
| PTM_ITMISCOUT         | 0xedc           | W   | 0x0        | Miscellaneous outputs        |
| PTM_ITMISCIN          | 0xee0           | W   | 0x0        | Miscellaneous inputs         |
| PTM_ITTRIGGER         | 0xee8           | W   | 0x0        | Trigger register             |
| PTM_ITATBDATA0        | 0xeec           | W   | 0x0        | ATB data 0                   |
| PTM_ITATBCTR2         | 0xef0           | W   | 0x0        | ATB control 2                |
| PTM_ITATBID           | 0xef4           | W   | 0x0        | ATB identification           |
| PTM_ITATBCTR0         | 0xef8           | W   | 0x0        | ATB control 0                |
| PTM_ETMITCTRL         | 0xf00           | W   | 0x0        | Integration mode control     |
| PTM_AS                | 0xfb8           | W   | 0x0        | Authentication status        |
| PTM_DC                | 0xfc8           | W   | 0x0        | Device configuration         |
| PTM_DT                | 0xfcc           | W   | 0x0        | Device type                  |
| PTM_PID4              | 0xfd0           | W   | 0x4        | Peripheral ID4               |
| PTM_PID5              | 0xfd4           | W   | 0x0        | Peripheral ID5               |
| PTM_PID6              | 0xfd8           | W   | 0x0        | Peripheral ID6               |
| PTM_PID7              | 0xfdc           | W   | 0x0        | Peripheral ID7               |
| PTM_PID0              | 0xfe0           | W   | 0x50       | Peripheral ID0               |
| PTM_PID1              | 0xfe4           | W   | 0xb9       | Peripheral ID1               |
| PTM_PID2              | 0xfe8           | W   | 0x1b       | Peripheral ID2               |
| PTM_PID3              | 0xfec           | W   | 0x0        | Peripheral ID3               |
| PTM_CID0              | 0xff0           | W   | 0xd        | Component ID0                |
| PTM_CID1              | 0xff4           | W   | 0x90       | Component ID1                |
| PTM_CID2              | 0xff8           | W   | 0x5        | Component ID2                |
| PTM_CID3              | 0xffc           | W   | 0xb1       | Component ID3                |

# 6.4.8 PTM Detailed Register Description

# PTM\_ETMCR

Address: PTM\_BASE + offset(0x000)

Main Control Register

| Bits  | Attr | Reset Value | Description                                          |
|-------|------|-------------|------------------------------------------------------|
| 31:30 | -    | -           | Reserved                                             |
| 29    | RW   | 0x0         | Return stack enable<br>b0 = disabled<br>b1 = enabled |
| 28    | RW   | 0x0         | Timestamp enable b0 = disabled                       |



|       |    |     | b1 = enabled                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27:25 | RW | 0x0 | Processor select                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 24    | R  | 0x0 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 23:16 | -  | -   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 15:14 | RW | 0x0 | ContextIDSize b00 = no context ID tracing b01 = context ID bits [7:0] traced b10 = context ID bits [15:0] traced b11 = context ID bits [31:0] traced. On reset, this bit is set to b00, no context ID tracing                                                                                                                                                                                                                     |
| 13    | -  | -   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 12    | RW | 0×0 | CycleAccurate b0 = cycle counting disabled b1 = cycle counting enabled On reset this bit is set to b0, no cycle counting.                                                                                                                                                                                                                                                                                                         |
| 11    | -  | -   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 10    | RW | 0x1 | Programming Bit This bit must be set to b1 when the PTM is being programmed, see Modes of operation on page 2-3. On a PTM reset this bit is set to b1.                                                                                                                                                                                                                                                                            |
| 9     | RW | 0x0 | Debug request control When set to b1 and the trigger event occurs, the PTMDBGRQ output is asserted until PTMDBGACK is observed. This enables a debugger to force the processor into Debug state. On PTM reset this bit is set to b0                                                                                                                                                                                               |
| 8     | RW | 0×0 | Branch Output When this bit is set to b1, addresses are output for all executed branches, both direct and indirect. On PTM reset this bit is set to b0.                                                                                                                                                                                                                                                                           |
| 7     | R  | 0x0 | Stall processor                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6:1   | 2  | 7_  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0     | RW | 0x1 | PowerDown This bit enables external control of the PTM. This bit must be cleared by the trace software tools at the beginning of a debug session. When this bit is set to b0, both the PTM and the trace interface in the processor are enabled. To avoid corruption of trace data, this bit must not be set before the Programming Status bit in the PTM Status Register has been read as 1. On PTM reset this bit is set to b1. |

# PTM\_ETMCCR

Address: PTM\_BASE + offset(0x004)

Configuration Code Register



| 31    | RO | 0x1 | ID Register present Indicates that the ID Register is present.                                   |
|-------|----|-----|--------------------------------------------------------------------------------------------------|
| 30:28 | -  | -   | Reserved                                                                                         |
| 27    | RO | 0x1 | Software access Indicates that software access is supported                                      |
| 26    | RO | 0x1 | Trace stop/start block Indicates that the trace start/stop block is present.                     |
| 25:24 | RO | 0x1 | Number of Context ID comparators Specifies the number of Context ID comparators, one.            |
| 23    | RO | 0x0 | FIFOFULL logic Indicates that it is not possible to stall the processor to prevent FIFO overflow |
| 22:20 | RO | 0x2 | Number of external outputs Specifies the number of external outputs, two.                        |
| 19:17 | RO | 0x4 | Number of external inputs Specifies the number of external inputs, four.                         |
| 16    | RO | 0x1 | Sequencer Indicates that the sequencer is present                                                |
| 15:13 | RO | 0x2 | Number of counters Specifies the number of counters, two.                                        |
| 12:4  | -  | -   | Reserved                                                                                         |
| 3:0   | RO | 0x4 | Number of pairs of address comparators Specifies the number of address comparator pairs, four.   |

# PTM\_ETMSCR

Address: PTM\_BASE + offset(0x014)

System Configuration Register

| Bits  | Attr | Reset Value | Description                                                                                                 |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------|
| 31:15 | _    | - \ \ \ \ \ | Reserved                                                                                                    |
| 14:12 | RO   |             | Number of supported processors minus 1.The value of this field is set by the MAXCORES[2:0] input to the PTM |
| 11:9  | -    | 7           | Reserved                                                                                                    |
| 8     | RO   | -           | Read Only, as b0 - FIFOFULL is not supported.                                                               |
| 7:0   |      | -           | Reserved                                                                                                    |

# PTM\_ETMTSSCR

Address: PTM\_BASE + offset(0x018) TraceEnable Start/Stop Control Register

| Bits  | Attr | Reset Value | Description                                                                                                                                                                                                                  |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | -    | -           | Reserved                                                                                                                                                                                                                     |
| 23:16 | RW   | 0x0         | When a bit is set to 1, it selects a single address comparator (8-1) as a stop address for the TraceEnable Start/Stop block. For example, if you set bit [16] to 1 it selects single address comparator 1 as a stop address. |
| 15:8  | -    | -           | Reserved                                                                                                                                                                                                                     |



| 7.0 | DW | 0x0 | When a bit is set to 1, it selects a single address comparator (8-1) as a start address for the TraceEnable |
|-----|----|-----|-------------------------------------------------------------------------------------------------------------|
| 7:0 | RW |     | Start/Stop block. For example, if you set bit [0] to 1 it selects single address comparator 1 as a          |
|     |    |     | start address.                                                                                              |

# PTM\_ETMTECR1

Address: PTM\_BASE + offset(0x024)

TraceEnable Control Register1

| Bits  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                               |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:26 | -    | -           | Reserved                                                                                                                                                                                                                                                                                                                                                  |
| 25    | RW   | 0×0         | Trace start/stop control enable. The possible values of this bit are:  0 Tracing is unaffected by the trace start/stop logic.  1 Tracing is controlled by the trace on and off addresses configured for the trace start/stop logic.  The trace start/stop resource is not affected by the value of this bit.                                              |
| 24    | RW   | 0x0         | Exclude/include flag. The possible values of this bit are:  0 Include. The specified address range comparators indicate the regions where tracing can occur. No tracing occurs outside this region.  1 Exclude. The specified address range comparators indicate regions to be excluded from the trace. When outside an exclude region, tracing can occur |
| 23:4  | -    | -           | Reserved                                                                                                                                                                                                                                                                                                                                                  |
| 3:0   | RW   | 0×0         | When a bit is set to 1, it selects an address range comparator, 4-1, for include/exclude control. For example, bit [0] set to 1 selects address range comparator 1                                                                                                                                                                                        |

#### PTM\_ETMACVR1-8

Address: PTM\_BASE + offset(0x040-0x05c)

FTMACVR1-8

| Bits | Attr | Reset Value | Description                       |
|------|------|-------------|-----------------------------------|
| 31:0 | RW   | 0x0         | Address comparator value register |

# PTM\_ETMACTR1-8

Address:  $PTM_BASE + offset(0x080-0x09c)$ 

ETMACTR1-8

| Bits | Attr | Reset Value | Description                             |
|------|------|-------------|-----------------------------------------|
| 31:0 | RW   | 0x0         | Address comparator access type register |

# PTM\_ETMCNTRLDVR1-2

Address: PTM\_BASE + offset(0x140-0x144)

ETMCNTRLDVR1-2



| Bits | Attr | Reset Value | Description  |
|------|------|-------------|--------------|
| 31:0 | RW   | 0x0         | Reload value |

#### PTM\_ETMCNTENR1-2

Address:  $PTM_BASE + offset(0x150-0x154)$ 

ETMCNTENR1-2

| Bits | Attr | Reset Value | Description  |
|------|------|-------------|--------------|
| 31:0 | RW   | 0x0         | Enable Event |

#### PTM\_ETMCNTRLDEVR1-2

Address:  $PTM_BASE + offset(0x160-0x164)$ 

ETMCNTRLDEVR1-2

| Bits | Attr | Reset Value |              | Description |
|------|------|-------------|--------------|-------------|
| 31:0 | RW   | 0x0         | Reload Event | • • • •     |

#### PTM\_ETMCNTVR1-2

Address:  $PTM_BASE + offset(0x160-0x164)$ 

ETMCNTVR1-2

| Bits | Attr | Reset Value | Description |  |
|------|------|-------------|-------------|--|
| 31:0 | RW   | 0x0         | Value       |  |

#### PTM\_ETMSYNCFR

Address: PTM BASE + offset(0x1e0)

| Bits | Attr | Reset Value | Description                                                                                                                           |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x0         | The ETMSYNCFR holds the trace synchronization frequency value.Bits [2:0] of this register are not implemented and read as zero (RAZ). |

#### PTM\_ETMIDR

Address: PTM\_BASE + offset(0x1e4)

| Bits  | Attr | Reset Value | Description                                                                                                                                      |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | RO   | 0x41        | Implementor code. This field reads as 0x41, ASCII code for A, indicating ARM Limited.                                                            |
| 23:20 | -11  | _           | Reserved                                                                                                                                         |
| 19    | RO   | 0x1         | Support for Security Extensions. The value of this bit is 1, indicating that the processor implements the ARM architecture Security Extensions.  |
| 18    | RO   | 0x1         | Support for 32-bit Thumb instructions. The value of this bit is 1, indicating that a 32-bit Thumb instruction is traced as a single instruction. |
| 17:12 | -    | -           | Reserved                                                                                                                                         |
| 11:8  | RO   | 0x3         | Major architecture version number.                                                                                                               |
| 7:4   | RO   | 0x0         | Major architecture version number.                                                                                                               |
| 3:0   | RO   | -           | Implementation revision                                                                                                                          |

# PTM\_ETMCCER

Address: PTM\_BASE + offset(0x1e8)



| Bits  | Attr | Reset Value | Description                                                                              |
|-------|------|-------------|------------------------------------------------------------------------------------------|
| 31:26 | RO   | 0x0         | Reserved                                                                                 |
| 25    | RO   | 0x0         | Timestamps not generated for DMB/DSB.                                                    |
| 24    | RO   | 0x0         | MB/DSB instructions are not treated as waypoints.                                        |
| 23    | RO   | 0x1         | Return stack implemented.                                                                |
| 22    | RO   | 0x1         | Timestamping implemented.                                                                |
| 21:16 | -    | -           | Reserved                                                                                 |
| 15:13 | RO   | 0x0         | Specifies the number of instrumentation resources.                                       |
| 12    | -    | -           | Reserved                                                                                 |
| 11    | RO   | 0x1         | b1 - Indicates that all registers, except some Integration Test Registers, are readable. |
| 10:3  | RO   | 0x34        | Specifies the size of the extended external input bus, 52.                               |
| 2:0   | RO   | 0x2         | Specifies the number of extended external input selectors, 2.                            |

# PTM\_ETMEXTINSELR

Address: PTM BASE + offset(0x1ec)

| Bits  | Attr | Reset Value | Description                             |
|-------|------|-------------|-----------------------------------------|
| 31:14 | -    | -           | Reserved                                |
| 13:8  | RW   | 0x0         | Second extended external input selector |
| 7:6   | -    | -           | Reserved                                |
| 5:0   | RW   | 0x0         | First extended external input selector  |

# PTM\_ETMAUXCR

Address: PTM\_BASE + offset(0x1fc)

| Bits | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | -    | 107         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 3    | RW   | 0×0         | Force insertion of synchronization packets, regardless of current trace activity.  Possible values for this bit are:  b0 = Synchronization packets delayed when trace activity is high. This is the reset value.  b1 = Synchronization packets inserted regardless of trace activity.  This bit might be set if synchronization packets occur too far apart. Setting this bit might cause the trace FIFO to overflow more frequently when trace activity is high. |
| 2    | RW   | 0x0         | Specifies whether the PTM issues waypoint update packets if there are more than 4096 bytes between waypoints. Possible values for this bit are:  b0 = PTM always issues update packets if there are more than 4096 bytes between waypoints. This is the reset value.  b1 = PTM does not issue waypoint update packets unless required to do so as the result of                                                                                                   |



|   |    |     | an exception or debug entry.                                                                                                                                                                                                                                                                                                                        |
|---|----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | RW | 0×0 | Specifies whether the PTM issues a timestamp on a barrier instruction. Possible values for this bit are:  b0 = PTM issues timestamps on barrier instructions. This is the reset value.  b1 = PTM does not issue timestamps on barriers                                                                                                              |
| 0 | RW | 0×0 | Specifies whether the PTM enters overflow state when synchronization is requested, and the previous synchronization sequence has not yet completed. This does not affect entry to overflow state when the FIFO becomes full. Possible values for this bit are: b0 = Forced overflow enabled. This is the reset value. b1 = Forced overflow disabled |

# PTM\_ETMTRACEIDR

Address: PTM\_BASE + offset(0x200)

| Bits | Attr | Reset Value | Description                                                                                                                                                                                  |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7 | -    | -           | Reserved                                                                                                                                                                                     |
| 6:0  | RW   | 0×0         | Before trace is generated, you must program this register with a non-reserved value. Reserved values are 0x00 and any value in the range 0x70-0x7F. The reset value of this register is 0x00 |

# PTM\_ETMPDSR

Address: PTM BASE + offset(0x314)

| Addi C33. | Address. The DASE + onset(0x31+) |             |                                                                                                   |  |  |
|-----------|----------------------------------|-------------|---------------------------------------------------------------------------------------------------|--|--|
| Bits      | Attr                             | Reset Value | Description                                                                                       |  |  |
| 31:0      | RO                               | 0×1         | This register always reads as 0x0000001, indicating that the PTM Trace Registers can be accessed. |  |  |

# PTM\_OSLSR

Address: PTM BASE + offset(0x304)

| 7.tdd (635) 1 111_B162 1 611566(68561) |      |             |                                                                                        |  |
|----------------------------------------|------|-------------|----------------------------------------------------------------------------------------|--|
| Bits                                   | Attr | Reset Value | Description                                                                            |  |
| 31:0                                   | RO   | 0x0         | For the PTM, the OSLSR Reads As Zero (RAZ) to show that OS Locking is not implemented. |  |

# PTM\_ITMISCOUT

Address: PTM BASE + offset(0xedc)

| Bits  | Attr | Reset Value | Description                       |
|-------|------|-------------|-----------------------------------|
| 31:10 | -    | -           | Reserved                          |
| 9:8   | WO   | 0x0         | Drives the PTMEXTOUT[1:0] outputs |
| 7:6   | -    | -           | Reserved                          |
| 5     | WO   | 0x0         | Drives the PTMIDLEnACK output     |
| 4     | WO   | 0x0         | Drives the PTMDBGREQ output       |
| 3:0   | WO   | 0x0         | Reserved                          |



# PTM\_ITMISCIN

Address: PTM\_BASE + offset(0xee0)

| Bits | Attr | Reset Value | Description                                |
|------|------|-------------|--------------------------------------------|
| 31:7 | -    | -           | Reserved                                   |
| 6    | RO   | 0x0         | Returns the value of the STANDBYWFI input  |
| 5    | -    | -           | Reserved                                   |
| 4    | RO   | 0x0         | Returns the value of the PTMDBGACK input   |
| 3:0  | RO   | 0x0         | Returns the value of the EXTIN[3:0] inputs |

# PTM\_ITTRIGGER

Address: PTM\_BASE + offset(0xee8)

| Bits | Attr | Reset Value | Description                  |
|------|------|-------------|------------------------------|
| 31:1 | -    | -           | Reserved                     |
| 0    | WO   | 0x0         | Drives the PTMTRIGGER output |

# PTM\_ITATBDATA0

Address: PTM BASE + offset(0xeec)

| Bits | Attr | Reset Value | Description                   |
|------|------|-------------|-------------------------------|
| 31:5 | -    | -           | Reserved                      |
| 4    | WO   | -           | Drives the ATDATAM[31] output |
| 3    | WO   | -           | Drives the ATDATAM[23] output |
| 2    | WO   | -           | Drives the ATDATAM[15] output |
| 1    | WO   | -           | Drives the ATDATAM[7] output  |
| 0    | WO   | -           | Drives the ATDATAM[0] output  |

### PTM ITATBCTR2

Address: PTM BASE + offset(0xef0)

| Bits | Attr | Reset Value | Description                             |
|------|------|-------------|-----------------------------------------|
| 31:2 | _    | 1           | Reserved                                |
| 1    | RO   | -           | Returns the value of the AFVALIDM input |
| 0    | RO   | U '         | Returns the value of the ATREADYM input |

#### PTM\_ITATBID

Address: PTM\_BASE + offset(0xef4)

| Bits | Attr | Reset Value | Description                   |
|------|------|-------------|-------------------------------|
| 31:7 | -    | -           | Reserved                      |
| 6:0  | WO   | -           | Drives the ATIDM[6:0] outputs |

#### PTM\_ITATBCTR0

Address: PTM BASE + offset(0xef8)

| Bits  | Attr | Reset Value | Description                 |
|-------|------|-------------|-----------------------------|
| 31:10 | -    | -           | Reserved                    |
| 9:8   | WO   | -           | Drives the ATBYTESM outputs |
| 7:2   | -    | -           | Reserved                    |
| 1     | WO   | -           | Drives the AFREADYM output  |
| 0     | WO   | -           | Drives the ATVALIDM output  |



# PTM\_ETMITCTRL

Address: PTM\_BASE + offset(0xff0)

| Bits | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | -    | -           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0    | RW   | 0x0         | When bit [0] is set to 1, the PTM enters an integration mode. On reset this bit is cleared to 0.  Before entering integration mode, the PTM must be powered up and in programming mode. This means bit [0] of the Main Control Register is set to 0, and bit [10] of the Main Control Register is set to 1.  After leaving integration mode, the PTM must be reset before attempting to perform tracing. |

# PTM\_PID4

Address: PTM\_BASE + offset(0xfd0)

| Bits | Attr | Reset Value | Description                                                                                                 |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------|
| 31:8 | _    | -           | Reserved                                                                                                    |
| 7:4  | RO   | 0x04        | The peripheral identification registers provide standard information required for all CoreSight components. |
| 3:0  | _    | -           | Reserved                                                                                                    |

# PTM\_PID5

Address: PTM\_BASE + offset(0xfd4)

| Bits | Attr | Reset Value | Description                                                                                                 |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                                    |
| 7:4  | RO   | 0x00        | The peripheral identification registers provide standard information required for all CoreSight components. |
| 3:0  | -    | - 1         | Reserved                                                                                                    |

# PTM\_PID6

Address: PTM\_BASE + offset(0xfd8)

| Bits | Attr | Reset Value | Description                                                                                                 |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------|
| 31:8 | )    | -           | Reserved                                                                                                    |
| 7:4  | RO   | 0x00        | The peripheral identification registers provide standard information required for all CoreSight components. |
| 3:0  | -    | -           | Reserved                                                                                                    |

# PTM\_PID7

Address: PTM\_BASE + offset(0xfdc)

| Bits | Attr | Reset Value | Description                                                                                                 |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------|
| 31:8 | _    | -           | Reserved                                                                                                    |
| 7:4  | RO   | 0x00        | The peripheral identification registers provide standard information required for all CoreSight components. |



| 3:0 | - | - | Reserved |
|-----|---|---|----------|
|-----|---|---|----------|

#### PTM\_PID0

Address: PTM BASE + offset(0xfe0)

| Bits | Attr | Reset Value | Reset Value Description                                                                                     |  |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------|--|
| 31:8 | -    | -           | Reserved                                                                                                    |  |
| 7:4  | RO   | 0x50        | The peripheral identification registers provide standard information required for all CoreSight components. |  |
| 3:0  | -    | -           | Reserved                                                                                                    |  |

### PTM\_PID1

Address: PTM\_BASE + offset(0xfe4)

| Bits | Attr | Reset Value | Description                                                                                                 |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                                    |
| 7:4  | RO   | 0xb9        | The peripheral identification registers provide standard information required for all CoreSight components. |
| 3:0  | -    | -           | Reserved                                                                                                    |

# PTM\_PID2

Address: PTM\_BASE + offset(0xfe8)

| Bits | Attr | Reset Value | Description                                                                                                 |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                                    |
| 7:4  | RO   | 0x1b        | The peripheral identification registers provide standard information required for all CoreSight components. |
| 3:0  | -    | -           | Reserved                                                                                                    |

# PTM\_PID3

Address: PTM BASE + offset(0xfec)

| Bits | Attr             | Reset Value | Description                                                                                                 |  |
|------|------------------|-------------|-------------------------------------------------------------------------------------------------------------|--|
| 31:8 | - <sub>A</sub> ( |             | Reserved                                                                                                    |  |
| 7:4  | RO               | 0x00        | The peripheral identification registers provide standard information required for all CoreSight components. |  |
| 3:0  | )                | -           | Reserved                                                                                                    |  |

# PTM\_CID0

Address: PTM\_BASE + offset(0xff0)

| Bits | Attr | Reset Value | Description                                                                      |
|------|------|-------------|----------------------------------------------------------------------------------|
| 31:0 | RO   | 0x0d        | The component identification registers identify the PTM as a CoreSight component |

# PTM\_CID1

Address: PTM\_BASE + offset(0xff4)

| Bits | Attr | Reset Value | Description                                                                      |
|------|------|-------------|----------------------------------------------------------------------------------|
| 31:0 | RO   | 0x90        | The component identification registers identify the PTM as a CoreSight component |



# PTM\_CID2

Address: PTM BASE + offset(0xff8)

| Bits | Attr | Reset Value | Description                                                                      |
|------|------|-------------|----------------------------------------------------------------------------------|
| 31:0 | RO   | 0x05        | The component identification registers identify the PTM as a CoreSight component |

# PTM\_CID3

Address: PTM\_BASE + offset(0xffc)

| В   | its | Attr | Reset Value | Description                                                                      |
|-----|-----|------|-------------|----------------------------------------------------------------------------------|
| 31: | 0   | RO   | 0xb1        | The component identification registers identify the PTM as a CoreSight component |

# 6.4.9 Funnel register summary

| Name                  | Offset | Size | Reset<br>Value | Description                          |
|-----------------------|--------|------|----------------|--------------------------------------|
| FUNNEL_FCR            | 0x0    | W    | 0x300          | CSTF Control Register                |
| FUNNEL_PCR            | 0x4    | W    | 0xfac688       | CSTF Priority Control<br>Register    |
| FUNNEL_ITATBDATA<br>0 | 0xeec  | W    | 0x0            | CSTF Integration Test<br>Registers   |
| FUNNEL_ITATBCTR2      | 0xef0  | W    | 0x0            | CSTF Integration Test<br>Registers   |
| FUNNEL_ITATBCTR1      | 0xef4  | W    | 0x0            | CSTF Integration Test<br>Registers   |
| FUNNEL_ITATBCTR0      | 0xef8  | W    | 0x0            | CSTF Integration Test<br>Registers   |
| FUNNEL_IMCR           | 0xff0  | W    | 0x0            | Integration Mode Control<br>Register |
| FUNNEL_CTSR           | 0xfa0  | W    | 0xf            | Claim Tag Set Register               |
| FUNNEL_CTCR           | 0xfa4  | W    | 0x0            | Claim Tag Clear Register             |
| FUNNEL_LA             | 0xfb0  | W    | -              | Lock Access                          |
| FUNNEL_LS             | 0xfb4  | W    | 0x0            | Lock Status                          |
| FUNNEL_AS             | 0xfb8  | W    | 0x0            | Authentication status                |
| FUNNEL_DI             | 0xfc8  | W    | 0x28           | Device ID                            |
| FUNNEL_DTI            | 0xfcc  | W    | 0x12           | Device Type Identifier               |
| FUNNEL_PID4           | 0xfd0  | W    | 0x04           | Peripheral ID4                       |
| FUNNEL_PID0           | 0xfe0  | W    | 0x08           | Peripheral ID0                       |
| FUNNEL_PID1           | 0xfe4  | W    | 0xb9           | Peripheral ID1                       |
| FUNNEL_PID2           | 0xfe8  | W    | 0x1b           | Peripheral ID2                       |
| FUNNEL_PID3           | 0xfec  | W    | 0x00           | Peripheral ID3                       |
| FUNNEL_CID0           | 0xff0  | W    | 0x0d           | Component ID0                        |
| FUNNEL_CID1           | 0xff4  | W    | 0x90           | Component ID1                        |
| FUNNEL_CID2           | 0xff8  | W    | 0x05           | Component ID2                        |
| FUNNEL_CID3           | 0xffc  | W    | 0xb1           | Component ID3                        |

# 6.4.10 Funnel register details

# FUNNEL\_CR

Address: FUNNEL\_BASE + offset(0x000)



| Bits  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:12 | _    | -           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
| 11:8  | RW   | 0x3         | Minimum hold time[3:0] The formatting scheme can easily become inefficient if fast switching occurs, so, where possible, this must be minimized. If a source has nothing to transmit, then another source is selected irrespective of the minimum number of cycles. Reset is 0x3. The CSTF holds for the minimum hold time and one additional cycle. The maximum value that can be entered is 0xE and this equates to 15 cycles.  0xF is reserved. |  |
| 7     | RW   | 0x0         | Enable Slave port 7 Setting this bit enables this input, or slave, port. If the bit is not set then this has the effect of excluding the port from the priority selection scheme. The reset value is all clear, that is, all ports disabled.                                                                                                                                                                                                       |  |
| 6     | RW   | 0×0         | Enable Slave port 6 Setting this bit enables this input, or slave, port. If the bit is not set then this has the effect of excluding the port from the priority selection scheme. The reset value is all clear, that is, all ports disabled.                                                                                                                                                                                                       |  |
| 5     | RW   | 0×0         | Enable Slave port 5 Setting this bit enables this input, or slave, port. If the bit is not set then this has the effect of excluding the port from the priority selection scheme. The reset value is all clear, that is, all ports disabled.                                                                                                                                                                                                       |  |
| 4     | RW   | 0×0         | Enable Slave port 4 Setting this bit enables this input, or slave, port. If the bit is not set then this has the effect of excluding the port from the priority selection scheme. The reset value is all clear, that is, all ports disabled.                                                                                                                                                                                                       |  |
| 3     | RW   | 0×0         | Enable Slave port 3 Setting this bit enables this input, or slave, port. If the bit is not set then this has the effect of excluding the port from the priority selection scheme. The reset value is all clear, that is, all ports disabled.                                                                                                                                                                                                       |  |
| 2     | RW   | 0×0         | Enable Slave port 2 Setting this bit enables this input, or slave, port. If the bit is not set then this has the effect of excluding the port from the priority selection scheme. The reset value is all clear, that is, all ports disabled.                                                                                                                                                                                                       |  |
| 1     | RW   | 0×0         | Enable Slave port 1 Setting this bit enables this input, or slave, port. If the bit is not set then this has the effect of excluding the port from the priority selection                                                                                                                                                                                                                                                                          |  |



|     |    |     | scheme. The reset value is all clear, that is, all ports disabled.                                                                                                                                                                           |
|-----|----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 R | RW | 0x0 | Enable Slave port 0 Setting this bit enables this input, or slave, port. If the bit is not set then this has the effect of excluding the port from the priority selection scheme. The reset value is all clear, that is, all ports disabled. |

# FUNNEL\_PCR

Address: FUNNEL BASE + offset(0x004)

| Bits  | Attr | Reset Value | Description                                                                                                                                      |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | -    | -           | Reserved                                                                                                                                         |
| 23:21 | RW   | 0×0         | PriPort 7 Priority value of the eighth port. The value written into this location is the value that you want to assign the eighth slave port.    |
| 20:18 | RW   | 0x0         | PriPort 6 7th port priority value.                                                                                                               |
| 17:15 | RW   | 0x0         | PriPort 5 6th port priority value.                                                                                                               |
| 14:12 | RW   | 0x0         | PriPort 4 5th port priority value.                                                                                                               |
| 11:9  | RW   | 0x0         | PriPort 3 4th port priority value.                                                                                                               |
| 8:6   | RW   | 0x0         | PriPort 2 3th port priority value.                                                                                                               |
| 5:3   | RW   | 0x0         | PriPort 1 2th port priority value.                                                                                                               |
| 2:0   | RW   | 0x0         | PriPort 0 Priority value of the first slave port. The value written into this location is the value that you want to assign the first slave port |

# FUNNEL\_ITATBDATA0

Address: FUNNEL\_BASE + offset(0xeec)

| Bits | Attr | Reset Value | Description              |  |  |  |
|------|------|-------------|--------------------------|--|--|--|
| 31:5 |      | -           | Reserved                 |  |  |  |
| 4    | RW   | 0x0         | the value of ATDATAS<31> |  |  |  |
| 3    | RW   | 0x0         | the value of ATDATAS<23> |  |  |  |
| 2    | RW   | 0x0         | the value of ATDATAS<15> |  |  |  |
| 1    | RW   | 0x0         | the value of ATDATAS<7>  |  |  |  |
| 0    | RW   | 0x0         | the value of ATDATAS<0>  |  |  |  |

# FUNNEL\_ITATBCTR2

Address: FUNNEL BASE + offset(0xef0)

| Bits | Attr | Reset Value | Description           |
|------|------|-------------|-----------------------|
| 31:2 | -    | -           | Reserved              |
| 1    | RW   | 0x0         | the value of AFVALIDM |
| 0    | RW   | 0x0         | the value of ATREADYM |



# FUNNEL\_ITATBCTR1

Address: FUNNEL BASE + offset(0xef4)

| Bits | Attr | Reset Value | Description        |  |  |  |
|------|------|-------------|--------------------|--|--|--|
| 31:7 | -    | -           | Reserved           |  |  |  |
| 6:0  | RW   | 0x0         | the value of ATIDS |  |  |  |

#### **FUNNEL\_ITATBCTR0**

Address: FUNNEL BASE + offset(0xef4)

| Bits  | Attr | Reset Value | Description                        |
|-------|------|-------------|------------------------------------|
| 31:10 | -    | -           | Reserved                           |
| 9:8   | RW   | 0x0         | the value of ATBYTESS <n></n>      |
| 7:2   | -    | -           | Reserved                           |
| 1     | RW   | 0x0         | the value of AFREADYS <n></n>      |
| 0     | RW   | 0x0         | Read the value of ATVALIDS <n></n> |

# **FUNNEL\_CTS- FUNNEL\_CTC**

Address: FUNNEL BASE + offset(0xfa0-0xfa4)

| Bits | Attr | Reset Value | Description                                                                          |
|------|------|-------------|--------------------------------------------------------------------------------------|
| 31:4 | -    | -           | Reserved                                                                             |
| 3:0  | RW   | 0x0         | The CSTF implements a four-bit claim tag. The use of bits [3:0] is software defined. |

# **FUNNEL\_LA- FUNNEL\_LS**

Address: FUNNEL BASE + offset(0xfb0-0xfb4)

| Bits | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                        |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | _    | -           | Reserved                                                                                                                                                                                                                                                                                                           |
| 2:0  | RW   | 0x3         | The CSTF implements two memory maps controlled through PADDRDBG31. When PADDRDBG31 is HIGH, the Lock Status Register reads as 0x0 indicating that no lock exists. WhenPADDRDBG31 is LOW, the Lock Status Register reads as 0x3 from reset. This indicates a 32-bit lock access mechanism is present and is locked. |

# **FUNNEL AS**

Address: FUNNEL BASE + offset(0xfb8)

| Bits | Attr | Reset Value | Description                                                                                 |
|------|------|-------------|---------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                    |
| 7:0  | RW   | 0x0         | Reports the required security level. This is set to 0x00 for functionality not implemented. |

### **FUNNEL\_DID**

Address: FUNNEL\_BASE + offset(0xfc8)

| Bits | Attr | Reset Value | Description                                   |  |  |
|------|------|-------------|-----------------------------------------------|--|--|
| 31:8 | -    | -           | Reserved                                      |  |  |
| 7:4  | RW   | 0x0         | The CSTF implements a static priority scheme. |  |  |



|     |       |       | This | is | the | value | of | the | Verilog            | define |
|-----|-------|-------|------|----|-----|-------|----|-----|--------------------|--------|
| 3:0 | :0 RW | V 0X8 |      |    |     | •     |    |     | number<br>all 8 po | •      |
|     |       |       |      |    |     | •     |    |     | gal value          |        |

# FUNNEL\_DTID

Address: FUNNEL\_BASE + offset(0xfcc)

| Bits | Attr | Reset Value | Description                                                                                                  |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                                     |
| 7:0  | RW   | 0x12        | A value of $0x12$ identifies this device as a trace link $(0x2)$ and specifically as a funnel/router $(0x1)$ |

# FUNNEL\_PID4

Address: FUNNEL\_BASE + offset(0xfd0)

| Bits | Attr | Reset Value | Description                                                                                                 |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                                    |
| 7:4  | RO   | 0x04        | The peripheral identification registers provide standard information required for all CoreSight components. |
| 3:0  | -    | -           | Reserved                                                                                                    |

#### FUNNEL\_PID5

Address: FUNNEL\_BASE + offset(0xfd4)

| Bits | Attr | Reset Value | Description                                                                                                 |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                                    |
| 7:4  | RO   | 0x00        | The peripheral identification registers provide standard information required for all CoreSight components. |
| 3:0  | -    | - • 0       | Reserved                                                                                                    |

#### FUNNEL\_PID6

Address: FUNNEL BASE + offset(0xfd8)

| Bits | Attr | Reset Value | Description                                                                                                 |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------|
| 31:8 | - 1  | 7-          | Reserved                                                                                                    |
| 7:4  | RO   | 0×00        | The peripheral identification registers provide standard information required for all CoreSight components. |
| 3:0  | -    | -           | Reserved                                                                                                    |

# FUNNEL\_PID7

Address: FUNNEL\_BASE + offset(0xfdc)

| Bits | Attr | Reset Value | Description                                                                                                 |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                                    |
| 7:4  | RO   | 0x00        | The peripheral identification registers provide standard information required for all CoreSight components. |
| 3:0  | -    | -           | Reserved                                                                                                    |

# FUNNEL\_PID0



Address: FUNNEL BASE + offset(0xfe0)

| Bits | Attr | Reset Value | Description                                                                                                 |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                                    |
| 7:4  | RO   | 0x50        | The peripheral identification registers provide standard information required for all CoreSight components. |
| 3:0  | _    | -           | Reserved                                                                                                    |

# FUNNEL\_PID1

Address: FUNNEL BASE + offset(0xfe4)

| Bits | Attr | Reset Value | Description                                                                                                 |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                                    |
| 7:4  | RO   | 0xb9        | The peripheral identification registers provide standard information required for all CoreSight components. |
| 3:0  | -    | -           | Reserved                                                                                                    |

#### FUNNEL\_PID2

Address: FUNNEL\_BASE + offset(0xfe8)

| Bits | Attr | Reset Value | Description                                                                                                 |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                                    |
| 7:4  | RO   | 0x1b        | The peripheral identification registers provide standard information required for all CoreSight components. |
| 3:0  | -    | -           | Reserved                                                                                                    |

#### **FUNNEL PID3**

Address: FLINNEL BASE + offset(Oxfec)

| Bits | Attr | Reset Value | Description                                                                                                 |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------|
| 31:8 | _    | - \         | Reserved                                                                                                    |
| 7:4  | RO   | 0×00        | The peripheral identification registers provide standard information required for all CoreSight components. |
| 3:0  | - \  | -           | Reserved                                                                                                    |

#### FUNNEL\_CIDO

Address: FUNNEL BASE + offset(0xff0)

| 7 (dd. 0001 1 0111122_D) (02 1 011000 |      |             | <i>(</i> (10)                                                                    |
|---------------------------------------|------|-------------|----------------------------------------------------------------------------------|
| Bits                                  | Attr | Reset Value | Description                                                                      |
| 31:0                                  | RO   | 0x0d        | The component identification registers identify the PTM as a CoreSight component |

#### **FUNNEL\_CID1**

Address: FUNNEL BASE + offset(0xff4)

| Bits | Attr | Reset Value | Description                                                                      |
|------|------|-------------|----------------------------------------------------------------------------------|
| 31:0 | RO   | i iivaii    | The component identification registers identify the PTM as a CoreSight component |

# FUNNEL\_CID2

Address: FUNNEL\_BASE + offset(0xff8)



| Bits | Attr | Reset Value | Description                                                                      |
|------|------|-------------|----------------------------------------------------------------------------------|
| 31:0 | RO   | 1 112115    | The component identification registers identify the PTM as a CoreSight component |

# FUNNEL\_CID3

Address: FUNNEL\_BASE + offset(0xffc)

| Bi   | ts | Attr | Reset Value | Description                                                                      |
|------|----|------|-------------|----------------------------------------------------------------------------------|
| 31:0 | )  | RO   | 0xb1        | The component identification registers identify the PTM as a CoreSight component |

# 6.4.11 CTI register summary

| Name               | Offset          | Size | Reset<br>Value | Description                                           |
|--------------------|-----------------|------|----------------|-------------------------------------------------------|
| CTI_CTICONTROL     | 0x000           | W    | 0x0            | CTI Control Register                                  |
| CTI_CTIINTACK      | 0x010           | W    | -              | CTI Interrupt Acknowledge Register                    |
| CTI_CTIAPPSET      | 0x014           | W    | 0x0            | CTI Application Trigger<br>Set Register               |
| CTI_CTIAPPCLEAR    | 0x018           | W    | 0x0            | CTI Application Trigger<br>Clear Register             |
| CTI_CTIAPPPULSE    | 0x01c           | W    | 0×0            | CTI Application Pulse<br>Register                     |
| CTI_CTIINEN        | 0x020-0<br>x03c | w    | 0×0            | CTI Trigger to Channel Enable Registers, CTIINEN0-7   |
| CTI_CTIOUTEN       | 0x0a0-0<br>x0bc | w    | 0x0            | CTI Channel to Trigger Enable Registers, CTIOUTEN0-7  |
| CTI_CTITRIGINSTATU | 0x130           | w    | 0x0            | CTI Trigger In Status<br>Register,<br>CTITRIGINSTATUS |
| CTI_CTICHINSTATUS  | 0x138           | W    | -              | CTI Channel In Status<br>Register, CTICHINSTATUS      |
| CTI_CTICHOUTSTATU  | 0x13c           | W    | 0x0            | CTI Channel Out Status<br>Register                    |
| CTI_CTIGATE        | 0x140           | W    | 0xf            | Enable CTI Channel Gate<br>Register                   |
| CTI_ASICCTL        | 0x144           | W    | 0x0            | External Multiplexor<br>Control Register              |
| CTI_ITCHINACK      | 0xedc           | W    | 0x0            | ITCHINACK Register                                    |
| CTI_ITTRIGINACK    | 0xee0           | W    | 0x0            | ITTRIGINACK Register                                  |
| CTI_ITCHOUT        | 0xee4           | W    | 0x0            | ITCHOUT Register                                      |
| CTI_ITTRIGOUT      | 0xee8           | W    | 0x0            | ITTRIGOUT Register                                    |
| CTI_ITCHOUTACK     | 0xeec           | W    | 0x0            | ITCHOUTACK Register                                   |
| CTI_ITTRIGOUTACK   | 0xef0           | W    | 0x0            | ITTRIGOUTACK Register                                 |
| CTI_ITCHIN         | 0xef4           | W    | 0x0            | ITCHIN Register                                       |
| CTI_ITTRIGIN       | 0xef8           | W    | 0x0            | ITTRIGIN Register                                     |
| CTI_ITCTRL         | 0xf00           | W    | 0x0            | ITCTRL Register                                       |
| CTI_CTSR           | 0xfa0           | W    | 0xf            | Claim Tag Set Register                                |
| CTI_CTCR           | 0xfa4           | W    | 0x0            | Claim Tag Clear Register                              |



| CTI_LA   | 0xfb0 | W | -    | Lock Access            |
|----------|-------|---|------|------------------------|
| CTI_LS   | 0xfb4 | W | 0x0  | Lock Status            |
| CTI_AS   | 0xfb8 | W | 0x0  | Authentication status  |
| CTI_DI   | 0xfc8 | W | 0x28 | Device ID              |
| CTI_DTI  | 0xfcc | W | 0x12 | Device Type Identifier |
| CTI_PID4 | 0xfd0 | W | 0x04 | Peripheral ID4         |
| CTI_PID5 | 0xfd4 | W | 0x00 | Peripheral ID5         |
| CTI_PID6 | 0xfd8 | W | 0x00 | Peripheral ID6         |
| CTI_PID7 | 0xfdc | W | 0x00 | Peripheral ID7         |
| CTI_PID0 | 0xfe0 | W | 0x08 | Peripheral ID0         |
| CTI_PID1 | 0xfe4 | W | 0xb9 | Peripheral ID1         |
| CTI_PID2 | 0xfe8 | W | 0x1b | Peripheral ID2         |
| CTI_PID3 | 0xfec | W | 0x00 | Peripheral ID3         |
| CTI_CID0 | 0xff0 | W | 0x0d | Component ID0          |
| CTI_CID1 | 0xff4 | W | 0x90 | Component ID1          |
| CTI_CID2 | 0xff8 | W | 0x05 | Component ID2          |
| CTI_CID3 | 0xffc | W | 0xb1 | Component ID3          |

# 6.4.12 CTI register details

#### CTI\_CTICONTROL

Address: CTI\_BASE + offset(0x000)

| Bits | Attr | Reset Value | Description                                                                                                                                                         |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | -    | -           | Reserved                                                                                                                                                            |
| 0    | RW   | 0x0         | GLBEN Enables or disables the ECT: 0 = disabled (reset) 1 = enabled. When disabled, all cross triggering mapping logic functionality is disabled for this processor |

#### CTI\_CTIINTACK

Address: CTI BASE + offset(0x010)

| Bits | Attr | Reset Value | Description                                                                                                                                                                                                 |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | -11  |             | Reserved                                                                                                                                                                                                    |
| 7:0  | wo   | -           | INTACK Acknowledges the corresponding CTITRIGOUT output:  1 = CTITRIGOUT is acknowledged and is cleared when MAPTRIGOUT is LOW.  0 = no effect. There is one bit of the register for each CTITRIGOUT output |

# CTI\_CTIAPPSET

Address: CTI\_BASE + offset(0x014)

| Bits | Attr | Reset Value | Description                                      |
|------|------|-------------|--------------------------------------------------|
| 31:4 | -    | -           | Reserved                                         |
|      |      |             | APPSET                                           |
| 3:0  | RW   | 0x0         | Setting a bit HIGH generates a channel event for |
|      |      |             | the selected channel.                            |



|  | Read:                                             |
|--|---------------------------------------------------|
|  | 0 = application trigger inactive (reset)          |
|  | 1 = application trigger active.                   |
|  | Write:                                            |
|  | 0 = no effect                                     |
|  | 1 = generate channel event.                       |
|  | There is one bit of the register for each channel |

#### CTI\_CTIAPPCLEAR

Address: CTI BASE + offset(0x018)

| Bits | Attr | Reset Value | Description                                                                                                                                                                          |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | -    | -           | Reserved                                                                                                                                                                             |
| 3:0  | wo   | -           | Clears corresponding bits in the CTIAPPSET register.  1 = application trigger disabled in the CTIAPPSET register  0 = no effect.  There is one bit of the register for each channel. |

# CTI\_CTIAPPPULSE

Address: CTI\_BASE + offset(0x01c)

| Bits | Attr | Reset Value | Description                                                                                                                                                                                                           |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | _    | -           | Reserved                                                                                                                                                                                                              |
| 3:0  | wo   | -           | APPULSE Setting a bit HIGH generates a channel event pulse for the selected channel. Write: 1 = channel event pulse generated for one CTICLK period 0 = no effect. There is one bit of the register for each channel. |

# CTI\_CTIINENO-7

Address: CTI\_BASE + offset(0x020-0x03c)

| Bits | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | -    | 7           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3:0  | RW   | 0x0         | TRIGINEN Enables a cross trigger event to the corresponding channel when an CTITRIGIN is activated.  1 = enables the CTITRIGIN signal to generate an event on the respective channel of the CTM. There is one bit of the register for each of the four channels. For example in register CTIINENO, TRIGINEN[0] set to 1 enables CTITRIGIN onto channel 0.  0 = disables the CTITRIGIN signal from generating an event on the respective channel of the CTM |

# CTI\_CTIOUTEN0-7

Address: CTI\_BASE + offset(0x0a0-0x0bc)



| Bits | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | -    | -           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 3:0  | RW   | 0×0         | TRIGOUTEN Changing the value of this bit from a 0 to a 1 enables a channel event for the corresponding channel to generate an CTITRIGOUT output: 0 = the channel input (CTICHIN) from the CTM is not routed to the CTITRIGOUT output 1 = the channel input (CTICHIN) from the CTM is routed to the CTITRIGOUT output. There is one bit for each of the four channels. For example in register CTIOUTENO, enabling bit 0 enables CTICHIN[0] to cause a trigger event on the CTITRIGOUT[0] output. |

# CTI\_CTITRIGINSTATUS

Address: CTI BASE + offset(0x130)

| Bits | Attr | Reset Value | Description                                                                                                                                                                                                                                                         |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                                                                                                                                                                                            |
| 7:0  | RW   | 0×0         | TRIGINSTATUS Shows the status of the CTITRIGIN inputs:  1 = CTITRIGIN is active  0 = CTITRIGIN is inactive.  Because the register provides a view of the raw CTITRIGIN inputs, the reset value is unknown. There is one bit of the register for each trigger input. |

# **CTI\_CTITRIGOUTSTATUS**

Address: CTI BASE + offset(0x134)

| Bits | Attr | Reset Value | Description                                                                                                                                                                         |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | - Y         | Reserved                                                                                                                                                                            |
| 7:0  | RW   | 0×0         | TRIGOUTSTATUS Shows the status of the CTITRIGOUT outputs.  1 = CTITRIGOUT is active  0 = CTITRIGOUT is inactive (reset).  There is one bit of the register for each trigger output. |

# CTI\_CTICHINSTATUS

Address: CTI BASE + offset(0x138)

| Bits | Attr | Reset Value | Description                                                                                                                                                                                                                                                               |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | -    | -           | Reserved                                                                                                                                                                                                                                                                  |
| 3:0  | RW   | 0×0         | CTICHINSTATUS Shows the status of the CTICHIN inputs:  1 = CTICHIN is active  0 = CTICHIN is inactive.  Because the register provides a view of the raw CTICHIN inputs from the CTM, the reset value is unknown. There is one bit of the register for each channel input. |



# CTI\_CTICHOUTSTATUS

Address: CTI\_BASE + offset(0x13c)

| Bits | Attr | Reset Value | Description                                                                                                                                                                    |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | -    | -           | Reserved                                                                                                                                                                       |
| 3:0  | RW   | 0x0         | CTICHOUTSTATUS Shows the status of the CTICHOUT outputs.  1 = CTICHOUT is active  0 = CTICHOUT is inactive (reset).  There is one bit of the register for each channel output. |

# CTI\_CTIGATE

 $\Delta ddress \cdot CTI BASE + offset(0x140)$ 

| Bits | Attr | Reset Value | description                                                           |
|------|------|-------------|-----------------------------------------------------------------------|
| 31:4 | -    | -           | Reserved                                                              |
| 3    | RW   | 0x0         | CTIGATEEN3 Enable CTICHOUT3. Set to 0 to disable channel propagation. |
| 2    | RW   | 0x0         | CTIGATEEN2 Enable CTICHOUT2. Set to 0 to disable channel propagation. |
| 1    | RW   | 0x0         | CTIGATEEN1 Enable CTICHOUT1. Set to 0 to disable channel propagation. |
| 0    | RW   | 0x0         | CTIGATEEN0 Enable CTICHOUT0. Set to 0 to disable channel propagation  |

# CTI\_ASICCTL

Address: CTI\_BASE + offset(0x144)

| Bits | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                               |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | 307         | Reserved                                                                                                                                                                                                                                                                                                                  |
| 7:0  | RW   | 0×0         | ASICCTL Implementation-defined ASIC control, value written to the register is output on ASICCTL[7:0].  If external multiplexing of trigger signals is implemented then the number of multiplexed signals on each trigger must be reflected within the Device ID Register. This is done within a Verilog define EXTMUXNUM. |

# CTI\_ITCHINACK

Address: CTI BASE + offset(0xedc)

| Bits | Attr | Reset Value | Description                                      |
|------|------|-------------|--------------------------------------------------|
| 31:4 | -    | -           | Reserved                                         |
| 3:0  | WO   | -           | CTCHINACK Set the value of the CTCHINACK outputs |

# CTI\_ITTRIGINACK

Address: CTI\_BASE + offset(0xee0)

| Bits | Attr | Reset Value | Description |
|------|------|-------------|-------------|
|      |      |             | <u>-</u>    |



| 31:8 | -      | - | Reserved                                 |
|------|--------|---|------------------------------------------|
| 7.0  | ':0 WO | - | CTTRIGINACK                              |
| 7:0  |        |   | Set the value of the CTTRIGINACK outputs |

#### CTI\_ITCHOUT

Address: CTI\_BASE + offset(0xee4)

| Bits | Attr | Reset Value | Description                                  |
|------|------|-------------|----------------------------------------------|
| 31:4 | -    | -           | Reserved                                     |
| 3:0  | wo   | -           | CTCHOUT Set the value of the CTCHOUT outputs |

# CTI\_ITTRIGOUT

Address: CTI\_BASE + offset(0xee8)

| Bits | Attr | Reset Value | Description                                      |
|------|------|-------------|--------------------------------------------------|
| 31:8 | -    | -           | Reserved                                         |
| 7:0  | wo   | -           | CTTRIGOUT Set the value of the CTTRIGOUT outputs |

### CTI\_ITCHOUTACK

Address: CTI BASE + offset(0xeec)

| Bits | Attr | Reset Value | Description                                         |
|------|------|-------------|-----------------------------------------------------|
| 31:4 | -    | -           | Reserved                                            |
| 3:0  | RO   | 0x0         | CTCHOUTACK Read the values of the CTCHOUTACK inputs |

# CTI\_ITTRIGOUTACK

Address: CTI BASE + offset(0xef0)

| Bits | Attr | Reset Value | Description                                             |
|------|------|-------------|---------------------------------------------------------|
| 31:8 | -    |             | Reserved                                                |
| 7:0  | RO   | 0x0         | CTTRIGOUTACK Read the values of the CTTRIGOUTACK inputs |

### CTI\_ITCHIN

Address: CTI\_BASE + offset(0xef4)

| Bits | Attr | Reset Value | Description                                 |
|------|------|-------------|---------------------------------------------|
| 31:4 |      | -           | Reserved                                    |
| 3:0  | RO   | 0x0         | CTCHIN Read the values of the CTCHIN inputs |

# CTI\_ITTRIGIN

Address: CTI BASE + offset(0xef8)

| Bits | Attr | Reset Value | Description                                     |
|------|------|-------------|-------------------------------------------------|
| 31:8 | -    | -           | Reserved                                        |
| 7:0  | RO   | 0x0         | CTTRIGIN Read the values of the CTTRIGIN inputs |

# CTI\_CTS- CTI\_CTC

Address: CTI\_BASE + offset(0xfa0-0xfa4)

| - 3 |      |      |             |             |
|-----|------|------|-------------|-------------|
|     | Bits | Attr | Reset Value | Description |



| 31:4 | -  | -   | Reserved                                                                           |
|------|----|-----|------------------------------------------------------------------------------------|
| 3:0  | RW | 0x0 | The CTI implements a four-bit claim tag. The use of bits [3:0] is software defined |

# CTI\_LA- CTI\_LS

Address: CTI\_BASE + offset(0xfb0-0xfb4)

| Bits | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                       |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | _    | -           | Reserved                                                                                                                                                                                                                                                                                                          |
| 2:0  | RW   | 0x3         | The CTI implements two memory maps controlled through PADDRDBG31. When PADDRDBG31 is HIGH, the Lock Status Register reads as 0x0 indicating that no lock exists. WhenPADDRDBG31 is LOW, the Lock Status Register reads as 0x3 from reset. This indicates a 32-bit lock access mechanism is present and is locked. |

# CTI\_AS

Address: CTI BASE + offset(0xfb8)

| Bits | Attr | Reset Value | Description                                       |
|------|------|-------------|---------------------------------------------------|
| 31:4 | _    | -           | Reserved                                          |
| 3    | RW   | 0x0         | Current value of noninvasive debug enable signals |
| 2    | RW   | 0x0         | Non-invasive debug controlled                     |
| 1    | RW   | 0x0         | Current value of invasive debug enable signals    |
| 0    | RW   | 0x0         | Invasive debug controlled                         |

# CTI\_DID

| Bits  | Attr | Reset Value | Description                                                                                                                                                                                                                                            |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | -    | 30          | Reserved                                                                                                                                                                                                                                               |
| 19:16 | RO   | 0x0         | Number of ECT channels available.                                                                                                                                                                                                                      |
| 15:8  | RO   | 0x0         | Number of ECT triggers available.                                                                                                                                                                                                                      |
| 7:5   | -    | 7           | Reserved                                                                                                                                                                                                                                               |
| 4:0   | RO   | 0x0         | Indicates the number of multiplexing available on Trigger Inputs and Trigger Outputs using ASICCTL. Default value of 5'b00000 indicating no multiplexing present. Reflects the value of the Verilog `define EXTMUXNUM that you must alter accordingly. |

# CTI\_DTID

Address: CTI\_BASE + offset(0xfcc)

| Bits | Attr | Reset Value | Description                                                                                                                           |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                                                              |
| 7:0  | RW   | 0x14        | 0x14 indicates this device has a major type of debug control logic component (0x4) and sub-type corresponding to cross trigger (0x1). |

# CTI\_PID4



Address: CTI\_BASE + offset(0xfd0)

| Bits | Attr | Reset Value | Description                                                                                                                  |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                                                     |
| 3:0  | RO   | 0x3         | The CTI is identified as an ARM component with a JEP106 identity at 0x3B and a JEP106 continuation code at 0x4 (fifth bank). |

#### CTI\_PID0

Address: CTI\_BASE + offset(0xfe0)

| Bits | Attr | Reset Value | Description                        |
|------|------|-------------|------------------------------------|
| 31:8 | -    | -           | Reserved                           |
| 7:4  | RO   | 0x0         | Middle BCD value of Device number. |
| 3:0  | RO   | 0x6         | Lower BCD value of Device number.  |

# CTI\_PID1

Address: CTI BASE + offset(0xfe4)

| Bits | Attr | Reset Value | Description                                                                                                                  |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                                                     |
| 7:4  | RO   | 0xb         | The CTI is identified as an ARM component with a JEP106 identity at 0x3B and a JEP106 continuation code at 0x4 (fifth bank). |
| 3:0  | RO   | 0x9         | Upper BCD value of Device number.                                                                                            |

# CTI\_PID2

Address: CTI\_BASE + offset(0xfe8)

| Bits | Attr | Reset Value | Description                                                                                                                  |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | -    | -           | Reserved                                                                                                                     |
| 2:0  | RO   | 0x4         | The CTI is identified as an ARM component with a JEP106 identity at 0x3B and a JEP106 continuation code at 0x4 (fifth bank). |
| 3:0  | -    |             | Reserved                                                                                                                     |

# CTI\_PID3

Address: CTI BASE + offset(0xfec)

| Bits | Attr | Reset Value | Description                                                                                                 |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------|
| 31:8 |      | -           | Reserved                                                                                                    |
| 7:4  | RO   | 0x00        | The peripheral identification registers provide standard information required for all CoreSight components. |
| 3:0  | -    | -           | Reserved                                                                                                    |

# CTI\_CID0

Address: CTI BASE + offset(0xff0)

| Bits | Attr | Reset Value | Description                               |
|------|------|-------------|-------------------------------------------|
| 31:0 | RO   | UvUd        | The component identification registers    |
| 31.0 | KO   | 0x0d        | identify the PTM as a CoreSight component |

# CTI\_CID1

Address: CTI\_BASE + offset(0xff4)



| Bits | Attr | Reset Value | De | scription                        |   |
|------|------|-------------|----|----------------------------------|---|
| 31:0 | RO   | 0x90        | •  | identification<br>a CoreSight co | _ |

# CTI\_CID2

Address: CTI\_BASE + offset(0xff8)

| Bits | Attr | Reset Value |        | De            | scription       |           |
|------|------|-------------|--------|---------------|-----------------|-----------|
| 31:0 | RO   | 0x05        | The    | component     | identification  | registers |
| 31.0 | NO   | 0.000       | identi | fy the PTM as | a CoreSight cor | mponent   |

# CTI\_CID3

Address: CTI\_BASE + offset(0xffc)

|   | Bits | Attr | Reset Value | De | scription                         |     |
|---|------|------|-------------|----|-----------------------------------|-----|
| 3 | 1:0  | RO   | 0xb1        | •  | identification<br>a CoreSight cor | / - |

# 6.4.13 TPIU register summary

| Name                 | Offset | Size | Reset<br>Value | Description                       |
|----------------------|--------|------|----------------|-----------------------------------|
| TPIU_SPSR            | 0x000  | W    | 0x0000008a     | Supported port size               |
| TPIU_CPSR            | 0x004  | W    | 0x0000001      | Current port size                 |
| TPIU_STMR            | 0x100  | W    | 0x11f          | Supported trigger modes           |
| TPIU_TCR             | 0x104  | W    | 0x00           | Trigger counter value             |
| TPIU_TMR             | 0x108  | W    | 0x00           | Trigger multiplier                |
| TPIU_STPMR           | 0x200  | w    | 0x3000f        | Supported test pattern/modes      |
| TPIU_CTPMR           | 0x204  | W    | 0x00000        | Current test pattern/mode         |
| TPIU_TTPRCR          | 0x208  | W    | 0x00           | TPIU Test pattern repeat counter  |
| TPIU_FFSR            | 0x300  | W    | 0x0000006      | Formatter and flush status        |
| TPIU_FFCR            | 0x304  | W    | 0x00000100     | Formatter and flush control       |
| TPIU_FSCR            | 0x308  | W    | 0x00000000     | Formatter synchronization counter |
| TPIU_EXCTLPR<br>IN   | 0x400  | W    | N/A            | EXTCTL In Port                    |
| TPIU_EXCTLPR OUT     | 0x404  | W    | 0x00           | EXTCTL Out Port                   |
| TPIU_ITTRFLIN<br>ACK | 0xee4  | W    | N/A            | Integration Register              |
| TPIU_ITTRFLIN        | 0xee8  | W    | N/A            | Integration Register              |
| TPIU_ITATBDA<br>TA0  | 0xeec  | W    | N/A            | Integration Register              |
| TPIU_ITATBCT<br>R2   | 0xef0  | W    | N/A            | Integration Register              |
| TPIU_ITATBCT<br>R0   | 0xef8  | W    | N/A            | Integration Register              |
| TPIU_ITAMCTL         | 0xf00  | W    | 0x00000000     | Integration Mode control register |
| TPIU_CTS             | 0xfa0  | W    | 0x0000000f     | Claim tag set                     |
| TPIU_CTC             | 0xfa4  | W    | 0x00000000     | Claim tag clear                   |



| TPIU_LA   | 0xfb0 | W | N/A        | Lock access            |
|-----------|-------|---|------------|------------------------|
| TPIU_LS   | 0xfb4 | W | N/A        | Local status           |
| TPIU_AS   | 0xfb8 | W | 0x00000000 | Authentication status  |
| TPIU_DID  | 0xfc8 | W | 0x00000000 | Device ID              |
| TPIU_DTID | 0xfcc | W | 0x0000011  | Device type identifier |
| TPIU_PID4 | 0xfd0 | W | 0x00000004 | Peripheral ID4         |
| TPIU_PID0 | 0xfe0 | W | 0x00000041 | Peripheral ID0         |
| TPIU_PID1 | 0xfe4 | W | 0x000000b9 | Peripheral ID1         |
| TPIU_PID2 | 0xfe8 | W | 0x0000000b | Peripheral ID2         |
| TPIU_PID3 | 0xfec | W | 0x00000000 | Peripheral ID3         |
| TPIU_CID0 | 0xff0 | W | 0x0000000d | Component ID0          |
| TPIU_CID1 | 0xff4 | W | 0x00000090 | Component ID1          |

# 6.4.14 TPIU detailed register description

# TPIU\_SPSR

Address: TPIU BASE + offset(0x000)

| Bits | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x0000008a  | This register is read/write. Each bit location represents a single port size that is supported on the device, that is, 32-1 in bit locations [31:0]. If the bit is set then that port size is allowed. By default the RTL is designed to support all port sizes, set to 0xFFFFFFFF. This register reflects the value of the CSTPIU_SUPPORTSIZE_VAL Verilog `define value, currently not user modifiable, and is further constrained by the input tie-off TPMAXDATASIZE.  The external tie-off, TPMAXDATASIZE, must be set during finalization of the ASIC to reflect the actual number of TRACEDATA signals being wired to physical pins. This is to ensure that tools do not attempt to select a port width that cannot be captured by an attached TPA. The value on TPMAXDATASIZE causes bits within the Supported Port Size register that represent wider widths to be clear, that is, unsupported |

# TPIU\_CPSR

Address: TPIU BASE + offset(0x004)

| Bits | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x0000001   | This register is read/write. The Current Port Size Register has the same format as the Supported Port Sizes register but only one bit is set, and all others must be zero. Writing values with more than one bit set or setting a bit that is not indicated as supported is not supported and causes unpredictable behavior.  On reset this defaults to the smallest possible port size, 1 bit, and so reads as 0x00000001 |



# TPIU\_STMR

Address: TPIU\_BASE + offset(0x100)

| Bits  | Attr | Reset Value | Description                                                                     |
|-------|------|-------------|---------------------------------------------------------------------------------|
| 31:18 | -    | -           | Reserved                                                                        |
| 17    | RO   | 0x0         | Trigger Counter running. A trigger has occurred but the counter is not at zero. |
| 16    | RO   | 0x1         | Triggered. A trigger has occurred and the counter has reached zero              |
| 15:9  | -    | -           | Reserved                                                                        |
| 8     | RO   | 0x0         | 8-bit wide counter register implemented.                                        |
| 7:5   | -    | -           | Reserved                                                                        |
| 4     | RO   | 0x1         | Multiply the Trigger Counter by 65536 supported.                                |
| 3     | RO   | 0x1         | Multiply the Trigger Counter by 256 supported.                                  |
| 2     | RO   | 0x1         | Multiply the Trigger Counter by 16 supported.                                   |
| 1     | RO   | 0x1         | Multiply the Trigger Counter by 4 supported                                     |
| 0     | RO   | 0x1         | Multiply the Trigger Counter by 2 supported                                     |

# TPIU\_TCR

Address: TPIU BASE + offset(0x104)

| Bits | Attr | Reset Value | Description                                                                                                                    |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                                                       |
| 7:0  | RW   | 0x0         | 8-bit counter value for the number of words to be output from the formatter before a trigger is inserted. Reset value is 0x00. |

#### TPIU\_TMR

Address: TPIU BASE + offset(0x108)

| Bits | Attr | Reset Value | Description                                      |
|------|------|-------------|--------------------------------------------------|
| 31:5 | -    |             | Reserved                                         |
| 4    | RO   | 0x0         | Multiply the Trigger Counter by 65536 supported. |
| 3    | RO   | 0x0         | Multiply the Trigger Counter by 256 supported.   |
| 2    | RO   | 0x0         | Multiply the Trigger Counter by 16 supported.    |
| 1    | RO   | 0x0         | Multiply the Trigger Counter by 4 supported      |
| 0    | RO   | 0x0         | Multiply the Trigger Counter by 2 supported      |

# TPIU\_STPMR

Address: TPIU BASE + offset(0x200)

| Bits  | Attr | Reset Value | Description     |
|-------|------|-------------|-----------------|
| 31:18 | -    | -           | Reserved        |
| 17    | RO   | 0x1         | Continuous mode |
| 16    | RO   | 0x1         | Timed mode      |
| 15:4  | _    | -           | Reserved        |
| 3     | RO   | 0x1         | FF/00 Pattern   |



| 2 | RO | 0x1 | AA/55 Pattern      |
|---|----|-----|--------------------|
| 1 | RO | 0x1 | Walking 0s Pattern |
| 0 | RO | 0x1 | Walking 1s Pattern |

# TPIU\_CTPMR

Address: TPIU\_BASE + offset(0x204)

| Bits  | Attr | Reset Value | Description      |
|-------|------|-------------|------------------|
| 31:18 | -    | -           | Reserved         |
| 17:16 | RW   | 0x0         | Mode select      |
| 15:4  | -    | -           | Reserved         |
| 3:0   | RW   | 0x0         | Number of cycles |

# TPIU\_TTPRCR

Address: TPIU BASE + offset(0x208)

| Bits | Attr | Reset Value | Description                                                                                                                                      |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                                                                         |
| 7:0  | RW   | 0x0         | 8-bit counter value to indicate the number of TRACECLKIN cycles that a pattern runs for before switching to the next pattern. Default value is 0 |

# TPIU\_FFSR

Address: TPIU BASE + offset(0x300)

| Bits | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | -    | -           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2    | RO   | 0x1         | If this bit is set then TRACECTL is present. If no TRACECTL pin is available, that is, this bit is zero, then the data formatter must be used and only in continuous mode.  This is constrained by the CSTPIU_TRACECTL_VAL Verilog `define, which is not user modifiable, and the external tie-off TPCTL. If either constraint reports zero/LOW then no TRACECTL is present and this inability to use the pin is reflected in this register. |
| 1    | RO   | 0x1         | Formatter stopped. The formatter has received a stop request signal and all trace data and post-amble has been output. Any more trace data on the ATB interface is ignored and ATREADYS goes HIGH.                                                                                                                                                                                                                                           |
| 0    | RO   | 0x0         | Flush In Progress. This is an indication of the current state of AFVALIDS                                                                                                                                                                                                                                                                                                                                                                    |

# TPIU\_FFCR

Address: TPIU BASE + offset(0x304)

| 7 taar 6551 | <u> </u> | ISE I OHSCHONS | <i>y</i> 1 <i>y</i>                                                                |
|-------------|----------|----------------|------------------------------------------------------------------------------------|
| Bits        | Attr     | Reset Value    | Description                                                                        |
| 31:14       | _        | -              | Reserved                                                                           |
| 13          | RW       | 0x0            | Stop the formatter after a Trigger Eventa is observed. Reset to disabled, or zero. |



| 12  | RW | 0x0 | Stop the formatter after a flush completes (return of AFREADYS). This forces the FIFO to drain off any part-completed packets. Setting this bit enables this function but this is clear on reset, or disabled.            |
|-----|----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11  | -  | -   | Reserved                                                                                                                                                                                                                  |
| 10  | RW | 0x0 | Indicates a trigger on Flush completion on AFREADYS being returned.                                                                                                                                                       |
| 9   | RW | 0x0 | Indicate a trigger on a Trigger Event                                                                                                                                                                                     |
| 8   | RW | 0x1 | Indicate a trigger on TRIGIN being asserted.                                                                                                                                                                              |
| 7   | -  | -   | Reserved                                                                                                                                                                                                                  |
| 6   | RW | 0x0 | Manually generate a flush of the system. Setting this bit causes a flush to be generated. This is cleared when this flush has been serviced. This bit is clear on reset.                                                  |
| 5   | RW | 0x0 | Generate flush using Trigger event. Set this bit to cause a flush of data in the system when a Trigger Eventa occurs. Reset value is this bit clear.                                                                      |
| 4   | RW | 0x0 | Generate flush using the FLUSHIN interface.<br>Set this bit to enable use of the FLUSHIN<br>connection. This is clear on reset.                                                                                           |
| 3:2 | -  | -   | Reserved                                                                                                                                                                                                                  |
| 1   | RW | 0x0 | Continuous Formatting, no TRACECTL. Embed in trigger packets and indicate null cycles using Sync packets. Reset value is this bit clear. Can only be changed when FtStopped is HIGH.                                      |
| 0   | RW | 0x0 | Enable Formatting. Do not embed Triggers into the formatted stream. Trace disable cycles and triggers are indicated by TRACECTL, where fitted. Reset value is this bit clear. Can only be changed when FtStopped is HIGH. |

# TPIU\_FSCR

Address: TPIU BASE + offset(0x308)

| Bits  | Attr | Reset Value | Description                                                                                                                      |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:12 | )    | -           | Reserved                                                                                                                         |
| 11:0  | RW   | 0×0         | 12-bit counter value to indicate the number of complete frames between full synchronization packets. Default value is 64 (0x40). |

# TPIU\_ITTRFLINACK

Address: TPIU\_BASE + offset(0xee4)

| D:4- | A 44 | Basst Value | Description                 |
|------|------|-------------|-----------------------------|
| Bits | Attr | Reset Value | Description                 |
| 31:2 | -    | -           | Reserved                    |
| 1    | WO   | -           | Set the value of FLUSHINACK |
| 0    | WO   | -           | Set the value of TRIGINACK  |



#### TPIU\_ITTRFLIN

Address: TPIU\_BASE + offset(0xee8)

| Bits | Attr | Reset Value | Description               |
|------|------|-------------|---------------------------|
| 31:2 | -    | -           | Reserved                  |
| 1    | RO   | 0x0         | Read the value of FLUSHIN |
| 0    | RO   | 0x0         | Read the value of TRIGIN  |

# TPIU\_ITATBDATA0

Address: TPIU BASE + offset(0xeec)

| Bits | Attr | Reset Value | Description                   |
|------|------|-------------|-------------------------------|
| 31:5 | -    | -           | Reserved                      |
| 4    | RO   | 0x0         | Read the value of ATDATAS[31] |
| 3    | RO   | 0x0         | Read the value of ATDATAS[23] |
| 2    | RO   | 0x0         | Read the value of ATDATAS[15] |
| 1    | RO   | 0x0         | Read the value of ATDATAS[7]  |
| 0    | RO   | 0x0         | Read the value of ATDATAS[0]  |

#### TPIU\_ITATBCTR2

Address: TPIU\_BASE + offset(0xef0)

| Bits | Attr | Reset Value | Description               |
|------|------|-------------|---------------------------|
| 31:2 | -    | -           | Reserved                  |
| 1    | WO   | 0x0         | Set the value of AFVALIDS |
| 0    | WO   | 0x0         | Set the value of ATREADYS |

#### TPIU\_ITATBCTR1

Address: TPIU\_BASE + offset(0xef4)

| Bits | Attr | Reset Value | Description             |
|------|------|-------------|-------------------------|
| 31:7 | -    | - 2         | Reserved                |
| 6:0  | RO   | 0x0         | Read the value of ATIDS |

# TPIU\_ITATBCTR0

Address: TPIU\_BASE + offset(0xef8)

| Bits  | Attr | Reset Value | Description                |
|-------|------|-------------|----------------------------|
| 31:10 |      | -           | Reserved                   |
| 9:8   | RO   | 0x0         | Read the value of ATBYTESS |
| 7:2   | _    | -           | Reserved                   |
| 1     | RO   | 0x0         | Read the value of AFREADYS |
| 0     | RO   | 0x0         | Read the value of ATVALIDS |

# TPIU\_CTS-TPIU\_CTC

Address: TPIU\_BASE + offset(0xfa0-0xfa4)

| Bits | Attr | Reset Value | Description                                                                         |
|------|------|-------------|-------------------------------------------------------------------------------------|
| 31:4 | _    | -           | Reserved                                                                            |
| 3:0  | RW   | 0x0         | The TPIU implements a four-bit claim tag. The use of bits [3:0] is software defined |

# TPIU\_LA-TPIU\_LS



Address: TPIU BASE + offset(0xfb0-0xfb4)

| Bits | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                        |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | -    | 0xb1        | Reserved                                                                                                                                                                                                                                                                                                           |
| 2:0  | RW   | 0x3         | The TPIU implements two memory maps controlled through PADDRDBG31. When PADDRDBG31 is HIGH, the Lock Status Register reads as 0x0 indicating that no lock exists. WhenPADDRDBG31 is LOW, the Lock Status Register reads as 0x3 from reset. This indicates a 32-bit lock access mechanism is present and is locked. |

# TPIU\_AS

Address: TPIU\_BASE + offset(0xfb8)

| Bits | Attr | Reset Value | Description                                                                                                                       |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0×0         | Reports the required security level. The TPIU has a default value of 0x00 to indicate that this functionality is not implemented. |

# TPIU\_DID

Address: TPIU BASE + offset(0xfc8)

| Bits  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                         |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12 | _    | -           | Reserved                                                                                                                                                                                                                                                                            |
| 11    | RO   | 0x0         | Indicates Serial Wire Output (UART/NRZ) is not supported.                                                                                                                                                                                                                           |
| 10    | RO   | 0x0         | Indicates Serial Wire Output (Manchester) is not supported.                                                                                                                                                                                                                         |
| 9     | RO   | 0x0         | Indicates trace clock + data is supported.                                                                                                                                                                                                                                          |
| 8:6   | RO   | 0x0         | FIFO size in powers of 2. A value of 2 gives a FIFO size of 4 entries, 16 bytes.                                                                                                                                                                                                    |
| 5     | RO   | 0x0         | Indicates the relationship between ATCLK and TRACECLKIN. 0x1 indicates asynchronous.                                                                                                                                                                                                |
| 4:0   | RO   | 0x0         | Hidden Level of Input multiplexing. When nonzero this value indicates the type/number of ATB multiplexing present on the input to the ATB. Currently only 0x00 is supported, that is, no multiplexing present. This value is used to assist topology detection of the ATB structure |

# TPIU\_DTID

Address: TPIU BASE + offset(0xfcc)

| Bits | Attr | Reset Value | Description                                                                          |
|------|------|-------------|--------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                             |
| 7:0  | RW   | 0x11        | 0x11 indicates this device is a trace sink $(0x1)$ and specifically a TPIU $(0x1)$ . |

# TPIU\_PID4

Address: TPIU\_BASE + offset(0xfd0)

| Bits | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:8 | -    | -           | Reserved    |



#### TPIU\_PID0

Address: TPIU BASE + offset(0xfe0)

| Bits | Attr | Reset Value | Description                        |
|------|------|-------------|------------------------------------|
| 31:8 | -    | -           | Reserved                           |
| 7:4  | RO   | 0x1         | Middle BCD value of Device number. |
| 3:0  | RO   | 0x2         | Lower BCD value of Device number.  |

### TPIU\_PID1

Address: TPIU BASE + offset(0xfe4)

| Bits | Attr | Reset Value | Description                                                                                                                   |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                                                      |
| 7:4  | RO   | 0xb         | The TPIU is identified as an ARM component with a JEP106 identity at 0x3B and a JEP106 continuation code at 0x4 (fifth bank). |
| 3:0  | RO   | 0x9         | Upper BCD value of Device number.                                                                                             |

#### TPIU\_PID2

Address: TPIU\_BASE + offset(0xfe8)

| Bits | Attr | Reset Value | Description                                                                                                                   |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | -    | -           | Reserved                                                                                                                      |
| 2:0  | RO   | 0x4         | The TPIU is identified as an ARM component with a JEP106 identity at 0x3B and a JEP106 continuation code at 0x4 (fifth bank). |
| 3:0  | -    | -           | Reserved                                                                                                                      |

#### TPIU\_PID3

Address: TPIU BASE + offset(0xfec)

| Bits | Attr | Reset Value | Description                                                                                                 |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------|
| 31:8 |      | -           | Reserved                                                                                                    |
| 7:4  | RO   | 0×00        | The peripheral identification registers provide standard information required for all CoreSight components. |
| 3:0  | )    | -           | Reserved                                                                                                    |

#### TPIU\_CID1

Address: TPIU BASE + offset(0xff4)

|      |      |             | 1                                                                                    |
|------|------|-------------|--------------------------------------------------------------------------------------|
| Bits | Attr | Reset Value | Description                                                                          |
| 31:8 | RO   | 0x0         | Reserved                                                                             |
| 7:4  | RO   | 0x9         | The TPIU complies to the CoreSight class of components and this value is set to 0x9. |
| 3:0  | -    | 0x0         | Reserved                                                                             |

Notes: Attr: **RW**- Read/writable, **RO**- read only, **WO**- write only, **RWTC-**Readable and write "1" to clear the asserted bit from "1" to "0".

# **6.5 Interface description**

#### 6.5.1 DAP SWJ-DP interface

The following figure is the DAP SWJ-DP interface, the SWJ-DP is a combined JTAG-DP and SW-DP that enable you connect either a Serial Write Debug(SWJ) to JTAG probe to a target.



Fig. 6-2 DAP SWJ interface

| Table 6-1SWI interface   |   |
|--------------------------|---|
| Iania 6- I SWI interface | _ |
|                          | Ω |

| Module Pin | Directio | PAD Name | IOMUX Setting |
|------------|----------|----------|---------------|
|            | n        |          |               |
| TRST_N     | I        | TRST_N   | Dedicated IO  |
| TCK        | I        | TCK      | Dedicated IO  |
| TDI        | I,       | TDI      | Dedicated IO  |
| TMS        | IO       | TMS      | Dedicated IO  |
| TDO        | 0        | TDO      | Dedicated IO  |

#### 6.5.2 TPIU trace port interface

Table 6-2TPIU interface

| Module Pin    | Directio | PAD Name   | IOMUX Setting               |
|---------------|----------|------------|-----------------------------|
| Y             | n        |            |                             |
| trace_data[0] | 0        | GPIO4_C[0] | GRF_GPIO4C_IOMUX[1:0]=0x2   |
| trace_data[1] | 0        | GPIO4_C[1] | GRF_GPIO4C_IOMUX[3:2]=0x2   |
| trace_data[2] | 0        | GPIO4_C[2] | GRF_GPIO4C_IOMUX[5:4]=0x2   |
| trace_data[3] | 0        | GPIO4_C[3] | GRF_GPIO4C_IOMUX[7:6]=0x2   |
| trace_data[4] | 0        | GPIO4_C[4] | GRF_GPIO4C_IOMUX[9:8]=0x2   |
| trace_data[5] | 0        | GPIO4_C[5] | GRF_GPIO4C_IOMUX[11:10]=0x2 |
| trace_data[6] | 0        | GPIO4_C[6] | GRF_GPIO4C_IOMUX[13:12]=0x2 |
| trace_data[7] | 0        | GPIO4_C[7] | GRF_GPIO4C_IOMUX[15:14]=0x2 |



| trace_data[8]  | 0 | GPIO4_D[0] | GRF_GPIO4D_IOMUX[1:0]=0x2   |
|----------------|---|------------|-----------------------------|
| trace_data[9]  | 0 | GPIO4_D[1] | GRF_GPIO4D_IOMUX[3:2]=0x2   |
| trace_data[10] | 0 | GPIO4_D[2] | GRF_GPIO4D_IOMUX[5:4]=0x2   |
| trace_data[11] | 0 | GPIO4_D[3] | GRF_GPIO4D_IOMUX[7:6]=0x2   |
| trace_data[12] | 0 | GPIO4_D[4] | GRF_GPIO4D_IOMUX[9:8]=0x2   |
| trace_data[13] | 0 | GPIO4_D[5] | GRF_GPIO4D_IOMUX[11:10]=0x2 |
| trace_data[14] | 0 | GPIO6_D[6] | GRF_GPIO4D_IOMUX[13:12]=0x2 |
| trace_data[15] | 0 | GPIO6_D[7] | GRF_GPIO4D_IOMUX[15:14]=0x2 |
| trace_clk      | 0 | GPIO0_C[6] | GRF_GPIO0C_IOMUX[13:12]=0x1 |
| trace_ctl      | 0 | GPIO0_C[7] | GRF_GPIO0C_IOMUX[15:14]=0x1 |

# **Chapter 7 GRF (General Register Files)**

### 7.1 Overview

The general register file will be used to do static set by software, which is composed of many registers for system control.

# 7.2 Function Description

The function of general register file is:

- ◆ IOMUX control
- ◆ Control the state of gpio in power-down mode
- ♦ GPIO PAD pulldown and pullup control
- Used for common system control
- Used to record the system state

# 7.3 Register description.

#### 7.3.1 Register Summary

| Name           | Offset | Size | Reset<br>Value | Description                           |
|----------------|--------|------|----------------|---------------------------------------|
| GRF_GPIO0L_DIR | 0x0000 | W    | 0×00000000     | GPIO0A / GPIO0B output enable control |
| GRF_GPIO0H_DIR | 0x0004 | W    | 0x00000000     | GPIO0C / GPIO0D output enable control |
| GRF_GPIO1L_DIR | 0x0008 | w    | 0x00000000     | GPIO1A / GPIO0B output enable control |
| GRF_GPIO1H_DIR | 0x000c | W    | 0x00000000     | GPIO1C / GPIO1D output enable control |
| GRF_GPIO2L_DIR | 0x0010 | W    | 0x00000000     | GPIO2A / GPIO2B output enable control |
| GRF_GPIO2H_DIR | 0x0014 | W    | 0x00000000     | GPIO2C / GPIO2D output enable control |
| GRF_GPIO3L_DIR | 0x0018 | W    | 0x00000000     | GPIO3A / GPIO3B output enable control |
| GRF_GPIO3H_DIR | 0x001c | W    | 0x00000000     | GPIO3C / GPIO3D output enable control |
| GRF_GPIO4L_DIR | 0x0020 | W    | 0x00000000     | GPIO4A / GPIO4B output enable control |
| GRF_GPIO4H_DIR | 0x0024 | W    | 0x00000000     | GPIO4C / GPIO4D output enable control |
| GRF_GPIO6L_DIR | 0x0030 | W    | 0x00000000     | GPIO6A / GPIO6B output enable control |
| GRF_GPIO0L_DO  | 0x0038 | W    | 0x00000000     | GPIO0A / GPIO0B output control        |
| GRF_GPIO0H_DO  | 0x003c | W    | 0x00000000     | GPIOOC / GPIOOD output control        |



| Name             | Offset | Size | Reset<br>Value | Description                    |
|------------------|--------|------|----------------|--------------------------------|
| GRF_GPIO1L_DO    | 0x0040 | W    | 0×00000000     | GPIO1A / GPIO1B output control |
| GRF_GPIO1H_DO    | 0x0044 | W    | 0×00000000     | GPIO1C / GPIO1D output control |
| GRF_GPIO2L_DO    | 0x0048 | W    | 0×00000000     | GPIO2A / GPIO2B output control |
| GRF_GPIO2H_DO    | 0x004c | W    | 0x00000000     | GPIO2C / GPIO2D output control |
| GRF_GPIO3L_DO    | 0x0050 | W    | 0x00000000     | GPIO3A / GPIO3B output control |
| GRF_GPIO3H_DO    | 0x0054 | W    | 0x00000000     | GPIO3C / GPIO3D output control |
| GRF_GPIO4L_DO    | 0x0058 | W    | 0x00000000     | GPIO4A / GPIO4B output control |
| GRF_GPIO4H_DO    | 0x005c | W    | 0x00000000     | GPIO4C / GPIO4D output control |
| GRF_GPIO6L_DO    | 0x0068 | W    | 0x0000000      | GPIO6A / GPIO6B output control |
| GRF_GPIOOL_EN    | 0x0070 | W    | 0×00000000     | GPIO0A / GPIO0B output enable  |
| GRF_GPIO0H_EN    | 0x0074 | w    | 0×00000000     | GPIOOC / GPIOOD output enable  |
| GRF_GPIO1L_EN    | 0x0078 | W    | 0x00000000     | GPIO1A / GPIO1B output enable  |
| GRF_GPIO1H_EN    | 0x007c | W    | 0x00000000     | GPIO1C / GPIO1D output enable  |
| GRF_GPIO2L_EN    | 0x0080 | W    | 0x00000000     | GPIO2A / GPIO2B output enable  |
| GRF_GPIO2H_EN    | 0x0084 | W    | 0x00000000     | GPIO2C / GPIO2D output enable  |
| GRF_GPIO3L_EN    | 0x0088 | W    | 0x00000000     | GPIO3A / GPIO3B output enable  |
| GRF_GPIO3H_EN    | 0x008c | W    | 0x00000000     | GPIO3C / GPIO3D output enable  |
| GRF_GPIO4L_EN    | 0x0090 | W    | 0x00000000     | GPIO4A / GPIO4B output enable  |
| GRF_GPIO4H_EN    | 0x0094 | W    | 0x00000000     | GPIO4C / GPIO4D output enable  |
| GRF_GPIO6L_EN    | 0x00a0 | W    | 0x00000000     | GPIO6A / GPIO6B output enable  |
| GRF_GPIO0A_IOMUX | 0x00a8 | W    | 0x00000000     | GPIO0A iomux control           |



| Name                 | Offset   | Size  | Reset<br>Value | Description          |
|----------------------|----------|-------|----------------|----------------------|
| GRF_GPIO0B_IOMUX     | 0x00ac   | W     | 0x0000000      | GPIO0B iomux control |
| GRF_GPIO0C_IOMUX     | 0x00b0   | W     | 0x00000000     | GPIO0C iomux control |
| GRF_GPIO0D_IOMUX     | 0x00b4   | W     | 0x0000000      | GPIO0D iomux control |
| GRF_GPIO1A_IOMUX     | 0x00b8   | W     | 0x00000000     | GPIO1A iomux control |
| GRF_GPIO1B_IOMUX     | 0x00bc   | W     | 0x00000000     | GPIO1B iomux control |
| GRF_GPIO1C_IOMUX     | 0x00c0   | W     | 0x00000000     | GPIO1C iomux control |
| GRF_GPIO1D_IOMUX     | 0x00c4   | W     | 0x00000000     | GPIO1D iomux control |
| GRF_GPIO2A_IOMUX     | 0x00c8   | W     | 0x0000000      | GPIO2A iomux control |
| GRF_GPIO2B_IOMUX     | 0x00cc   | W     | 0x0000000      | GPIO2B iomux control |
| GRF_GPIO2C_IOMUX     | 0x00d0   | W     | 0x00000000     | GPIO2C iomux control |
| GRF_GPIO2D_IOMUX     | 0x00d4   | W     | 0x00000000     | GPIO2D iomux control |
| GRF_GPIO3A_IOMUX     | 0x00d8   | W     | 0x00000000     | GPIO3A iomux control |
| GRF_GPIO3B_IOMUX     | 0x00dc   | W     | 0x00000000     | GPIO3B iomux control |
| GRF_GPIO3C_IOMUX     | 0x00e0   | W     | 0x00000000     | GPIO3C iomux control |
| GRF_GPIO3D_IOMUX     | 0x00e4   | W     | 0x00000000     | GPIO3D iomux control |
| GRF_GPIO4A_IOMUX     | 0x00e8   | W     | 0x0000000      | GPIO4A iomux control |
| GRF_GPIO4B_IOMUX     | 0x00ec   | W     | 0x0000000      | GPIO4B iomux control |
| GRF_GPIO4C_IOMUX     | 0x00f0   | W     | 0x0000000      | GPIO4C iomux control |
| GRF_GPIO4D_IOMUX     | 0x00f4   | W     | 0x00000000     | GPIO4D iomux control |
| GRF_GPIO6B_IOMUX     | 0x010c   | W     | 0x00000000     | GPIO6B iomux control |
| CDE CDIOOL DULL      | 0x0118   | W     | 0x00000000     | GPIO0A / GPIO0B pull |
| GRF_GPIO0L_PULL      | UXU118   |       | u              | up/down control      |
| CDE CDIOOH DUIL      | 0x011c   | e W   | 0x00000000     | GPIO0C / GPIO0D pull |
| GRF_GPIO0H_PULL      | OXOTIC   |       | 020000000      | up/down control      |
| CDE CDIO11 DIIII     | 0x0120   | ١٨/   | 0×00000000     | GPIO0A / GPIO0B pull |
| GRF_GPIO1L_PULL      | 0.0120   | VV    | 020000000      | up/down control      |
| GRF_GPIO1H_PULL      | 0x0124   | ۱۸/   | 0x00000000     | GPIO1C / GPIO1D pull |
| GIG _GI TOTTI_T OLL  | 070124   | VV    | 020000000      | up/down control      |
| GRF_GPIO2L_PULL      | 0x0128   | ۱۸/   | 0x00000000     | GPIO2A / GPIO2B pull |
| GIG _GI TOZE_I OLE   | 0.0120   | VV    | 020000000      | up/down control      |
| GRF GPIO2H PULL      | 0x012c   | ۱۸/   | 0x00000000     | GPIO2C / GPIO2D pull |
| GRI _GI 10211_1 OLL  | 070120   | VV    | 020000000      | up/down control      |
| GRF_GPIO3L_PULL      | 0x0130   | ۱۸/   | 0x00000000     | GPIO3A / GPIO3B pull |
| ON _ON 103E_1 0EE    | 0.0130   | • •   |                | up/down control      |
| GRF_GPIO3H_PULL      | 0x0134   | w     | 0x00000000     | GPIO3C / GPIO3D pull |
| 0111 _01 10311_1 022 | 0,0131   | , , O |                | up/down control      |
| GRF_GPIO4L_PULL      | 0x0138 W | w     | 0x00000000     | GPIO4A / GPIO4B pull |
|                      |          | "     |                | up/down control      |
| GRF_GPIO4H_PULL      | 0x013c W | w     | 0x00000000     | GPIO4C / GPIO4D pull |
|                      | 27.0100  |       |                | up/down control      |



| Name            | Offset | Size | Reset<br>Value | Description            |
|-----------------|--------|------|----------------|------------------------|
| GRF_GPIO6L_PULL | 0x0148 | ۱۸/  | 0x00000000     | GPIO6A / GPIO6B pull   |
| GRI_GFIOOL_FOLL | 070140 | VV   | 020000000      | up/down control        |
| GRF_SOC_CON0    | 0x0150 | W    | 0x00000008     | soc control register   |
| GRF_SOC_CON1    | 0x0154 | W    | 0x0000006      | soc control register   |
| GRF_SOC_CON2    | 0x0158 | W    | 0x0000000      | soc control register   |
| GRF_SOC_STATUS0 | 0x015c | W    | 0x00000000     | soc status register    |
| GRF_DMAC1_CON0  | 0x0160 | W    | 0x00000002     | DMAC1 control register |
| GRF_DMAC1_CON1  | 0x0164 | W    | 0x0000000      | DMAC1 control register |
| GRF_DMAC1_CON2  | 0x0168 | W    | 0x0000000      | DMAC1 control register |
| GRF_DMAC2_CON0  | 0x016c | W    | 0x0000fffe     | DMAC2 control register |
| GRF_DMAC2_CON1  | 0x0170 | W    | 0x00003fff     | DMAC2 control register |
| GRF_DMAC2_CON2  | 0x0174 | W    | 0x000000f      | DMAC2 control register |
| GRF_DMAC2_CON3  | 0x0178 | W    | 0x00003fff     | DMAC2 control register |
| GRF_UOC0_CON0   | 0x017c | W    | 0x0000c963     | otg0 control register  |
| GRF_UOC0_CON1   | 0x0180 | W    | 0x000016fb     | otg0 control register  |
| GRF_UOC0_CON2   | 0x0184 | W    | 0x00000408     | otg0 control register  |
| GRF_UOC1_CON0   | 0x0188 | W    | 0x0000c963     | otg1 control register  |
| GRF_UOC1_CON1   | 0x018c | W    | 0x000016fb     | otg1 control register  |
| GRF_UOC1_CON2   | 0x0190 | W    | 0x00000408     | otg1 control register  |
| GRF_UOC1_CON3   | 0x0194 | W    | 0x000001c      | otg1 control register  |
| GRF_DDRC_CON0   | 0x0198 | W    | 0x0000000      | DDRC control register  |
| GRF_DDRC_STAT   | 0x019c | W    | 0x0000000      | DDRC status            |
| GRF_OS_REG0     | 0x01c8 | W    | 0x0000000      | OS register            |
| GRF_OS_REG1     | 0x01cc | W    | 0x0000000      | OS register            |
| GRF_OS_REG2     | 0x01d0 | W    | 0x0000000      | OS register            |
| GRF_OS_REG3     | 0x01d4 | W    | 0×00000000     | OS register            |

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

#### 7.3.2 Detail Register Description

#### GRF\_GPIOOL\_DIR

Address: Operational Base + offset (0x0000)GPIO0A / GPIO0B output enable control

| Bit Attr Reset Value | Description |
|----------------------|-------------|
|----------------------|-------------|



| Bit   | Attr | Reset Value | Description                                     |
|-------|------|-------------|-------------------------------------------------|
|       |      |             | write_enable                                    |
|       |      |             | bit0~15 write enable                            |
|       |      |             | When bit 16=1, bit 0 can be written by          |
|       |      |             | software .                                      |
|       |      |             | When bit 16=0, bit 0 cannot be written by       |
|       |      |             | software;                                       |
|       |      |             | When bit 17=1, bit 1 can be written by          |
| 31:16 | WO   | 0x0000      | software .                                      |
|       |      |             | When bit 17=0, bit 1 cannot be written by       |
|       |      |             | software;                                       |
|       |      |             |                                                 |
|       |      |             | When bit 31=1, bit 15 can be written by         |
|       |      |             | software .                                      |
|       |      |             | When bit 31=0, bit 15 cannot be written by      |
|       |      |             | software;                                       |
|       |      |             | gpio0b_dir                                      |
|       |      |             | GPIO0B output enable control                    |
|       |      |             | When system is forced into power down mode,     |
| 15:8  | RW   | 0x00        | Values written to this register independently   |
| 13.0  |      | OXOO .      | control the direction of the corresponding data |
|       |      |             | bit in GPIO bits .                              |
|       |      |             | 0: Input (default)                              |
|       |      |             | 1:Output                                        |
|       |      |             | gpio0a_dir                                      |
|       |      | . ()        | GPIO0A output enable control                    |
|       |      |             | When system is forced into power down mode,     |
| 7:0 R | RW   | 0×00        | Values written to this register independently   |
|       |      |             | control the direction of the corresponding data |
|       | 11   |             | bit in GPIO bits .                              |
|       | CN   | 7           | 0: Input (default)                              |
|       |      |             | 1:Output                                        |

#### GRF\_GPIO0H\_DIR

Address: Operational Base + offset (0x0004)GPIOOC / GPIOOD output enable control

| Bit Attr Reset Value | Description |
|----------------------|-------------|
|----------------------|-------------|



| Bit    | Attr | Reset Value | Description                                     |
|--------|------|-------------|-------------------------------------------------|
|        |      |             | write_enable                                    |
|        |      |             | bit0~15 write enable                            |
|        |      |             | When bit 16=1, bit 0 can be written by          |
|        |      |             | software .                                      |
|        |      |             | When bit 16=0, bit 0 cannot be written by       |
|        |      |             | software;                                       |
|        |      |             | When bit 17=1, bit 1 can be written by          |
| 31:16  | WO   | 0x0000      | software .                                      |
|        |      |             | When bit 17=0, bit 1 cannot be written by       |
|        |      |             | software;                                       |
|        |      |             |                                                 |
|        |      |             | When bit 31=1, bit 15 can be written by         |
|        |      |             | software .                                      |
|        |      |             | When bit 31=0, bit 15 cannot be written by      |
|        |      |             | software;                                       |
|        |      |             | gpio0d_dir                                      |
|        |      |             | GPIO0D output enable control                    |
|        |      |             | When system is forced into power down mode,     |
| 15:8   | RW   | 0×00        | Values written to this register independently   |
| 13.6   | KVV  | 0000        | control the direction of the corresponding data |
|        |      |             | bit in GPIO bits .                              |
|        |      |             | 0: Input (default)                              |
|        |      |             | 1:Output                                        |
|        |      |             | gpio0c_dir                                      |
|        |      | . 40        | GPIOOC output enable control                    |
|        |      |             | When system is forced into power down mode,     |
| 7:0 RW | RW   | 0×00        | Values written to this register independently   |
| /.0    | KVV  | 0,00        | control the direction of the corresponding data |
|        |      |             | bit in GPIO bits .                              |
|        |      | 7           | 0: Input (default)                              |
|        |      |             | 1:Output                                        |

#### GRF\_GPIO1L\_DIR

Address: Operational Base + offset (0x0008) GPIO1A / GPIO0B output enable control

| Bit Attr Reset Value | Description |
|----------------------|-------------|
|----------------------|-------------|

0x0000

0x00

0x00

31:16

15:8

7:0

WO

RW



software.

software;

software.

software; gpio1b\_dir

bit in GPIO bits .0: Input (default)

bit in GPIO bits .0: Input (default)

1:Output gpio1a\_dir

1:Output

. . . . . .

When bit 17=1, bit 1 can be written by

When bit 17=0, bit 1 cannot be written by

When bit 31=1, bit 15 can be written by

GPIO1B output enable control

GPIO1A output enable control

When bit 31=0, bit 15 cannot be written by

When system is forced into power down mode, Values written to this register independently

control the direction of the corresponding data

When system is forced into power down mode, Values written to this register independently

control the direction of the corresponding data

### GRF\_GPIO1H\_DIR

RW

Address: Operational Base + offset (0x000c) GPIO1C / GPIO1D output enable control

| Bit Attr Reset Value | Description |
|----------------------|-------------|
|----------------------|-------------|



| Bit    | Attr | Reset Value | Description                                     |
|--------|------|-------------|-------------------------------------------------|
|        |      |             | write_enable                                    |
|        |      |             | bit0~15 write enable                            |
|        |      |             | When bit 16=1, bit 0 can be written by          |
|        |      |             | software .                                      |
|        |      |             | When bit 16=0, bit 0 cannot be written by       |
|        |      |             | software;                                       |
|        |      |             | When bit 17=1, bit 1 can be written by          |
| 31:16  | WO   | 0x0000      | software .                                      |
|        |      |             | When bit 17=0, bit 1 cannot be written by       |
|        |      |             | software;                                       |
|        |      |             |                                                 |
|        |      |             | When bit 31=1, bit 15 can be written by         |
|        |      |             | software .                                      |
|        |      |             | When bit 31=0, bit 15 cannot be written by      |
|        |      |             | software;                                       |
|        |      |             | gpio1d_dir                                      |
|        |      |             | GPIO1D output enable control                    |
|        |      |             | When system is forced into power down mode,     |
| 15:8   | RW   | 0×00        | Values written to this register independently   |
| 15.0   | IXVV | 0,000       | control the direction of the corresponding data |
|        |      |             | bit in GPIO bits .                              |
|        |      |             | 0: Input (default)                              |
|        |      |             | 1:Output                                        |
|        |      |             | gpio1c_dir                                      |
|        |      | . ()        | GPIO1C output enable control                    |
|        |      | 1,5         | When system is forced into power down mode,     |
| 7:0 RV | RW   | 0x00        | Values written to this register independently   |
|        |      |             | control the direction of the corresponding data |
|        | 11   |             | bit in GPIO bits .                              |
|        |      | 7           | 0: Input (default)                              |
|        |      |             | 1:Output                                        |

#### GRF\_GPIO2L\_DIR

Address: Operational Base + offset (0x0010)GPIO2A / GPIO2B output enable control

| Bit Attr Reset Value | Description |
|----------------------|-------------|
|----------------------|-------------|



#### GRF GPIO2H DIR

Address: Operational Base + offset (0x0014) GPIO2C / GPIO2D output enable control

| Bit   | Attr | Reset Value | Description                       |
|-------|------|-------------|-----------------------------------|
| 31:16 | WO   |             | write_enable bit0~15 write enable |



| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                      |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8 | RW   | 0x00        | gpio2d_dir GPIO2D output enable control When system is forced into power down mode, Values written to this register independently control the direction of the corresponding data bit in GPIO bits . 0: Input (default) 1:Output |
| 7:0  | RW   | 0×00        | gpio2c_dir GPIO2C output enable control When system is forced into power down mode, Values written to this register independently control the direction of the corresponding data bit in GPIO bits . 0: Input (default) 1:Output |

## GRF\_GPIO3L\_DIR

Address: Operational Base + offset (0x0018)GPIO3A / GPIO3B output enable control

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0×0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 cannot be written by software; |



| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                      |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8 | RW   | 0x00        | gpio3b_dir GPIO3B output enable control When system is forced into power down mode, Values written to this register independently                                                                                                |
|      |      |             | control the direction of the corresponding data bit in GPIO bits .  0: Input (default)  1:Output                                                                                                                                 |
| 7:0  | RW   | 0x00        | gpio3a_dir GPIO3A output enable control When system is forced into power down mode, Values written to this register independently control the direction of the corresponding data bit in GPIO bits . 0: Input (default) 1:Output |

## GRF\_GPIO3H\_DIR

Address: Operational Base + offset (0x001c) GPIO3C / GPIO3D output enable control

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0×0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 cannot be written by software; |



| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                      |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8 | RW   | 0x00        | gpio3d_dir GPIO3D output enable control When system is forced into power down mode, Values written to this register independently control the direction of the corresponding data bit in GPIO bits . 0: Input (default) 1:Output |
| 7:0  | RW   | 0x00        | gpio3c_dir GPIO3C output enable control When system is forced into power down mode, Values written to this register independently control the direction of the corresponding data bit in GPIO bits . 0: Input (default) 1:Output |

## GRF\_GPIO4L\_DIR

Address: Operational Base + offset (0x0020)GPIO0A / GPIO0B output enable control

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0×0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 cannot be written by software; |



| Bit  | Attr | Reset Value | Description                                     |
|------|------|-------------|-------------------------------------------------|
|      |      |             | gpio4b_dir                                      |
|      |      |             | GPIO4B output enable control                    |
|      |      |             | When system is forced into power down mode,     |
| 15:8 | RW   | 0×00        | Values written to this register independently   |
| 15.6 | IXVV | UXUU        | control the direction of the corresponding data |
|      |      |             | bit in GPIO bits .                              |
|      |      |             | 0: Input (default)                              |
|      |      |             | 1:Output                                        |
|      |      | 0×00        | gpio4a_dir                                      |
|      | RW   |             | GPIO4A output enable control                    |
|      |      |             | When system is forced into power down mode,     |
| 7:0  |      |             | Values written to this register independently   |
| 7.0  |      |             | control the direction of the corresponding data |
|      |      |             | bit in GPIO bits .                              |
|      |      |             | 0: Input (default)                              |
|      |      |             | 1:Output                                        |

## GRF\_GPIO4H\_DIR

Address: Operational Base + offset (0x0024)GPIO4C / GPIO4D output enable control

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0×0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 cannot be written by software; |



| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                      |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8 | RW   | 0×00        | gpio0d_dir GPIO0D output enable control When system is forced into power down mode, Values written to this register independently control the direction of the corresponding data bit in GPIO bits . 0: Input (default) 1:Output |
| 7:0  | RW   | 0×00        | gpio0c_dir GPIO0C output enable control When system is forced into power down mode, Values written to this register independently control the direction of the corresponding data bit in GPIO bits . 0: Input (default) 1:Output |

## GRF\_GPIO6L\_DIR

Address: Operational Base + offset (0x0030)GPIO6A / GPIO6B output enable control

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0×0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 cannot be written by software; |



| Bit   | Attr | Reset Value | Description                                                                                                                               |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8  | RW   | 0×00        | gpio6b_dir GPIO6B output enable control                                                                                                   |
|       |      |             | When system is forced into power down mode, Values written to this register independently control the direction of the corresponding data |
|       |      |             | bit in GPIO bits .                                                                                                                        |
|       |      |             | 0: Input (default)                                                                                                                        |
|       |      |             | 1:Output                                                                                                                                  |
|       | RW   | 0×00        | gpio6a_dir<br>GPIO6A output enable control                                                                                                |
|       |      |             | When system is forced into power down mode,                                                                                               |
| 7.0   |      |             | Values written to this register independently                                                                                             |
| 7:0 R |      |             | control the direction of the corresponding data                                                                                           |
|       |      |             | bit in GPIO bits .                                                                                                                        |
|       |      |             | 0: Input (default)                                                                                                                        |
|       |      |             | 1:Output                                                                                                                                  |

# GRF\_GPIO0L\_DO

Address: Operational Base + offset (0x0038)

GPIO0A / GPIO0B output control

| GFIOUA      | / GPIOU | B output control    |                                                                                                                                                                                                                                                                                     |
|-------------|---------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Attr    | Reset Value         | Description                                                                                                                                                                                                                                                                         |
| 31:16       | WO      | Reset Value  0x0000 | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software. When bit 31=1, bit 15 can be written by |
| <b>&gt;</b> |         |                     | software. When bit 31=0, bit 15 cannot be written by software;                                                                                                                                                                                                                      |
| 15:8        | RW      | 0×00                | gpio0b_do GPIO0B output control When system is forced into power down mode, Values written to this register are output on the I/O signals for GPIO if the corresponding data direction bits for GPIO are set to output mode.                                                        |



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                  |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | RW   | 0x00        | gpio0a_do GPIO0A output control When system is forced into power down mode, Values written to this register are output on the I/O signals for GPIO if the corresponding data direction bits for GPIO are set to output mode. |

#### GRF\_GPIO0H\_DO

Address: Operational Base + offset (0x003c)

GPIOOC / GPIOOD output control

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                   |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. |
| 15:8  | RW   | 0x00        | When bit 31=0, bit 15 cannot be written by software; gpio0d_do GPIO0D output control When system is forced into power down mode, Values written to this register are output on the I/O signals for GPIO if the corresponding data direction bits for GPIO are set to output                   |
| 7:0   | RW   | 0×00        | mode. gpio0c_do GPIO0C output control When system is forced into power down mode, Values written to this register are output on the I/O signals for GPIO if the corresponding data direction bits for GPIO are set to output mode.                                                            |



Address: Operational Base + offset (0x0040)

GPIO1A / GPIO1B output control

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                     |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0×0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=1, bit 15 can be written by software; |
| 15:8  | RW   | 0×00        | gpio1b_do GPIO1B output control When system is forced into power down mode, Values written to this register are output on the I/O signals for GPIO if the corresponding data direction bits for GPIO are set to output mode.                                                                                                                    |
| 7:0   | RW   | 0×00        | gpio1a_do GPIO1A output control When system is forced into power down mode, Values written to this register are output on the I/O signals for GPIO if the corresponding data direction bits for GPIO are set to output mode.                                                                                                                    |

### GRF\_GPIO1H\_DO

Address: Operational Base + offset (0x0044)

GPIO1C / GPIO1D output control

| Bit | Attr | <b>Reset Value</b> | Description |
|-----|------|--------------------|-------------|
|-----|------|--------------------|-------------|

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0×0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 cannot be written by software; |
| 15:8  | RW   | 0×00        | gpio1d_do GPIO1D output control When system is forced into power down mode, Values written to this register are output on the I/O signals for GPIO if the corresponding data direction bits for GPIO are set to output mode.                                                                                                                       |
| 7:0   | RW   | 0x00        | gpio1c_do GPIO1C output control When system is forced into power down mode, Values written to this register are output on the I/O signals for GPIO if the corresponding data direction bits for GPIO are set to output mode.                                                                                                                       |

### GRF\_GPIO2L\_DO

Address: Operational Base + offset (0x0048)

GPIO2A / GPIO2B output control

| Bit Attr Reset Value Description | Bit | Attr | Bit Attr Reset Value | Description |
|----------------------------------|-----|------|----------------------|-------------|
|----------------------------------|-----|------|----------------------|-------------|



| Bit   | Attr | Reset Value   | Description                                                                                     |
|-------|------|---------------|-------------------------------------------------------------------------------------------------|
|       |      |               | write_enable                                                                                    |
|       |      |               | bit0~15 write enable                                                                            |
|       |      |               | When bit 16=1, bit 0 can be written by software.                                                |
|       |      |               | When bit 16=0, bit 0 cannot be written by                                                       |
|       |      |               | software;                                                                                       |
|       |      |               | When bit 17=1, bit 1 can be written by                                                          |
| 31:16 | WO   | 0×0000        | software .                                                                                      |
|       |      |               | When bit 17=0, bit 1 cannot be written by                                                       |
|       |      |               | software;                                                                                       |
|       |      |               |                                                                                                 |
|       |      |               |                                                                                                 |
|       |      |               | X                                                                                               |
|       |      |               |                                                                                                 |
|       |      |               |                                                                                                 |
|       |      |               |                                                                                                 |
|       |      |               |                                                                                                 |
| 15:8  | RW   | 0×00          | Values written to this register are output on                                                   |
|       |      |               | the I/O signals for GPIO if the corresponding                                                   |
|       |      |               | data direction bits for GPIO are set to output                                                  |
|       |      |               | mode.                                                                                           |
|       |      |               | gpio2a_do                                                                                       |
|       |      |               |                                                                                                 |
| 7.0   | DW   |               |                                                                                                 |
| /:0   | RW   | 0x00          |                                                                                                 |
|       |      |               |                                                                                                 |
|       |      | $C_{\lambda}$ | ·                                                                                               |
| 7:0   | RW   | 0x00          | the I/O signals for GPIO if the corresponding data direction bits for GPIO are set to outprode. |

### GRF\_GPIO2H\_DO

Address: Operational Base + offset (0x004c)

GPIO2C / GPIO2D output control

| Bit Attr Reset Value Descripti | on |
|--------------------------------|----|
|--------------------------------|----|



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                              |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0×0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 cannot be written by |
| 15:8  | RW   | 0×00        | software;  gpio2d_do  GPIO2D output control  When system is forced into power down mode,  Values written to this register are output on the I/O signals for GPIO if the corresponding data direction bits for GPIO are set to output mode.                                                                                               |
| 7:0   | RW   | 0x00        | gpio2c_do GPIO2C output control When system is forced into power down mode, Values written to this register are output on the I/O signals for GPIO if the corresponding data direction bits for GPIO are set to output mode.                                                                                                             |

### GRF\_GPIO3L\_DO

Address: Operational Base + offset (0x0050)

GPIO3A / GPIO3B output control

| Bit Attr Reset Value Description | Bit | Attr | Bit Attr Reset Value | Description |
|----------------------------------|-----|------|----------------------|-------------|
|----------------------------------|-----|------|----------------------|-------------|



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                   |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0x0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. |
| 15:8  | RW   | 0x00        | When bit 31=0, bit 15 cannot be written by software;  gpio3b_do GPIO3B output control When system is forced into power down mode, Values written to this register are output on the I/O signals for GPIO if the corresponding data direction bits for GPIO are set to output mode.            |
| 7:0   | RW   | 0x00        | gpio3a_do GPIO3A output control When system is forced into power down mode, Values written to this register are output on the I/O signals for GPIO if the corresponding data direction bits for GPIO are set to output mode.                                                                  |

### GRF\_GPIO3H\_DO

Address: Operational Base + offset (0x0054)

GPIO3C / GPIO3D output control

| Bit Attr Reset Value Description |
|----------------------------------|
|----------------------------------|



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                              |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0x0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 cannot be written by |
| 15:8  | RW   | 0x00        | software; gpio3d_do GPIO3D output control When system is forced into power down mode, Values written to this register are output on the I/O signals for GPIO if the corresponding data direction bits for GPIO are set to output mode.                                                                                                   |
| 7:0   | RW   | 0×00        | gpio3c_do GPIO3C output control When system is forced into power down mode, Values written to this register are output on the I/O signals for GPIO if the corresponding data direction bits for GPIO are set to output mode.                                                                                                             |

## GRF\_GPIO4L\_DO

Address: Operational Base + offset (0x0058)

GPIO4A / GPIO4B output control

| Bit Attr Reset Value Description |  |
|----------------------------------|--|
|----------------------------------|--|



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                              |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 cannot be written by |
| 15:8  | RW   | 0×00        | software; gpio4b_do GPIO4B output control When system is forced into power down mode, Values written to this register are output on the I/O signals for GPIO if the corresponding data direction bits for GPIO are set to output mode.                                                                                                   |
| 7:0   | RW   | 0×00        | gpio4a_do GPIO4A output control When system is forced into power down mode, Values written to this register are output on the I/O signals for GPIO if the corresponding data direction bits for GPIO are set to output mode.                                                                                                             |

### GRF\_GPIO4H\_DO

Address: Operational Base + offset (0x005c)

GPIO4C / GPIO4D output control

| Bit Attr Reset Value Descripti | on |
|--------------------------------|----|
|--------------------------------|----|



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                              |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 cannot be written by |
| 15:8  | RW   | 0×00        | software;  gpio4d_do  GPIO4D output control  When system is forced into power down mode,  Values written to this register are output on the I/O signals for GPIO if the corresponding data direction bits for GPIO are set to output mode.                                                                                               |
| 7:0   | RW   | 0x00        | gpio4c_do GPIO4C output control When system is forced into power down mode, Values written to this register are output on the I/O signals for GPIO if the corresponding data direction bits for GPIO are set to output mode.                                                                                                             |

## GRF\_GPIO6L\_DO

Address: Operational Base + offset (0x0068)

GPIO6A / GPIO6B output control

| Bit Attr Reset Value Description | Bit | Attr | Bit Attr Reset Value | Description |
|----------------------------------|-----|------|----------------------|-------------|
|----------------------------------|-----|------|----------------------|-------------|



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                              |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 cannot be written by |
| 15:8  | RW   | 0×00        | software;  gpio6b_do  GPIO6B output control  When system is forced into power down mode,  Values written to this register are output on the I/O signals for GPIO if the corresponding data direction bits for GPIO are set to output mode.                                                                                               |
| 7:0   | RW   | 0x00        | gpio6a_do GPIO6A output control When system is forced into power down mode, Values written to this register are output on the I/O signals for GPIO if the corresponding data direction bits for GPIO are set to output mode.                                                                                                             |

### GRF\_GPIO0L\_EN

Address: Operational Base + offset (0x0070)

GPIO0A / GPIO0B output enable

|  | Bit | Attr | Reset Value | Description |
|--|-----|------|-------------|-------------|
|--|-----|------|-------------|-------------|



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                     |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=1, bit 15 can be written by software; |
| 15:8  | RW   | 0×00        | gpio0b_en GPIO0B output enable When system is forced into power down mode, Values written to this register will enable whether GPIO status will be controlled by GRF register                                                                                                                                                                   |
| 7:0   | RW   | 0x00        | gpio0a_en GPIO0A output enable When system is forced into power down mode, Values written to this register will enable whether GPIO status will be controlled by GRF register                                                                                                                                                                   |

# GRF\_GPIO0H\_EN

Address: Operational Base + offset (0x0074)

GPIOOC / GPIOOD output enable

| Bit A | Attr Reset Value | Description |
|-------|------------------|-------------|
|-------|------------------|-------------|



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                     |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=1, bit 15 can be written by software; |
| 15:8  | RW   | 0×00        | gpio0d_en GPIO0D output enable When system is forced into power down mode, Values written to this register will enable whether GPIO status will be controlled by GRF register                                                                                                                                                                   |
| 7:0   | RW   | 0x00        | gpio0c_en GPIO0C output enable When system is forced into power down mode, Values written to this register will enable whether GPIO status will be controlled by GRF register                                                                                                                                                                   |

## GRF\_GPIO1L\_EN

Address: Operational Base + offset (0x0078) GPIO1A / GPIO1B output enable

| Bit | Attr | Reset Value | Description |  |  |  |
|-----|------|-------------|-------------|--|--|--|



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                     |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=1, bit 15 can be written by software; |
| 15:8  | RW   | 0×00        | gpio1b_en GPIO1B output enable When system is forced into power down mode, Values written to this register will enable whether GPIO status will be controlled by GRF register                                                                                                                                                                   |
| 7:0   | RW   | 0x00        | gpio1a_en GPIO1A output enable When system is forced into power down mode, Values written to this register will enable whether GPIO status will be controlled by GRF register                                                                                                                                                                   |

# GRF\_GPIO1H\_EN

Address: Operational Base + offset (0x007c)

GPIO1C / GPIO1D output enable

| D.11 | <b>N</b> | D 11/1      |             |
|------|----------|-------------|-------------|
| Bit  | Attr     | Reset Value | Description |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                     |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=1, bit 15 can be written by software; |
| 15:8  | RW   | 0×00        | gpio1d_en GPIO1D output enable When system is forced into power down mode, Values written to this register will enable whether GPIO status will be controlled by GRF register                                                                                                                                                                   |
| 7:0   | RW   | 0x00        | gpio1c_en GPIO1C output enable When system is forced into power down mode, Values written to this register will enable whether GPIO status will be controlled by GRF register                                                                                                                                                                   |

# GRF\_GPIO2L\_EN

Address: Operational Base + offset (0x0080)

GPIO2A / GPIO2B output enable

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
|-----|------|-------------|-------------|



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 cannot be written by software; |
| 15:8  | RW   | 0×00        | gpio2b_en GPIO2B output enable When system is forced into power down mode, Values written to this register will enable whether GPIO status will be controlled by GRF register                                                                                                                                                                      |
| 7:0   | RW   | 0x00        | gpio2a_en GPIO2A output enable When system is forced into power down mode, Values written to this register will enable whether GPIO status will be controlled by GRF register                                                                                                                                                                      |

# GRF\_GPIO2H\_EN

Address: Operational Base + offset (0x0084)

GPIO2C / GPIO2D output enable

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
|-----|------|-------------|-------------|



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                     |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=1, bit 15 can be written by software; |
| 15:8  | RW   | 0×00        | gpio2d_en GPIO2D output enable When system is forced into power down mode, Values written to this register will enable whether GPIO status will be controlled by GRF register                                                                                                                                                                   |
| 7:0   | RW   | 0×00        | gpio2c_en GPIO2C output enable When system is forced into power down mode, Values written to this register will enable whether GPIO status will be controlled by GRF register                                                                                                                                                                   |

# GRF\_GPIO3L\_EN

Address: Operational Base + offset (0x0088)

GPIO3A / GPIO3B output enable

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
|-----|------|-------------|-------------|



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                     |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0×0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=1, bit 15 can be written by software; |
| 15:8  | RW   | 0×00        | gpio3b_en GPIO3B output enable When system is forced into power down mode, Values written to this register will enable whether GPIO status will be controlled by GRF register                                                                                                                                                                   |
| 7:0   | RW   | 0x00        | gpio3a_en GPIO3A output enable When system is forced into power down mode, Values written to this register will enable whether GPIO status will be controlled by GRF register                                                                                                                                                                   |

# GRF\_GPIO3H\_EN

Address: Operational Base + offset (0x008c) GPIO3C / GPIO3D output enable

| _ |     |      |             |             |
|---|-----|------|-------------|-------------|
| Ī | Bit | Attr | Reset Value | Description |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 cannot be written by |
| 15:8  | RW   | 0×00        | software; gpio3d_en GPIO3D output enable When system is forced into power down mode, Values written to this register will enable whether GPIO status will be controlled by GRF register                                                                                                                                                                                                    |
| 7:0   | RW   | 0x00        | gpio3c_en GPIO3C output enable When system is forced into power down mode, Values written to this register will enable whether GPIO status will be controlled by GRF register                                                                                                                                                                                                              |

# GRF\_GPIO4L\_EN

Address: Operational Base + offset (0x0090)

GPIO4A / GPIO4B output enable

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
|-----|------|-------------|-------------|



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                         |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by |
| 15:8  | RW   | 0x00        | software .  When bit 31=0, bit 15 cannot be written by software;  gpio4b_en  GPIO4B output enable  When system is forced into power down mode, Values written to this register will enable whether GPIO status will be controlled by GRF register                                   |
| 7:0   | RW   | 0x00        | gpio4a_en GPIO4A output enable When system is forced into power down mode, Values written to this register will enable whether GPIO status will be controlled by GRF register                                                                                                       |

# GRF\_GPIO4H\_EN

Address: Operational Base + offset (0x0094) GPIO4C / GPIO4D output enable

| Bit Attr | Reset Value | Description |  |  |
|----------|-------------|-------------|--|--|



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                     |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0×0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=1, bit 15 can be written by software; |
| 15:8  | RW   | 0×00        | gpio4d_en GPIO4D output enable When system is forced into power down mode, Values written to this register will enable whether GPIO status will be controlled by GRF register                                                                                                                                                                   |
| 7:0   | RW   | 0x00        | gpio4c_en GPIO4C output enable When system is forced into power down mode, Values written to this register will enable whether GPIO status will be controlled by GRF register                                                                                                                                                                   |

# GRF\_GPIO6L\_EN

Address: Operational Base + offset (0x00a0)

GPIO6A / GPIO6B output enable

| Bit Attr Reset Value | Description |
|----------------------|-------------|
|----------------------|-------------|



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0×0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 cannot be written by software; |
| 15:8  | RW   | 0x00        | gpio6b_en GPIO6B output enable When system is forced into power down mode, Values written to this register will enable whether GPIO status will be controlled by GRF register                                                                                                                                                                      |
| 7:0   | RW   | 0×00        | gpio6a_en GPIO6A output enable When system is forced into power down mode, Values written to this register will enable whether GPIO status will be controlled by GRF register                                                                                                                                                                      |

# GRF\_GPIO0A\_IOMUX

Address: Operational Base + offset (0x00a8) GPIO0A iomux control

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|



| Bit   | Attr | Reset Value  | Description                                |
|-------|------|--------------|--------------------------------------------|
|       |      |              | write_enable                               |
|       |      |              | bit0~15 write enable                       |
|       |      |              | When bit 16=1, bit 0 can be written by     |
|       |      |              | software .                                 |
|       |      |              | When bit 16=0, bit 0 cannot be written by  |
|       |      |              | software;                                  |
|       |      |              | When bit 17=1, bit 1 can be written by     |
| 31:16 | WO   | 0x0000       | software .                                 |
|       |      |              | When bit 17=0, bit 1 cannot be written by  |
|       |      |              | software;                                  |
|       |      |              |                                            |
|       |      |              | When bit 31=1, bit 15 can be written by    |
|       |      |              | software .                                 |
|       |      |              | When bit 31=0, bit 15 cannot be written by |
|       |      |              | software;                                  |
| 15    | RO   | 0x0          | reserved                                   |
|       |      |              | gpio0a7_sel                                |
| 14    | RW   | 0×0          | GPIO0A[7] iomux select                     |
|       |      | OXO .        | 1: i2s 8ch sdi                             |
|       |      |              | 0: gpio                                    |
| 13    | RO   | 0x0 reserved |                                            |
|       |      |              | gpio0a6_sel                                |
| 12    | RW   | 0x0          | GPIO0A[6] iomux select                     |
|       |      | OXO .        | 1: host_drv_vbus                           |
| 4.4   |      |              | 0: gpio                                    |
| 11    | RO   | 0x0          | reserved                                   |
|       | RW.  |              | gpio0a5_sel                                |
| 10    |      | 0×0          | GPIO0A[5] iomux select                     |
|       |      |              | 1: otg_drv_vbus                            |
|       |      |              | 0: gpio                                    |
| 9     | RO   | 0x0          | reserved                                   |
| (2)   |      |              | gpio0a4_sel                                |
| 8     | RW   | 0x0          | GPIO0A[4] iomux select                     |
| ,     |      |              | 1: pwm1                                    |
| _     |      | 0: gpio      |                                            |
| 7     | RO   | 0x0          | reserved                                   |
|       |      |              | gpio0a3_sel                                |
| 6     | RW   | 0x0          | GPIO0A[3] iomux select                     |
|       |      |              | 1: pwm0                                    |
| _     |      |              | 0: gpio                                    |
| 5     | RO   | 0x0          | reserved                                   |



| Bit | Attr | Reset Value | Description            |
|-----|------|-------------|------------------------|
|     |      |             | gpio0a2_sel            |
| 4   | RW   | 0×0         | GPIO0A[2] iomux select |
| 4   | KVV  | UXU         | 1: hdmi_i2c_sda        |
|     |      |             | 0: gpio                |
| 3   | RO   | 0x0         | reserved               |
|     |      | 00          | gpio0a1_sel            |
| 2   | RW   |             | GPIO0A[1] iomux select |
| 2   | KVV  | 0×0         | 1: hdmi_i2c_scl        |
|     |      |             | 0: gpio                |
| 1   | RO   | 0x0         | reserved               |
|     |      |             | gpio0a0_sel            |
|     | RW   | 0×0         | GPIO0A[0] iomux select |
| 0   |      |             | 1: hdmi_hot_plug_in    |
|     |      |             | 0: gpio                |

#### GRF\_GPIO0B\_IOMUX

Address: Operational Base + offset (0x00ac) GPIO0B iomux control

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 cannot be written by software; |
| 15    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                           |
| 14    | RW   | 0x0         | gpio0b7_sel GPIO0B[7] iomux select 1: i2s 8ch sdo3 0: gpio                                                                                                                                                                                                                                                                                         |
| 13    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                           |



| Bit | Attr   | Reset Value  | Description            |  |
|-----|--------|--------------|------------------------|--|
|     |        |              | gpio0b6_sel            |  |
| 12  | RW     | 0x0          | GPIO0B[6] iomux select |  |
| 12  | I NV   | UXU          | 1: i2s 8ch sdo2        |  |
|     |        |              | 0: gpio                |  |
| 11  | RO     | 0x0          | reserved               |  |
|     |        |              | gpio0b5_sel            |  |
| 10  | RW     | 0x0          | GPIO0B[5] iomux select |  |
| 10  | IX V V | 0.00         | 1: i2s 8ch sdo1        |  |
|     |        |              | 0: gpio                |  |
| 9   | RO     | 0x0          | reserved               |  |
|     |        |              | gpio0b4_sel            |  |
| 8   | RW     | 0x0          | GPIO0B[4] iomux select |  |
| 0   | IX V V | 0.00         | 1: i2s 8ch sdo0        |  |
|     |        |              | 0: gpio                |  |
| 7   | RO     | 0x0          | reserved               |  |
|     |        |              | gpio0b3_sel            |  |
| 6   | RW     | 0×0          | GPIO0B[3] iomux select |  |
|     | IX V V | 0.00         | 1: i2s 8ch lrck tx     |  |
|     |        |              | 0: gpio                |  |
| 5   | RO     | 0x0          | reserved               |  |
|     |        |              | gpio0b2_sel            |  |
| 4   | RW     | 0x0          | GPIO0B[2] iomux select |  |
|     | IXVV   |              | 1: i2s 8ch lrck_rx     |  |
|     |        |              | 0: gpio                |  |
| 3   | RO     | 0x0          | reserved               |  |
|     |        |              | gpio0b1_sel            |  |
| 2   | RW     | 0x0          | GPIO0B[1] iomux select |  |
| _   | IXVV   | O X O        | 1: i2s 8ch sclk        |  |
|     |        |              | 0: gpio                |  |
| 1   | RO     | 0x0 reserved |                        |  |
|     |        |              | gpio0b0_sel            |  |
| 0   | RW     | 0x0          | GPIO0B[0] iomux select |  |
|     | IV V V |              | 1: i2s_8ch_clk         |  |
| ,   |        |              | 0: gpio                |  |

## GRF\_GPIOOC\_IOMUX

Address: Operational Base + offset (0x00b0)

GPIO0C iomux control

| Bit Attr Reset Value Description |  |
|----------------------------------|--|
|----------------------------------|--|



| Bit   | Attr | Reset Value | Description                                |
|-------|------|-------------|--------------------------------------------|
|       |      |             | write_enable                               |
|       |      |             | bit0~15 write enable                       |
|       |      |             | When bit 16=1, bit 0 can be written by     |
|       |      |             | software .                                 |
|       |      |             | When bit 16=0, bit 0 cannot be written by  |
|       |      |             | software;                                  |
|       |      |             | When bit 17=1, bit 1 can be written by     |
| 31:16 | WO   | 0x0000      | software .                                 |
|       |      |             | When bit 17=0, bit 1 cannot be written by  |
|       |      |             | software;                                  |
|       |      |             |                                            |
|       |      |             | When bit 31=1, bit 15 can be written by    |
|       |      |             | software .                                 |
|       |      |             | When bit 31=0, bit 15 cannot be written by |
|       |      |             | software;                                  |
| 15    | RO   | 0x0         | reserved                                   |
|       |      |             | gpio0c7_sel                                |
|       |      |             | GPIO0C[7] iomux select                     |
| 14    | RW   | 0x0         | 01: trace ctl                              |
|       |      |             | 10: smc_addr3                              |
|       |      |             | 00: gpio                                   |
|       |      |             | gpio0c6_sel                                |
|       |      |             | GPIO0C[6] iomux select                     |
| 13:12 | RW   | 0x0         | 01: trace clk                              |
|       |      | . (         | 10: smc_addr2                              |
|       |      | 7.5         | 00: gpio                                   |
| 11    | RO   | 0x0         | reserved                                   |
|       | RW   | ()          | gpio0c5_sel                                |
| 10    |      | 0×0         | GPIO0C[5] iomux select                     |
|       |      | UXU         | 1: i2s1 2ch sdo                            |
|       |      |             | 0: gpio                                    |
| 9     | RO   | 0x0         | reserved                                   |
|       |      |             | gpio0c4_sel                                |
| 8     | RW   | 0×0         | GPIO0C[4] iomux select                     |
|       |      |             | 1: i2s1 2ch sdi                            |
|       |      |             | 0: gpio                                    |
| 7     | RO   | 0x0         | reserved                                   |
|       |      |             | gpio0c3_sel                                |
| 6     | RW   | 0x0         | GPIO0C[3] iomux select                     |
|       |      |             | 1: i2s1 2ch lrck tx                        |
|       |      |             | 0: gpio                                    |
| 5     | RO   | 0x0         | reserved                                   |



| Bit | Attr | Reset Value | Description            |
|-----|------|-------------|------------------------|
|     |      |             | gpio0c2_sel            |
| 4   | RW   | 0×0         | GPIO0C[2] iomux select |
| 4   | KVV  | UXU         | 1: i2s 8ch lrck_rx     |
|     |      |             | 0: gpio                |
| 3   | RO   | 0x0         | reserved               |
|     |      |             | gpio0c1_sel            |
| 2   | RW   | 0×0         | GPIO0C[1] iomux select |
| 2   | KVV  | UXU         | 1: i2s1 2ch sclk       |
|     |      |             | 0: gpio                |
| 1   | RO   | 0x0         | reserved               |
|     |      |             | gpio0c0_sel            |
|     | RW   | 0×0         | GPIO0C[0] iomux select |
| 0   | KVV  |             | 1: i2s1 2ch clk        |
|     |      |             | 0: gpio                |

GRF\_GPIOOD\_IOMUX
Address: Operational Base + offset (0x00b4)
GPIOOD iomux control

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 cannot be written by software; |
| 15    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                           |
| 14    | RW   | 0×0         | gpio0d7_sel GPIO0D[7] iomux select 1: pwm3 0: gpio                                                                                                                                                                                                                                                                                                 |
| 13    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                           |



| Bit   | Attr | Reset Value | Description            |
|-------|------|-------------|------------------------|
| 12    |      |             | gpio0d6_sel            |
|       | RW   | 0×0         | GPIO0D[6] iomux select |
| 12    | KVV  | 0.00        | 1: pwm2                |
|       |      |             | 0: gpio                |
|       |      |             | gpio0d5_sel            |
|       |      |             | GPIO0D[5] iomux select |
| 11:10 | RW   | 0x0         | 01: i2s2 2ch sdo       |
|       |      |             | 10: smc_addr1          |
|       |      |             | 00: gpio               |
|       |      |             | gpio0d4_sel            |
|       |      |             | GPIO0D[4] iomux select |
| 9:8   | RW   | 0x0         | 01: i2s1 2ch sdi       |
|       |      |             | 10: smc_addr0          |
|       |      |             | 00: gpio               |
|       |      |             | gpio0d3_sel            |
|       |      |             | GPIO0D[3] iomux select |
| 7:6   | RW   | 0×0         | 01: i2s1 2ch lrck tx   |
|       |      |             | 10: smc_adv_n          |
|       |      |             | 00: gpio               |
|       |      |             | gpio0d2_sel            |
|       |      |             | GPIO0D[2] iomux select |
| 5:4   | RW   | 0x0         | 01: i2s1 2ch lrck_rx   |
|       |      |             | 10: smc_oe_n           |
|       |      |             | 0: gpio                |
|       |      | • 1         | gpio0d1_sel            |
|       |      | 0×0         | GPIO0D[1] iomux select |
| 3:2   | RW   |             | 01: i2s2 2ch sclk      |
|       |      | C           | 10: smc_we_n           |
|       | 1    |             | 00: gpio               |
|       |      | Y           | gpio0d0_sel            |
|       |      |             | GPIO0D[0] iomux select |
| 1:0   | RW   | 0x0         | 01: i2s2 2ch clk       |
|       | +    |             | 10: smc_csn0           |
|       |      |             | 00: gpio               |

## GRF\_GPIO1A\_IOMUX

Address: Operational Base + offset (0x00b8)

GPIO1A iomux control

| Bit Attr Reset Value | Description |
|----------------------|-------------|
|----------------------|-------------|





| Bit | Attr  | Reset Value | Description            |
|-----|-------|-------------|------------------------|
|     |       |             | gpio1a2_sel            |
| 4   | RW    | 0×0         | GPIO1A[2] iomux select |
| 4   | IK VV | UXU         | 1: uart0_cts_n         |
|     |       |             | 0: gpio                |
| 3   | RO    | 0x0         | reserved               |
|     |       |             | gpio1a1_sel            |
| 2   | RW    | 0×0         | GPIO1A[1] iomux select |
| 2   | KVV   | UXU         | 1: uart0 sout          |
|     |       |             | 0: gpio                |
| 1   | RO    | 0x0         | reserved               |
|     |       |             | gpio1a0_sel            |
| 0   | RW    | 0x0         | GPIO1A[0] iomux select |
|     | KVV   |             | 1: uart0_sin           |
|     |       |             | 0: gpio                |

GRF\_GPIO1B\_IOMUX
Address: Operational Base + offset (0x00bc)
GPIO1B iomux control

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 cannot be written by software; |
| 15    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                           |
| 14    | RW   | 0×0         | gpio1b7_sel GPIO1B[7] iomux select 1: cif_data11 0: gpio                                                                                                                                                                                                                                                                                           |
| 13    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                           |



| Bit | Attr   | Reset Value                             | Description            |
|-----|--------|-----------------------------------------|------------------------|
|     |        |                                         | gpio1b6_sel            |
| 12  | RW     | 0×0                                     | GPIO1B[6] iomux select |
| 12  | KVV    | UXU                                     | 1: cif_data10          |
|     |        |                                         | 0: gpio                |
| 11  | RO     | 0x0                                     | reserved               |
|     |        |                                         | gpio1b5_sel            |
| 10  | RW     | 0×0                                     | GPIO1B[5] iomux select |
| 10  | KVV    | UXU                                     | 1: cif0_data1          |
|     |        |                                         | 0: gpio                |
| 9   | RO     | 0x0                                     | reserved               |
|     |        |                                         | gpio1b4_sel            |
| 8   | RW     | 0×0                                     | GPIO1B[4] iomux select |
| O   | IK V V | 0.00                                    | 1: cif0_data0          |
|     |        |                                         | 0: gpio                |
| 7   | RO     | 0x0                                     | reserved               |
|     |        |                                         | gpio1b3_sel            |
| 6   | RW     | 0×0                                     | GPIO1B[3] iomux select |
|     | KVV    | UXU                                     | 1: cif0_clkout         |
|     |        |                                         | 0: gpio                |
| 5   | RO     | 0x0                                     | reserved               |
|     |        |                                         | gpio1b2_sel            |
| 4   | RW     | 0×0                                     | GPIO1B[2] iomux select |
| -   | KVV    |                                         | 1: spdif_tx            |
|     |        |                                         | 0: gpio                |
| 3   | RO     | 0x0                                     | reserved               |
|     |        | \ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \ | gpio1b1_sel            |
| 2   | RW     | 0x0                                     | GPIO1B[1] iomux select |
| _   | IXVV   | OXO                                     | 1: uart2_sout          |
|     |        |                                         | 0: gpio                |
| 1   | RO     | 0x0                                     | reserved               |
|     |        |                                         | gpio1b0_sel            |
|     | RW     | 0x0                                     | GPIO1B[0] iomux select |
| 0   |        |                                         | 1: uart2_sin           |
| 7   |        |                                         | 0: gpio                |

## **GRF\_GPIO1C\_IOMUX**

Address: Operational Base + offset (0x00c0)

GPIO1C iomux control

| Bit Attr Reset Value Description |
|----------------------------------|
|----------------------------------|



| Bit   | Attr | Reset Value | Description                                |
|-------|------|-------------|--------------------------------------------|
|       |      |             | write_enable                               |
|       |      |             | bit0~15 write enable                       |
|       |      |             | When bit 16=1, bit 0 can be written by     |
|       |      |             | software .                                 |
|       |      |             | When bit 16=0, bit 0 cannot be written by  |
|       |      |             | software;                                  |
|       |      |             | When bit 17=1, bit 1 can be written by     |
| 31:16 | WO   | 0x0000      | software .                                 |
|       |      |             | When bit 17=0, bit 1 cannot be written by  |
|       |      |             | software;                                  |
|       |      |             | When bit 31=1, bit 15 can be written by    |
|       |      |             | software .                                 |
|       |      |             | When bit 31=0, bit 15 cannot be written by |
|       |      |             | software;                                  |
|       |      |             | gpio1c7_sel                                |
|       |      |             | GPIO1C[7] iomux select                     |
| 15:14 | RW   | 0x0         | 01: cif_data9                              |
|       |      |             | 10: rmii_rxd0                              |
|       |      |             | 00: gpio                                   |
|       |      |             | gpio1c6_sel                                |
|       |      |             | GPIO1C[6] iomux select                     |
| 13:12 | RW   | 0x0         | 01: cif_data8                              |
|       |      |             | 10: rmii_rxd1                              |
|       |      | . ()        | 00: gpio                                   |
|       |      |             | gpio1c5_sel                                |
|       |      |             | GPIO1C[5] iomux select                     |
| 11:10 | RW   | 0x0         | 01:cif_data7                               |
|       | 11   |             | 10:rmii_crs_dvalid                         |
|       |      |             | 00: gpio                                   |
|       |      |             | gpio1c4_sel                                |
|       | DW   | 00          | GPIO1C[4] iomux select                     |
| 9:8   | RW   | 0x0         | 01:cif_data6                               |
|       |      |             | 10:rmii_rx_err                             |
|       |      |             | 00: gpio                                   |
|       |      |             | gpio1c3_sel GPIO1C[3] iomux select         |
| 7:6   | RW   | 0×0         | 01: cif_data5                              |
| 7:6   | KVV  | 0x0         | 10: rmii_txd0                              |
|       |      |             |                                            |
|       |      |             | 00: gpio                                   |



| Bit | Attr | Reset Value | Description            |
|-----|------|-------------|------------------------|
|     |      |             | gpio0c2_sel            |
|     |      |             | GPIO0C[2] iomux select |
| 5:4 | RW   | 0x0         | 01: cif1_data4         |
|     |      |             | 10: rmii_txd1          |
|     |      |             | 00:gpio                |
|     |      |             | gpio1c1_sel            |
|     |      | 0×0         | GPIO1C[1] iomux select |
| 3:2 | RW   |             | 01: cif_data3          |
|     |      |             | 10: rmii_tx_en         |
|     |      |             | 00: gpio               |
|     |      |             | gpio1c0_sel            |
|     |      | 0×0         | GPIO1C[0] iomux select |
| 1:0 | RW   |             | 01: cif1_data2         |
|     |      |             | 10: rmii_clkout        |
|     |      |             | 11: rmii_clkin         |
|     |      |             | 00: gpio               |

# GRF\_GPIO1D\_IOMUX

Address: Operational Base + offset (0x00c4)

GPIO1D iomux control

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                     |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0×0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=1, bit 15 can be written by software; |
| 15    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                        |
| 14    | RW   | 0×0         | gpio1d7_sel GPIO1D[7] iomux select 1: cif1_clkout 0: gpio                                                                                                                                                                                                                                                                                       |
| 13    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                        |



| Bit | Attr | Reset Value    | Description            |
|-----|------|----------------|------------------------|
|     |      |                | gpio1d6_sel            |
| 12  | RW   | 0×0            | GPIO1D[6] iomux select |
| 12  | INV  | OXO            | 1: cif1_data11         |
|     |      |                | 0: gpio                |
| 11  | RO   | 0x0            | reserved               |
|     |      |                | gpio1d5_sel            |
| 10  | RW   | 0x0            | GPIO1D[5] iomux select |
|     |      | OXO            | 1: cif1_data10         |
|     |      |                | 0: gpio                |
| 9   | RO   | 0x0            | reserved               |
|     |      |                | gpio1d4_sel            |
| 8   | RW   | 0x0            | GPIO1D[4] iomux select |
|     |      | UXU            | 1: cif1_data1          |
|     |      |                | 0: gpio                |
| 7   | RO   | 0x0            | reserved               |
|     |      |                | gpio1d3_sel            |
| 6   | RW   | 0x0            | GPIO1D[3] iomux select |
|     |      | OXO .          | 1:cif1_data0           |
|     |      |                | 0: gpio                |
| 5   | RO   | 0x0            | reserved               |
|     |      |                | gpio1d2_sel            |
| 4   | RW   | 0×0            | GPIO1D[2] iomux select |
| •   |      |                | 1: cif1_clkin          |
|     |      |                | 0: gpio                |
|     |      | • \            | gpio1d1_sel            |
|     |      | 0×0            | GPIO1D[1] iomux select |
| 3:2 | RW   |                | 01: cif1_href          |
|     |      | $(C)^{\gamma}$ | 10: mii_mdclk          |
|     |      |                | 00: gpio               |
|     |      | Y .            | gpio1d0_sel            |
|     | RW   | 0x0            | GPIO1D[0] iomux select |
| 1:0 |      |                | 01: cif1_vsync         |
|     |      |                | 10: mii_md             |
|     |      |                | 00: gpio               |

## **GRF\_GPIO2A\_IOMUX**

Address: Operational Base + offset (0x00c8)

GPIO2A iomux control

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
|-----|------|-------------|-------------|





| Bit | Attr | Reset Value | Description            |
|-----|------|-------------|------------------------|
|     |      |             | gpio2a2_sel            |
|     |      |             | GPIO2A[2] iomux select |
| 5:4 | RW   | 0x0         | 01: lcdc_data2         |
|     |      |             | 10: smc_addr6          |
|     |      |             | 00: gpio               |
|     |      |             | gpio2a1_sel            |
|     |      | 0x0         | GPIO2A[1] iomux select |
| 3:2 | RW   |             | 01: lcdc1_data1        |
|     |      |             | 10:smc_addr5           |
|     |      |             | 00: gpio               |
|     |      |             | gpio2a0_sel            |
|     |      | 0x0         | GPIO2A[0] iomux select |
| 1:0 | RW   |             | 01: lcdc1_data0        |
|     |      |             | 10: smc_addr4          |
|     |      |             | 00: gpio               |

# GRF\_GPIO2B\_IOMUX

Address: Operational Base + offset (0x00cc)

GPIO2B iomux control

| GPIUZB | <u>iomux c</u> | OTILFOI     |                                                                                                |
|--------|----------------|-------------|------------------------------------------------------------------------------------------------|
| Bit    | Attr           | Reset Value | Description                                                                                    |
|        |                |             | write_enable<br>bit0~15 write enable                                                           |
|        |                |             | When bit 16=1, bit 0 can be written by software.                                               |
|        |                | . 0         | When bit 16=0, bit 0 cannot be written by software;                                            |
| 31:16  | wo             | 0×0000      | When bit 17=1, bit 1 can be written by software.                                               |
|        | N              |             | When bit 17=0, bit 1 cannot be written by software;                                            |
| R      | 5              |             | When bit 31=1, bit 15 can be written by software .  When bit 31=0, bit 15 cannot be written by |
|        |                |             | software;                                                                                      |
|        |                |             | gpio2b7_sel GPIO2B[7] iomux select 01: lcdc1_data15                                            |
| 15:14  | RW             | 0x0         | 10: smc_addr19                                                                                 |
|        |                |             | 11: hsadc_data7<br>00: gpio                                                                    |



| Bit   | Attr   | Reset Value | Description            |
|-------|--------|-------------|------------------------|
|       |        |             | gpio2b6_sel            |
|       |        |             | GPIO2B[6] iomux select |
| 13:12 | RW     | 0×0         | 01: lcdc1_data14       |
| 13.12 | KVV    | UXU         | 10:smc_addr18          |
|       |        |             | 11:ts_sync             |
|       |        |             | 00: gpio               |
|       |        |             | gpio2b5_sel            |
|       |        |             | GPIO2B[5] iomux select |
| 11:10 | RW     | 0×0         | 01:lcdc1_data13        |
| 11.10 | IXVV   | 0.00        | 10: smc_addr17         |
|       |        |             | 11:hsadc_data8         |
|       |        |             | 00: gpio               |
|       |        |             | gpio2b4_sel            |
|       |        |             | GPIO2B[4] iomux select |
| 9:8   | RW     | 0×0         | 01: lcdc1_data12       |
| 3.0   |        | OXO         | 10: smc_addr16         |
|       |        |             | 11: hsadc_data9        |
|       |        |             | 00: gpio               |
|       |        |             | gpio2b3_sel            |
|       |        |             | GPIO2B[3] iomux select |
| 7:6   | RW     | 0x0         | 01: lcdc1_data11       |
|       |        |             | 10: smc_addr15         |
|       |        |             | 00: gpio               |
|       |        |             | gpio2b2_sel            |
|       |        |             | GPIO2B[2] iomux select |
| 5:4   | RW     | 0x0         | 01: lcdc1_data10       |
|       |        |             | 10: smc_addr14         |
|       |        |             | 0: gpio                |
|       |        |             | gpio2b1_sel            |
|       | 5.6    |             | GPIO2B[1] iomux select |
| 3:2   | RW     | 0x0         | 01: lcdc1_data9        |
| 0     | $\cup$ |             | 10: smc_addr13         |
|       | V      |             | 00: gpio               |
| 7     |        |             | gpio2b0_sel            |
| 1.0   | DW     | 00          | GPIO2B[0] iomux select |
| 1:0   | RW     | 0x0         | 01: lcdc1_data8        |
|       |        |             | 10: smc_addr12         |
|       |        |             | 00: gpio               |

## GRF\_GPIO2C\_IOMUX

Address: Operational Base + offset (0x00d0)

GPIO2C iomux control

| Bit | Attr Reset Val | Description |
|-----|----------------|-------------|
|-----|----------------|-------------|



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0×0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 cannot be written by software; |
| 15:14 | RW   | 0×0         | gpio2c7_sel GPIO2C[7] iomux select 01: lcdc1_data23 10: spi1_csn1 11:hsadc_data4 00: gpio                                                                                                                                                                                                                                                          |
| 13:12 | RW   | 0x0         | gpio2c6_sel GPIO2C[6] iomux select 01: lcdc1_data22 10: spi1_rxd 11:hsadc_data3 00: gpio                                                                                                                                                                                                                                                           |
| 11:10 | RW   | 0x0         | gpio2c5_sel GPIO2C[5] iomux select 01: lcdc1_data21 10: spi1_txd 11:hsadc_data2 00: gpio                                                                                                                                                                                                                                                           |
| 9:8   | RW   | 0x0         | gpio2c4_sel GPIO2C[4] iomux select 01: lcdc1_data20 10:spi1_csn0 11:hsadc_data1 00: gpio                                                                                                                                                                                                                                                           |



#### GRF\_GPIO2D\_IOMUX

Address: Operational Base + offset (0x00d4)

GPIO2D iomux control

|     |        | 7 7 7       |             |
|-----|--------|-------------|-------------|
| Bit | Attr ( | Reset Value | Description |

11:hsadc\_clkout

00: gpio



| Bit   | Attr   | Reset Value | Description                                |
|-------|--------|-------------|--------------------------------------------|
|       |        |             | write_enable                               |
|       |        |             | bit0~15 write enable                       |
|       |        |             | When bit 16=1, bit 0 can be written by     |
|       |        |             | software .                                 |
|       |        |             | When bit 16=0, bit 0 cannot be written by  |
|       |        |             | software;                                  |
|       |        |             | When bit 17=1, bit 1 can be written by     |
| 31:16 | WO     | 0x0000      | software .                                 |
|       |        |             | When bit 17=0, bit 1 cannot be written by  |
|       |        |             | software;                                  |
|       |        |             |                                            |
|       |        |             | When bit 31=1, bit 15 can be written by    |
|       |        |             | software .                                 |
|       |        |             | When bit 31=0, bit 15 cannot be written by |
|       |        |             | software;                                  |
| 15    | RO     | 0x0         | reserved                                   |
|       |        |             | gpio2d7_sel                                |
| 14    | RW     | 0×0         | GPIO2D[7] iomux select                     |
| 14    | IX V V | 0.00        | 1: i2c1_scl                                |
|       |        |             | 0: gpio                                    |
| 13    | RO     | 0x0         | reserved                                   |
|       |        |             | gpio2d6_sel                                |
| 12    | RW     | 0×0         | GPIO2D[6] iomux select                     |
| 12    | IXVV   | 0.00        | 1: i2c1_sda                                |
|       |        | . ()        | 0: gpio                                    |
| 11    | RO     | 0x0         | reserved                                   |
|       |        |             | gpio2d5_sel                                |
| 10    | RW     | 0x0         | GPIO2D[5] iomux select                     |
|       | 1      | OXO         | 1: i2c0_scl                                |
|       |        | 7           | 0: gpio                                    |
| 9     | RO     | 0x0         | reserved                                   |
| 0     |        |             | gpio2d4_sel                                |
| 8     | RW     | 0×0         | GPIO2D[4] iomux select                     |
|       | 1      |             | 1:i2c0_sda                                 |
|       |        |             | 0: gpio                                    |
| 7     | RO     | 0x0         | reserved                                   |
|       |        |             | gpio2d3_sel                                |
| 6     | RW     | 0x0         | GPIO2D[3] iomux select                     |
|       |        |             | 1: lcdc1_vsync                             |
|       |        |             | 0: gpio                                    |
| 5     | RO     | 0x0         | reserved                                   |



| Bit | Attr | Reset Value | Description            |
|-----|------|-------------|------------------------|
|     |      |             | gpio2d2_sel            |
| 4   | RW   | 00          | GPIO2D[2] iomux select |
| 4   | KVV  | 0×0         | 1: lcdc1_hsync         |
|     |      |             | 0: gpio                |
|     |      |             | gpio2d1_sel            |
|     |      |             | GPIO2D[1] iomux select |
| 3:2 | RW   | 0x0         | 01: lcdc1_den          |
|     |      |             | 10: smc_csn1           |
|     |      |             | 00: gpio               |
| 1   | RO   | 0x0         | reserved               |
|     |      | W 0x0       | gpio2d0_sel            |
|     | DW   |             | GPIO2D[0] iomux select |
| 0   | KVV  |             | 1: lcdc1_dclk          |
|     |      |             | 0: gpio                |

## **GRF\_GPIO3A\_IOMUX**

Address: Operational Base + offset (0x00d8)

GPIO3A iomux control

| Bit      | Attr   | Reset Value | Description                                |
|----------|--------|-------------|--------------------------------------------|
|          |        |             | write_enable                               |
|          |        |             | bit0~15 write enable                       |
|          |        |             | When bit 16=1, bit 0 can be written by     |
|          |        |             | software .                                 |
|          |        |             | When bit 16=0, bit 0 cannot be written by  |
|          |        | • 1         | software;                                  |
|          |        |             | When bit 17=1, bit 1 can be written by     |
| 31:16    | WO     | 0x0000      | software .                                 |
|          |        |             | When bit 17=0, bit 1 cannot be written by  |
|          |        |             | software;                                  |
|          |        | 7           |                                            |
|          |        |             | When bit 31=1, bit 15 can be written by    |
| 0        |        |             | software .                                 |
|          | /      |             | When bit 31=0, bit 15 cannot be written by |
| <b>y</b> |        |             | software;                                  |
| 15       | RO     | 0x0         | reserved                                   |
|          |        |             | gpio3a7_sel                                |
| 14       | RW     | 0×0         | GPIO3A[7] iomux select                     |
| 1 7      | IX V V | UXU         | 1: sdmmc0_write_prt                        |
|          |        |             | 0: gpio                                    |
| 13       | RO     | 0x0         | reserved                                   |



| Bit      | Attr   | Reset Value | Description            |
|----------|--------|-------------|------------------------|
|          |        |             | gpio3a6_sel            |
| 12       | RW     | 0×0         | GPIO3A[6] iomux select |
| 12       | KVV    | UXU         | 1:sdmmc0_rstn_out      |
|          |        |             | 0: gpio                |
| 11       | RO     | 0x0         | reserved               |
|          |        |             | gpio3a5_sel            |
| 10       | DW     | 0.40        | GPIO3A[5] iomux select |
| 10       | RW     | 0x0         | 1: i2c4_scl            |
|          |        |             | 0: gpio                |
| 9        | RO     | 0x0         | reserved               |
|          |        |             | gpio3a4_sel            |
|          | DW     |             | GPIO3A[4] iomux select |
| 8        | RW     | 0x0         | 1: i2c4_sda            |
|          |        |             | 0: gpio                |
| 7        | RO     | 0x0         | reserved               |
|          |        |             | gpio3a3_sel            |
| _        | DW     | 0.40        | GPIO3A[3] iomux select |
| 6        | RW     | 0x0         | 1: i2c3_scl            |
|          |        |             | 0: gpio                |
| 5        | RO     | 0x0         | reserved               |
|          |        |             | gpio3a2_sel            |
| 4        | RW     | 0×0         | GPIO3A[2] iomux select |
| 7        | I V V  | W UXU       | 1: i2c3_sda            |
|          |        |             | 0: gpio                |
| 3        | RO     | 0x0         | reserved               |
|          |        |             | gpio3a1_sel            |
| 2        | RW     | 0x0         | GPIO3A[1] iomux select |
| _        | IK V V | UXU         | 1: i2c2_scl            |
|          | 1      |             | 0: gpio                |
| 1        | RO     | 0x0         | reserved               |
|          |        |             | gpio3a0_sel            |
| $\Omega$ | RW     | 0x0         | GPIO3A[0] iomux select |
| 0        | KW     | UXU         | 1: i2c2_sda            |
| 7        |        |             | 0: gpio                |

## GRF\_GPIO3B\_IOMUX

Address: Operational Base + offset (0x00dc)

GPIO3B iomux control



| Bit   | Attr | Reset Value | Description                                |
|-------|------|-------------|--------------------------------------------|
|       |      |             | write_enable                               |
|       |      |             | bit0~15 write enable                       |
|       |      |             | When bit 16=1, bit 0 can be written by     |
|       |      |             | software .                                 |
|       |      |             | When bit 16=0, bit 0 cannot be written by  |
|       |      |             | software;                                  |
|       |      |             | When bit 17=1, bit 1 can be written by     |
| 31:16 | WO   | 0x0000      | software .                                 |
|       |      |             | When bit 17=0, bit 1 cannot be written by  |
|       |      |             | software;                                  |
|       |      |             |                                            |
|       |      |             | When bit 31=1, bit 15 can be written by    |
|       |      |             | software .                                 |
|       |      |             | When bit 31=0, bit 15 cannot be written by |
|       |      |             | software;                                  |
| 15    | RO   | 0x0         | reserved                                   |
|       |      | gpio3b7_sel | gpio3b7_sel                                |
| 14    | RW   | 0×0         | GPIO3B[7] iomux select                     |
|       |      | 0.00        | 1: sdmmc0_write_prt                        |
|       |      |             | 0: gpio                                    |
| 13    | RO   | 0x0         | reserved                                   |
|       |      |             | gpio3b6_sel                                |
| 12    | RW   | 0×0         | GPIO3B[6] iomux select                     |
|       |      |             | 1: sdmmc0_detect_n                         |
|       |      | . 1         | 0: gpio                                    |
| 11    | RO   | 0x0         | reserved                                   |
|       |      |             | gpio3b5_sel                                |
| 10    | RW . | 0x0         | GPIO3B[5] iomux select                     |
|       |      |             | 1: sdmmc0_data3                            |
|       |      | 7           | 0: gpio                                    |
| 9     | RO   | 0x0         | reserved                                   |
| 0     |      |             | gpio3b4_sel                                |
| 8     | RW   | 0×0         | GPIO3B[4] iomux select                     |
|       |      | o x o       | 1: sdmmc0_data2                            |
|       |      |             | 0: gpio                                    |
| 7     | RO   | 0x0         | reserved                                   |
|       |      |             | gpio3b3_sel                                |
| 6     | RW   | 0×0         | GPIO3B[3] iomux select                     |
|       |      |             | 1: sdmmc0_data1                            |
|       |      |             | 0: gpio                                    |
| 5     | RO   | 0x0         | reserved                                   |



| Bit | Attr   | Reset Value | Description            |             |
|-----|--------|-------------|------------------------|-------------|
|     |        |             | gpio3b2_sel            |             |
| 4   | RW     | 0×0         | GPIO3B[2] iomux select |             |
| 7   | IK V V | OXO         | 1: sdmmc0_data0        |             |
|     |        |             | 0: gpio                |             |
| 3   | RO     | 0x0         | reserved               |             |
|     |        | 0×0         | gpio3b1_sel            |             |
| 2   | RW     |             | GPIO3B[1] iomux select |             |
| 2   | KVV    | UXU         | 1: sdmmc0_cmd          |             |
|     |        |             | 0: gpio                | <u> </u>    |
| 1   | RO     | 0x0         | reserved               |             |
|     |        |             | gpio3b0_sel            |             |
| 0   | DW     | RW 0x0      | GPIO3B[0] iomux select |             |
| 0   | KVV    |             | 1: sdmmc0_clkout       | <b>&gt;</b> |
|     |        |             | 0: gpio                | )           |

GRF\_GPIO3C\_IOMUX
Address: Operational Base + offset (0x00e0)
GPIO3C iomux control

| Bit      | Attr | Reset Value | Description                                |
|----------|------|-------------|--------------------------------------------|
|          |      |             | write_enable                               |
|          |      |             | bit0~15 write enable                       |
|          |      |             | When bit 16=1, bit 0 can be written by     |
|          |      |             | software .                                 |
|          |      |             | When bit 16=0, bit 0 cannot be written by  |
|          |      | • 0         | software;                                  |
|          |      |             | When bit 17=1, bit 1 can be written by     |
| 31:16    | WO   | 0x0000      | software .                                 |
|          |      |             | When bit 17=0, bit 1 cannot be written by  |
|          |      |             | software;                                  |
|          |      | 7           |                                            |
|          |      |             | When bit 31=1, bit 15 can be written by    |
| 0        |      |             | software .                                 |
|          | 1    |             | When bit 31=0, bit 15 cannot be written by |
| <i>y</i> |      |             | software;                                  |
| 15       | RO   | 0x0         | reserved                                   |
|          |      |             | gpio3c7_sel                                |
| 14       | RW   | 0×0         | GPIO3C[7] iomux select                     |
| 1.7      | IXVV |             | 1: sdmmc1_write_prt                        |
|          |      |             | 0: gpio                                    |
| 13       | RO   | 0x0         | reserved                                   |



| Bit | Attr | Reset Value | Description            |
|-----|------|-------------|------------------------|
|     |      |             | gpio3c6_sel            |
| 12  | RW   | 0×0         | GPIO3C[6] iomux select |
| 12  | KVV  | UXU         | 1: sdmmc1_detect_n     |
|     |      |             | 0: gpio                |
| 11  | RO   | 0x0         | reserved               |
|     |      |             | gpio3c5_sel            |
| 10  | RW   | 0×0         | GPIO3C[5] iomux select |
|     | KVV  | UXU         | 1: sdmmc1_clkout       |
|     |      |             | 0: gpio                |
| 9   | RO   | 0x0         | reserved               |
|     |      |             | gpio3c4_sel            |
| 8   | RW   | 0×0         | GPIO3C[4] iomux select |
|     | IXVV | UXU         | 1: sdmmc1_data3        |
|     |      |             | 0: gpio                |
| 7   | RO   | 0x0         | reserved               |
|     |      |             | gpio3c3_sel            |
| 6   | RW   | 0×0         | GPIO3C[3] iomux select |
|     | IXVV | 0.00        | 1: sdmmc1_data2        |
|     |      |             | 0: gpio                |
| 5   | RO   | 0x0         | reserved               |
|     |      |             | gpio3c2_sel            |
| 4   | RW   | 0x0         | GPIO3C[2] iomux select |
| 5   |      |             | 1: sdmmc1_data1        |
|     |      |             | 0: gpio                |
| 3   | RO   | 0x0         | reserved               |
|     |      |             | gpio3c1_sel            |
| 2   | RW   | 0x0         | GPIO3C[1] iomux select |
| _   |      | OXO .       | 1: sdmmc1_data0        |
|     |      |             | 0: gpio                |
| 1   | RO   | 0x0         | reserved               |
|     |      |             | gpio3c0_sel            |
| 0   | RW   | 0×0         | GPIO3C[0] iomux select |
|     | KVV  |             | 1: smmc1_cmd           |
|     |      |             | 0: gpio                |

## **GRF\_GPIO3D\_IOMUX**

Address: Operational Base + offset (0x00e4)

GPIO3D iomux control

| Bit | Attr | Reset Value | Description        |
|-----|------|-------------|--------------------|
|     |      |             | 2 00 0 1 P 11 0 11 |



| Bit                   | Attr | Reset Value | Description                                |
|-----------------------|------|-------------|--------------------------------------------|
|                       |      |             | write_enable                               |
|                       |      |             | bit0~15 write enable                       |
|                       |      |             | When bit 16=1, bit 0 can be written by     |
|                       |      |             | software .                                 |
|                       |      |             | When bit 16=0, bit 0 cannot be written by  |
|                       |      |             | software;                                  |
|                       |      |             | When bit 17=1, bit 1 can be written by     |
| 31:16                 | WO   | 0x0000      | software .                                 |
|                       |      |             | When bit 17=0, bit 1 cannot be written by  |
|                       |      |             | software;                                  |
|                       |      |             |                                            |
|                       |      |             | When bit 31=1, bit 15 can be written by    |
|                       |      |             | software .                                 |
|                       |      |             | When bit 31=0, bit 15 cannot be written by |
|                       |      |             | software;                                  |
|                       |      |             | gpio3d7_sel                                |
|                       |      |             | GPIO3D[7] iomux select                     |
| 15:14                 | RW   | 0x0         | 01: flash_dqs                              |
|                       |      |             | 10: emmc_clkout                            |
| 4.0                   | D.O. | 0.0         | 00: gpio                                   |
| 13                    | RO   | 0x0         | reserved                                   |
|                       |      |             | gpio3d6_sel                                |
| 15:14  13  12  11  10 | RW   | 0x0         | GPIO3D[6] iomux select                     |
|                       |      |             | 1: uart3_rts_n                             |
| 11                    | RO   | 0×0         | 0: gpio                                    |
| 11                    | KU   | UXU         | reserved                                   |
|                       |      |             | gpio3d5_sel<br>GPIO3D[5] iomux select      |
| 10                    | RW   | 0x0         | 1: uart3_cts_n                             |
|                       |      | 7           | 0: gpio                                    |
| 9                     | RO   | 0×0         | reserved                                   |
|                       | NO.  | OXO .       | gpio3d4_sel                                |
| 12                    |      |             | GPIO3D[4] iomux select                     |
| 8                     | RW   | 0x0         | 1: uart3_sout                              |
|                       |      |             | 0: gpio                                    |
| 7                     | RO   | 0x0         | reserved                                   |
|                       |      |             | gpio3d3_sel                                |
|                       |      |             | GPIO3D[3] iomux select                     |
| 6                     | RW   | 0x0         | 1:uart3_sin                                |
|                       |      |             | 0: gpio                                    |
| 5                     | RO   | 0x0         | reserved                                   |
|                       | 1    | 1           |                                            |



| Bit | Attr | Reset Value | Description            |
|-----|------|-------------|------------------------|
|     |      |             | gpio3d2_sel            |
| 4   | RW   | 0x0         | GPIO3D[2] iomux select |
| 4   | KVV  | UXU         | 1: sdmmc1_int_n        |
|     |      |             | 0: gpio                |
| 3   | RO   | 0x0         | reserved               |
|     |      | 00          | gpio3d1_sel            |
| 2   | RW   |             | GPIO3D[1] iomux select |
| 2   | KVV  | 0x0         | 1: sdmmc1_backend_pwr  |
|     |      |             | 0: gpio                |
| 1   | RO   | 0x0         | reserved               |
|     |      |             | gpio3d0_sel            |
|     | RW   | w 0x0       | GPIO3D[0] iomux select |
| 0   |      |             | 1: sdmmc1_pwr_en       |
|     |      |             | 0: gpio                |

#### **GRF\_GPIO4A\_IOMUX**

Address: Operational Base + offset (0x00e8)
GPIO4A iomux control

| GFIU4A | iomux c | OTILIOI     |                                                                                                                                         |
|--------|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit    | Attr    | Reset Value | Description                                                                                                                             |
|        |         | • •         | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software . When bit 16=0, bit 0 cannot be written by software; |
| 31:16  | wo      | 0×0000      | When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software;                                    |
| 3      |         |             | When bit 31=1, bit 15 can be written by software . When bit 31=0, bit 15 cannot be written by software;                                 |
| 15     | RO      | 0x0         | reserved                                                                                                                                |
| 14     | RW      | 0×0         | <ul><li>gpio4a7_sel</li><li>GPIO4A[7] iomux select</li><li>1: flash_data15</li><li>0: gpio</li></ul>                                    |
| 13     | RO      | 0x0         | reserved                                                                                                                                |



| Bit | Attr | Reset Value | Description            |
|-----|------|-------------|------------------------|
|     |      |             | gpio4a6_sel            |
| 12  | RW   | 0×0         | GPIO4A[6] iomux select |
| 12  | KVV  | UXU         | 1: flash_data14        |
|     |      |             | 0: gpio                |
| 11  | RO   | 0x0         | reserved               |
|     |      |             | gpio4a5_sel            |
| 10  | RW   | 0×0         | GPIO4A[5] iomux select |
| 10  | KVV  | UXU         | 1: flash_data13        |
|     |      |             | 0: gpio                |
| 9   | RO   | 0x0         | reserved               |
|     |      |             | gpio4a4_sel            |
| 8   | RW   | 0×0         | GPIO4A[4] iomux select |
| 0   | KVV  | UXU         | 1: flash_data12        |
|     |      |             | 0: gpio                |
| 7   | RO   | 0x0         | reserved               |
|     |      |             | gpio4a3_sel            |
| 6   | RW   | 0×0         | GPIO4A[3] iomux select |
| 0   | KVV  | UXU         | 1: flash_data11        |
|     |      |             | 0: gpio                |
| 5   | RO   | 0x0         | reserved               |
|     | RW   |             | gpio4a2_sel            |
| 4   |      | 0×0         | GPIO4A[2] iomux select |
| -   | IVV  |             | 1: flash_data10        |
|     |      |             | 0: gpio                |
| 3   | RO   | 0x0         | reserved               |
|     |      |             | gpio4a1_sel            |
| 2   | RW   | 0×0         | GPIO4A[1] iomux select |
| 2   | KVV  | OXO         | 1: flash_data9         |
|     | 1    |             | 0: gpio                |
| 1   | RO   | 0x0         | reserved               |
|     |      |             | gpio4a0_sel            |
|     | RW   | 0x0         | GPIO4A[0] iomux select |
| 0   | KW   |             | 1: flash_data8         |
| 7   |      |             | 0: gpio                |

## GRF\_GPIO4B\_IOMUX

Address: Operational Base + offset (0x00ec)

GPIO4B iomux control

| Bit Attr Reset Value Description |
|----------------------------------|
|----------------------------------|



| Bit   | Attr | Reset Value | Description                                |
|-------|------|-------------|--------------------------------------------|
|       |      |             | write_enable                               |
|       |      |             | bit0~15 write enable                       |
|       |      |             | When bit 16=1, bit 0 can be written by     |
|       |      |             | software .                                 |
|       |      |             | When bit 16=0, bit 0 cannot be written by  |
|       |      |             | software;                                  |
|       |      |             | When bit 17=1, bit 1 can be written by     |
| 31:16 | WO   | 0x0000      | software .                                 |
|       |      |             | When bit 17=0, bit 1 cannot be written by  |
|       |      |             | software;                                  |
|       |      |             |                                            |
|       |      |             | When bit 31=1, bit 15 can be written by    |
|       |      |             | software .                                 |
|       |      |             | When bit 31=0, bit 15 cannot be written by |
|       |      |             | software;                                  |
| 15    | RO   | 0x0         | reserved                                   |
|       |      |             | gpio4b7_sel                                |
| 14    | RW   | 0×0         | GPIO4B[7] iomux select                     |
| 14    | INVV | UXU         | 1: spi0_csn1                               |
|       |      |             | 0: gpio                                    |
| 13    | RO   | 0x0         | reserved                                   |
|       |      |             | gpio4b6_sel                                |
| 12    | RW   | 0×0         | GPIO4B[6] iomux select                     |
| 12    |      | UXU         | 1: flash_csn7                              |
|       |      |             | 0: gpio                                    |
| 11    | RO   | 0x0         | reserved                                   |
|       |      |             | gpio4b5_sel                                |
| 10    | RW.  | RW 0x0      | GPIO4B[5] iomux select                     |
|       |      | OKO         | 1: flash_csn6                              |
|       |      | 7           | 0: gpio                                    |
| 9     | RO   | 0x0         | reserved                                   |
| 0     |      |             | gpio4b4_sel                                |
| 8     | RW   | 0x0         | GPIO4B[4] iomux select                     |
|       | IVVV | OXO .       | 1: flash_csn5                              |
|       |      |             | 0: gpio                                    |
| 7     | RO   | 0x0         | reserved                                   |
|       |      |             | gpio4b3_sel                                |
| 6     | RW   | 0x0         | GPIO4B[3] iomux select                     |
|       |      |             | 1: flash_csn4                              |
|       |      |             | 0: gpio                                    |



| Bit | Attr | Reset Value | Description            |
|-----|------|-------------|------------------------|
|     |      |             | gpio4b2_sel            |
|     |      |             | GPIO4B[2] iomux select |
| 5:4 | RW   | 0x0         | 01: flash_csn3         |
|     |      |             | 10:emmc_rstn_out       |
|     |      |             | 00: gpio               |
|     |      |             | gpio4b1_sel            |
|     |      |             | GPIO4B[1] iomux select |
| 3:2 | RW   | 0x0         | 01: flash_csn2         |
|     |      |             | 10: emmc_cmd           |
|     |      |             | 00: gpio               |
| 1   | RO   | 0x0         | reserved               |
|     |      |             | gpio4b0_sel            |
|     | DW   | 0.40        | GPIO4B[0] iomux select |
| 0   | RW   | 0x0         | 1: flash_csn1          |
|     |      |             | 0: gpio                |

# GRF\_GPIO4C\_IOMUX

Address: Operational Base + offset (0x00f0)

GPIO4C iomux control

| Bit   | Attr   | Reset Value                           | Description                                |
|-------|--------|---------------------------------------|--------------------------------------------|
|       |        |                                       | write_enable                               |
|       |        |                                       | bit0~15 write enable                       |
|       |        |                                       | When bit 16=1, bit 0 can be written by     |
|       |        |                                       | software .                                 |
|       |        | • 0                                   | When bit 16=0, bit 0 cannot be written by  |
|       |        | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | software;                                  |
|       |        |                                       | When bit 17=1, bit 1 can be written by     |
| 31:16 | WO     | 0×0000                                | software .                                 |
|       |        |                                       | When bit 17=0, bit 1 cannot be written by  |
|       | 0.3    | ,                                     | software;                                  |
|       |        |                                       |                                            |
| 0     | $\cup$ |                                       | When bit 31=1, bit 15 can be written by    |
|       | /      |                                       | software.                                  |
|       |        |                                       | When bit 31=0, bit 15 cannot be written by |
|       |        |                                       | software;                                  |
|       |        |                                       | gpio4c7_sel                                |
| l     |        |                                       | GPIO4[7] iomux select                      |
| 15:14 | RW     | 0x0                                   | 01: smc_data7                              |
|       |        |                                       | 10: trace_data7                            |
|       |        |                                       | 00: gpio                                   |



| Bit   | Attr   | Reset Value | Description            |
|-------|--------|-------------|------------------------|
|       |        |             | gpio4c6_sel            |
|       |        |             | GPIO4C[6] iomux select |
| 13:12 | RW     | 0x0         | 01: smc_data6          |
|       |        |             | 10: trace_data6        |
|       |        |             | 00: gpio               |
|       |        |             | gpio4c5_sel            |
|       |        |             | GPIO4C[5] iomux select |
| 11:10 | RW     | 0x0         | 01:smc_data5           |
|       |        |             | 10:trace_data5         |
|       |        |             | 00:gpio                |
|       |        |             | gpio4c4_sel            |
|       |        |             | GPIO4C[4] iomux select |
| 9:8   | RW     | 0x0         | 01: smc_data4          |
|       |        |             | 10: trace_data4        |
|       |        |             | 00: gpio               |
|       |        |             | gpio4c3_sel            |
|       |        |             | GPIO4C[3] iomux select |
| 7:6   | RW     | 0x0         | 01: smc_data3          |
|       |        |             | 10: trace_data3        |
|       |        |             | 00: gpio               |
|       |        |             | gpio4c2_sel            |
|       |        |             | GPIO4C[2] iomux select |
| 5:4   | RW     | 0x0         | 01: smc_data2          |
|       |        |             | 10: trace_data2        |
|       |        | . 1         | 00: gpio               |
|       |        |             | gpio4c1_sel            |
|       |        |             | GPIO4C[1] iomux select |
| 3:2   | RW     | 0x0         | 01:smc_data1           |
|       | 1      |             | 10:trace_data1         |
|       |        | 7           | 00: gpio               |
|       |        |             | gpio4c0_sel            |
|       | $\cup$ |             | GPIO4C[0] iomux select |
| 1:0   | RW     | 0x0         | 01: smc_data0          |
| 7     |        |             | 10:trace_data0         |
|       |        |             | 00: gpio               |

# GRF\_GPIO4D\_IOMUX

Address: Operational Base + offset (0x00f4)

GPIO4D iomux control

| Bit Attr Reset Value | Description |
|----------------------|-------------|
|----------------------|-------------|



| Bit   | Attr  | Reset Value                             | Description                                |
|-------|-------|-----------------------------------------|--------------------------------------------|
|       |       |                                         | write_enable                               |
|       |       |                                         | bit0~15 write enable                       |
|       |       |                                         | When bit 16=1, bit 0 can be written by     |
|       |       |                                         | software .                                 |
|       |       |                                         | When bit 16=0, bit 0 cannot be written by  |
|       |       |                                         | software;                                  |
|       |       |                                         | When bit 17=1, bit 1 can be written by     |
| 31:16 | WO    | 0x0000                                  | software .                                 |
|       |       |                                         | When bit 17=0, bit 1 cannot be written by  |
|       |       |                                         | software;                                  |
|       |       |                                         |                                            |
|       |       |                                         | When bit 31=1, bit 15 can be written by    |
|       |       |                                         | software .                                 |
|       |       |                                         | When bit 31=0, bit 15 cannot be written by |
|       |       |                                         | software;                                  |
|       |       |                                         | gpio4d7_sel                                |
|       |       |                                         | GPIO4D[7] iomux select                     |
| 15:14 | RW    | 0x0                                     | 10: smc_data15                             |
|       |       |                                         | 01: trace_data15                           |
|       |       |                                         | 00: gpio                                   |
|       |       |                                         | gpio4d6_sel                                |
| 1     |       |                                         | GPIO4D[6] iomux select                     |
| 13:12 | RW    | 0x0                                     | 01: smc_data14                             |
|       |       |                                         | 10: trace_data14                           |
|       |       | • 1                                     | 00: gpio                                   |
|       |       | \ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \ | gpio4d5_sel                                |
| 11.10 | DW    | 00                                      | GPIO4D[5] iomux select                     |
| 11:10 | RW    | 0x0                                     | 01: smc_data13                             |
|       |       |                                         | 10: trace_data13                           |
|       |       | 7                                       | 00: gpio                                   |
|       |       |                                         | gpio4d4_sel                                |
| 9:8   | RW    | 0x0                                     | GPIO4D[4] iomux select 01: smc_data12      |
| 9.0   | L/ VV | UXU                                     | 10: trace_data12                           |
|       |       |                                         | 00: gpio                                   |
|       |       |                                         | gpio4d3_sel                                |
|       |       |                                         | GPIO4D[3] iomux select                     |
| 7:6   | RW    | 0×0                                     | 01: smc_data11                             |
| /.0   | 1200  |                                         | 10: trace_data11                           |
|       |       |                                         | 00: gpio                                   |
|       |       |                                         | our abin                                   |



| Bit | Attr | Reset Value | Description            |
|-----|------|-------------|------------------------|
|     |      |             | gpio4d2_sel            |
|     |      |             | GPIO4D[2] iomux select |
| 5:4 | RW   | 0x0         | 01: smc_data10         |
|     |      |             | 10: trace_data10       |
|     |      |             | 00: gpio               |
|     |      |             | gpio4d1_sel            |
|     |      |             | GPIO4D[1] iomux select |
| 3:2 | RW   | 0x0         | 01: smc_data9          |
|     |      |             | 10:trace_data9         |
|     |      |             | 00: gpio               |
|     |      |             | gpio4d0_sel            |
|     |      |             | GPIO4D[0] iomux select |
| 1:0 | RW   | 0x0         | 01: smc_data8          |
|     |      |             | 10: trace_data8        |
|     |      |             | 00: gpio               |

## GRF\_GPIO6B\_IOMUX

Address: Operational Base + offset (0x010c)

GPIO6B iomux control

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0×0000      | write_enable bit0~15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 cannot be written by software; |
| 15    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                           |
| 14    | RW   | 0×0         | gpio6b7_sel GPIO6B[7] iomux select 1: test_clock_out 0: gpio                                                                                                                                                                                                                                                                                       |
| 13:0  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                           |



#### **GRF\_GPIOOL\_PULL**

Address: Operational Base + offset (0x0118) GPIO0A / GPIO0B pull up/down control

| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
|       |      |             | write_enable                                  |
|       |      |             | bit0~bit15 write enable                       |
|       |      |             | When bit 16=1, bit 0 can be written by        |
|       |      |             | software .                                    |
|       |      |             | When bit 16=0, bit 0 cannot be written by     |
|       |      |             | software;                                     |
|       |      |             | When bit 17=1, bit 1 can be written by        |
| 31:16 | WO   | 0x0000      | software .                                    |
|       |      |             | When bit 17=0, bit 1 cannot be written by     |
|       |      |             | software;                                     |
|       |      |             |                                               |
|       |      |             | When bit 31=1, bit 15 can be written by       |
|       |      |             | software .                                    |
|       |      |             | When bit 31=0, bit 15 cannot be written by    |
|       |      |             | software;                                     |
|       | RW   |             | gpio0b_pull                                   |
|       |      |             | GPIO0B pull up/down enable                    |
|       |      |             | Values written to this register independently |
| 15:8  |      | 0x00        | control Pullup/Pulldown or not for the        |
| 13.0  |      |             | corresponding data bit in GPIO.               |
|       |      |             | 0: pull up/down enable, PAD type will decide  |
|       |      |             | to be up or down ,not related with this value |
|       |      |             | 1: pull up/down disable                       |
|       |      | 0x00        | gpio0a_pull                                   |
| 7:0   | RW   |             | GPIO0A pull up/down enable                    |
|       |      |             | Values written to this register independently |
|       |      |             | control Pullup/Pulldown or not for the        |
|       |      |             | corresponding data bit in GPIO.               |
|       |      |             | 0: pull up/down enable, PAD type will decide  |
|       |      |             | to be up or down ,not related with this value |
|       |      |             | 1: pull up/down disable                       |

## GRF\_GPIO0H\_PULL

Address: Operational Base + offset (0x011c) GPIOOC / GPIOOD pull up/down control

| Bit Attr Reset Value Description |  |
|----------------------------------|--|
|----------------------------------|--|



| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
|       |      |             | write_enable                                  |
|       |      |             | bit0~bit15 write enable                       |
|       |      |             | When bit 16=1, bit 0 can be written by        |
|       |      |             | software .                                    |
|       |      |             | When bit 16=0, bit 0 cannot be written by     |
|       |      |             | software;                                     |
|       |      |             | When bit 17=1, bit 1 can be written by        |
| 31:16 | WO   | 0x0000      | software .                                    |
|       |      |             | When bit 17=0, bit 1 cannot be written by     |
|       |      |             | software;                                     |
|       |      |             |                                               |
|       |      |             | When bit 31=1, bit 15 can be written by       |
|       |      |             | software .                                    |
|       |      |             | When bit 31=0, bit 15 cannot be written by    |
|       |      |             | software;                                     |
|       | RW   | 0x00        | gpio0d_pull                                   |
|       |      |             | GPIO0D pull up/down enable                    |
|       |      |             | Values written to this register independently |
| 15:8  |      |             | control Pullup/Pulldown or not for the        |
| 15.6  |      |             | corresponding data bit in GPIO.               |
|       |      |             | 0: pull up/down enable, PAD type will decide  |
|       |      |             | to be up or down ,not related with this value |
|       |      |             | 1: pull up/down disable                       |
|       |      |             | gpio0c_pull                                   |
|       |      | 0x00        | GPIOOC pull up/down enable                    |
| 7:0   | RW   |             | Values written to this register independently |
|       |      |             | control Pullup/Pulldown or not for the        |
|       |      |             | corresponding data bit in GPIO.               |
|       |      |             | 0: pull up/down enable, PAD type will decide  |
|       |      | 7           | to be up or down ,not related with this value |
|       |      |             | 1: pull up/down disable                       |

#### GRF\_GPIO1L\_PULL

Address: Operational Base + offset (0x0120)GPIO0A / GPIO0B pull up/down control

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
|-----|------|-------------|-------------|



| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
|       |      |             | write_enable                                  |
|       |      |             | bit0~bit15 write enable                       |
|       |      |             | When bit 16=1, bit 0 can be written by        |
|       |      |             | software .                                    |
|       |      |             | When bit 16=0, bit 0 cannot be written by     |
|       |      |             | software;                                     |
|       |      |             | When bit 17=1, bit 1 can be written by        |
| 31:16 | WO   | 0x0000      | software .                                    |
|       |      |             | When bit 17=0, bit 1 cannot be written by     |
|       |      |             | software;                                     |
|       |      |             |                                               |
|       |      |             | When bit 31=1, bit 15 can be written by       |
|       |      |             | software .                                    |
|       |      |             | When bit 31=0, bit 15 cannot be written by    |
|       |      |             | software;                                     |
|       | RW   | 0x00        | gpio0b_pull                                   |
|       |      |             | GPIO0B pull up/down enable                    |
|       |      |             | Values written to this register independently |
| 15:8  |      |             | control Pullup/Pulldown or not for the        |
| 15.0  |      |             | corresponding data bit in GPIO.               |
|       |      |             | 0: pull up/down enable, PAD type will decide  |
|       |      |             | to be up or down ,not related with this value |
|       |      |             | 1: pull up/down disable                       |
|       |      |             | gpio0a_pull                                   |
|       | RW   | 0x00        | GPIO0A pull up/down enable                    |
| 7:0   |      |             | Values written to this register independently |
|       |      |             | control Pullup/Pulldown or not for the        |
|       |      |             | corresponding data bit in GPIO.               |
|       |      |             | 0: pull up/down enable, PAD type will decide  |
|       |      | 7           | to be up or down ,not related with this value |
|       |      |             | 1: pull up/down disable                       |

#### **GRF\_GPIO1H\_PULL**

Address: Operational Base + offset (0x0124)GPIO1C / GPIO1D pull up/down control

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
|-----|------|-------------|-------------|



| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
|       |      |             | write_enable                                  |
|       |      |             | bit0~bit15 write enable                       |
|       |      |             | When bit 16=1, bit 0 can be written by        |
|       |      |             | software .                                    |
|       |      |             | When bit 16=0, bit 0 cannot be written by     |
|       |      |             | software;                                     |
|       |      |             | When bit 17=1, bit 1 can be written by        |
| 31:16 | WO   | 0x0000      | software .                                    |
|       |      |             | When bit 17=0, bit 1 cannot be written by     |
|       |      |             | software;                                     |
|       |      |             |                                               |
|       |      |             | When bit 31=1, bit 15 can be written by       |
|       |      |             | software .                                    |
|       |      |             | When bit 31=0, bit 15 cannot be written by    |
|       |      |             | software;                                     |
|       | RW   | 0x00        | gpio1d_pull                                   |
|       |      |             | GPIO1d pull up/down enable                    |
|       |      |             | Values written to this register independently |
| 15:8  |      |             | control Pullup/Pulldown or not for the        |
| 13.0  |      |             | corresponding data bit in GPIO.               |
|       |      |             | 0: pull up/down enable, PAD type will decide  |
|       |      |             | to be up or down ,not related with this value |
|       |      |             | 1: pull up/down disable                       |
|       |      |             | gpio1c_pull                                   |
|       | RW   | 0x00        | GPIO1C pull up/down enable                    |
| 7:0   |      |             | Values written to this register independently |
|       |      |             | control Pullup/Pulldown or not for the        |
|       |      |             | corresponding data bit in GPIO.               |
|       |      |             | 0: pull up/down enable, PAD type will decide  |
|       |      | Y           | to be up or down ,not related with this value |
|       |      |             | 1: pull up/down disable                       |

#### GRF\_GPIO2L\_PULL

Address: Operational Base + offset (0x0128) GPIO2A / GPIO2B pull up/down control

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
|-----|------|-------------|-------------|



| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
|       |      |             | write_enable                                  |
|       |      |             | bit0~bit15 write enable                       |
|       |      |             | When bit 16=1, bit 0 can be written by        |
|       |      |             | software .                                    |
|       |      |             | When bit 16=0, bit 0 cannot be written by     |
|       |      |             | software;                                     |
|       |      |             | When bit 17=1, bit 1 can be written by        |
| 31:16 | WO   | 0x0000      | software .                                    |
|       |      |             | When bit 17=0, bit 1 cannot be written by     |
|       |      |             | software;                                     |
|       |      |             |                                               |
|       |      |             | When bit 31=1, bit 15 can be written by       |
|       |      |             | software .                                    |
|       |      |             | When bit 31=0, bit 15 cannot be written by    |
|       |      |             | software;                                     |
|       |      |             | gpio2b_pull                                   |
|       |      |             | GPIO2B pull up/down enable                    |
|       | RW   | 0x00        | Values written to this register independently |
| 15:8  |      |             | control Pullup/Pulldown or not for the        |
| 15.0  |      |             | corresponding data bit in GPIO.               |
|       |      |             | 0: pull up/down enable, PAD type will decide  |
|       |      |             | to be up or down ,not related with this value |
|       |      |             | 1: pull up/down disable                       |
|       |      |             | gpio2a_pull                                   |
| 7:0   | RW   | 0x00        | GPIO2A pull up/down enable                    |
|       |      |             | Values written to this register independently |
|       |      |             | control Pullup/Pulldown or not for the        |
|       |      |             | corresponding data bit in GPIO.               |
|       |      |             | 0: pull up/down enable, PAD type will decide  |
|       |      | 7           | to be up or down ,not related with this value |
|       |      |             | 1: pull up/down disable                       |

#### GRF\_GPIO2H\_PULL

Address: Operational Base + offset (0x012c) GPIO2C / GPIO2D pull up/down control

| Bit Attr Reset Value | Description |
|----------------------|-------------|
|----------------------|-------------|

| Bit   | Attr | Reset Value | Description                                       |
|-------|------|-------------|---------------------------------------------------|
|       |      |             | write_enable                                      |
|       |      |             | bit0~bit15 write enable                           |
|       |      |             | When bit 16=1, bit 0 can be written by            |
|       |      |             | software .                                        |
|       |      |             | When bit 16=0, bit 0 cannot be written by         |
|       |      |             | software;                                         |
|       |      |             | When bit 17=1, bit 1 can be written by            |
| 31:16 | WO   | 0x0000      | software .                                        |
|       |      |             | When bit 17=0, bit 1 cannot be written by         |
|       |      |             | software;                                         |
|       |      |             | When his 21, 1, his 15, and he welled his         |
|       |      |             | When bit 31=1, bit 15 can be written by software. |
|       |      |             | When bit 31=0, bit 15 cannot be written by        |
|       |      |             | software;                                         |
|       |      |             | gpio2d_pull                                       |
|       |      |             | GPIO2d pull up/down enable                        |
|       |      |             | Values written to this register independently     |
| 1.5.0 |      |             | control Pullup/Pulldown or not for the            |
| 15:8  | RW   | 0x00        | corresponding data bit in GPIO.                   |
|       |      |             | 0: pull up/down enable, PAD type will decide      |
|       |      |             | to be up or down ,not related with this value     |
|       |      |             | 1: pull up/down disable                           |
|       |      |             | gpio2c_pull                                       |
|       |      | 0×00        | GPIO2C pull up/down enable                        |
|       |      |             | Values written to this register independently     |
| 7:0   | RW   |             | control Pullup/Pulldown or not for the            |
|       |      |             | corresponding data bit in GPIO.                   |
|       | 1    |             | 0: pull up/down enable, PAD type will decide      |
|       | C    | 7           | to be up or down ,not related with this value     |
|       |      |             | 1: pull up/down disable                           |

#### GRF\_GPIO3L\_PULL

Address: Operational Base + offset (0x0130)

GPIO3A / GPIO3B pull up/down control

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
|-----|------|-------------|-------------|



| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
|       |      |             | write_enable                                  |
|       |      |             | bit0~bit15 write enable                       |
|       |      |             | When bit 16=1, bit 0 can be written by        |
|       |      |             | software .                                    |
|       |      |             | When bit 16=0, bit 0 cannot be written by     |
|       |      |             | software;                                     |
|       |      |             | When bit 17=1, bit 1 can be written by        |
| 31:16 | WO   | 0x0000      | software .                                    |
|       |      |             | When bit 17=0, bit 1 cannot be written by     |
|       |      |             | software;                                     |
|       |      |             |                                               |
|       |      |             | When bit 31=1, bit 15 can be written by       |
|       |      |             | software .                                    |
|       |      |             | When bit 31=0, bit 15 cannot be written by    |
|       |      |             | software;                                     |
|       |      |             | gpio3b_pull                                   |
|       |      |             | GPIO3B pull up/down enable                    |
|       | RW   |             | Values written to this register independently |
| 15:8  |      | 0×00        | control Pullup/Pulldown or not for the        |
| 15.0  |      | UXUU        | corresponding data bit in GPIO.               |
|       |      |             | 0: pull up/down enable, PAD type will decide  |
|       |      |             | to be up or down ,not related with this value |
|       |      |             | 1: pull up/down disable                       |
|       |      |             | gpio3a_pull                                   |
|       |      | 0x00        | GPIO3A pull up/down enable                    |
|       |      |             | Values written to this register independently |
| 7:0   | RW   |             | control Pullup/Pulldown or not for the        |
| , .0  | KW 1 |             | corresponding data bit in GPIO.               |
|       |      |             | 0: pull up/down enable, PAD type will decide  |
|       |      | 7           | to be up or down ,not related with this value |
|       |      |             | 1: pull up/down disable                       |

#### GRF\_GPIO3H\_PULL

Address: Operational Base + offset (0x0134)GPIO3C / GPIO3D pull up/down control

| Bit Attr Reset Value | Description |
|----------------------|-------------|
|----------------------|-------------|



| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
|       |      |             | write_enable                                  |
|       |      |             | bit0~bit15 write enable                       |
|       |      |             | When bit 16=1, bit 0 can be written by        |
|       |      |             | software .                                    |
|       |      |             | When bit 16=0, bit 0 cannot be written by     |
|       |      |             | software;                                     |
|       |      |             | When bit 17=1, bit 1 can be written by        |
| 31:16 | RW   | 0x0000      | software .                                    |
|       |      |             | When bit 17=0, bit 1 cannot be written by     |
|       |      |             | software;                                     |
|       |      |             |                                               |
|       |      |             | When bit 31=1, bit 15 can be written by       |
|       |      |             | software .                                    |
|       |      |             | When bit 31=0, bit 15 cannot be written by    |
|       |      |             | software;                                     |
|       |      |             | gpio3d_pull                                   |
|       |      |             | GPIO3d pull up/down enable                    |
|       | RW   |             | Values written to this register independently |
| 15:8  |      | 0x00        | control Pullup/Pulldown or not for the        |
| 15.0  |      | UXUU        | corresponding data bit in GPIO.               |
|       |      |             | 0: pull up/down enable, PAD type will decide  |
|       |      |             | to be up or down ,not related with this value |
|       |      |             | 1: pull up/down disable                       |
|       |      |             | gpio3c_pull                                   |
|       |      | 0x00        | GPIO3C pull up/down enable                    |
|       |      |             | Values written to this register independently |
| 7:0   | RW   |             | control Pullup/Pulldown or not for the        |
| , .0  | KW   |             | corresponding data bit in GPIO.               |
|       |      |             | 0: pull up/down enable, PAD type will decide  |
|       |      |             | to be up or down ,not related with this value |
|       |      |             | 1: pull up/down disable                       |

#### GRF\_GPIO4L\_PULL

Address: Operational Base + offset (0x0138)

GPIO4A / GPIO4B pull up/down control

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
|-----|------|-------------|-------------|



#### **GRF GPIO4H PULL**

Address: Operational Base + offset (0x013c) GPIO4C / GPIO4D pull up/down control

| Bit Attr Reset Value | Description |
|----------------------|-------------|
|----------------------|-------------|



| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
|       |      |             | write_enable                                  |
|       |      |             | bit0~bit15 write enable                       |
|       |      |             | When bit 16=1, bit 0 can be written by        |
|       |      |             | software .                                    |
|       |      |             | When bit 16=0, bit 0 cannot be written by     |
|       |      |             | software;                                     |
|       |      |             | When bit 17=1, bit 1 can be written by        |
| 31:16 | WO   | 0x0000      | software .                                    |
|       |      |             | When bit 17=0, bit 1 cannot be written by     |
|       |      |             | software;                                     |
|       |      |             |                                               |
|       |      |             | When bit 31=1, bit 15 can be written by       |
|       |      |             | software .                                    |
|       |      |             | When bit 31=0, bit 15 cannot be written by    |
|       |      |             | software;                                     |
|       |      |             | gpio4d_pull                                   |
|       |      |             | GPIO4d pull up/down enable                    |
|       | RW   |             | Values written to this register independently |
| 15:8  |      | 0×00        | control Pullup/Pulldown or not for the        |
| 15.0  |      | UXUU        | corresponding data bit in GPIO.               |
|       |      |             | 0: pull up/down enable, PAD type will decide  |
|       |      |             | to be up or down ,not related with this value |
|       |      |             | 1: pull up/down disable                       |
|       |      |             | gpio4c_pull                                   |
|       |      | 0x00        | GPIO4C pull up/down enable                    |
|       |      |             | Values written to this register independently |
| 7:0   | RW   |             | control Pullup/Pulldown or not for the        |
| 7.0   |      |             | corresponding data bit in GPIO.               |
|       |      |             | 0: pull up/down enable, PAD type will decide  |
|       |      |             | to be up or down ,not related with this value |
|       |      |             | 1: pull up/down disable                       |

#### GRF\_GPIO6L\_PULL

Address: Operational Base + offset (0x0148)

GPIO6A / GPIO6B pull up/down control

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
|-----|------|-------------|-------------|



#### **GRF SOC CONO**

Address: Operational Base + offset (0x0150)

soc control register

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
|-----|------|-------------|-------------|



| Bit   | Attr | Reset Value | Description                                |
|-------|------|-------------|--------------------------------------------|
|       |      |             | write_enable                               |
|       |      |             | bit 0~bit 15 write enable                  |
|       |      |             | When bit 16=1, bit 0 can be written by     |
|       |      |             | software .                                 |
|       |      |             | When bit 16=0, bit 0 cannot be written by  |
|       |      |             | software;                                  |
|       |      |             | When bit 17=1, bit 1 can be written by     |
| 31:16 | RW   | 0×0000      | software .                                 |
|       |      |             | When bit 17=0, bit 1 cannot be written by  |
|       |      |             | software;                                  |
|       |      |             |                                            |
|       |      |             | When bit 31=1, bit 15 can be written by    |
|       |      |             | software .                                 |
|       |      |             | When bit 31=0, bit 15 cannot be written by |
|       |      |             | software;                                  |
|       |      |             | hdmi_ext_sel                               |
| 4 =   | D14/ |             | external hdmi select                       |
| 15    | RW   | 0x0         | 0: hdmi in SoC is used                     |
|       |      |             | 1: hdmi in SoC is not used                 |
|       |      |             | hdmi_video_sel                             |
| 1.4   | DW   | 0.40        | hdmi video source select                   |
| 14    | RW   | 0x0         | 0: hdmi get rgb datas from LCDC0           |
|       |      |             | 1: hdmi get rga datas from LCDC1           |
|       |      |             | smc_mux_con                                |
| 13    | RW   | 0x0         | When high, the smc memory interface        |
|       |      | <b>1</b>    | operates in multiplexed address/data mode. |
|       |      | My y        | soc_remap                                  |
|       |      |             | remap bit control                          |
| 12    | RW   | 0x0         | When soc_remap = 1, the bootrom is mapped  |
|       |      | 7           | to address 0x10100000 and internal memory  |
|       |      |             | is mapped to address 0x0.                  |
|       |      |             | emmc_flash_sel                             |
| 11    | RW   | 0×0         | emmc flash select used for iomux           |
| 11    | 1244 |             | IO_FLASH_DATA[7:0] , IO_FLASH_WP are       |
|       |      |             | selected for emmc instead of flash         |
| 10:7  | RW   | 0×0         | tzpc_revision                              |
| 10.7  |      |             |                                            |



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:5 | RW   | 0x0         | I2cache_acc L2 Cache access control 00: used as L2 cache accessed by CPU. 10: 256KB is for L2 cahce accessed by CPU , another 256KB is for internal memory accessed by AXI 11/01: used as internal mmeory accessed by AXI                                                                                                                                                                                                                                                                                      |
| 4:3 | RW   | 0×1         | I2rd_wait L2 Cache read wait cycle 00: the rdata of L2 cache will be captured at the next cycle after read command valid when used as internal memory. 01: the rdata of L2 cache will be captured one cycle later after read command valid when used as internal memory. 10: the rdata of L2 cache will be captured two cycle later after read command valid when used as internal memory. 11: the rdata of L2 cache will be captured three cycle later after read command valid when used as internal memory. |
| 2:1 | RW   | 0×0         | imemrd_wait IMEM read wait cycle 00: the rdata of internal memory will be captured at the next cycle after read command valid 01: the rdata of internal memory will be captured one cycle later after read command valid 10: the rdata of internal memory will be captured two cycle later after read command valid 11: the rdata of internal memory will be captured three cycle later after read command valid                                                                                               |
| 0   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

# GRF\_SOC\_CON1

Address: Operational Base + offset (0x0154)

soc control register

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|



| Bit   | Attr     | Reset Value | Description                                    |
|-------|----------|-------------|------------------------------------------------|
|       |          |             | write_enable                                   |
|       |          |             | bit 0~bit 15 write enable                      |
|       |          |             | When bit 16=1, bit 0 can be written by         |
|       |          |             | software .                                     |
|       |          |             | When bit 16=0, bit 0 cannot be written by      |
|       |          |             | software;                                      |
|       |          |             | When bit 17=1, bit 1 can be written by         |
| 31:16 | RW       | 0x0000      | software .                                     |
|       |          |             | When bit 17=0, bit 1 cannot be written by      |
|       |          |             | software;                                      |
|       |          |             |                                                |
|       |          |             | When bit 31=1, bit 15 can be written by        |
|       |          |             | software .                                     |
|       |          |             | When bit 31=0, bit 15 cannot be written by     |
|       |          |             | software;                                      |
|       |          |             | rki2c_sel                                      |
| 15:11 | RW       | 0x00        | 0: use old i2c                                 |
| 13.11 | 1 / 4 /  | 0,000       | 1: rki2c is used instead of old i2c            |
|       |          |             | X                                              |
|       |          | 0×0         | vpu_sel                                        |
| 10    | RW       |             | vdpu vepu clock select                         |
|       |          |             | 0: select vepu aclk as vpu main clock          |
|       |          |             | 1: select vdpu aclk as vpu main clock          |
|       |          |             | peri_emem_pause                                |
| 9     | RW       | 0x0         | peri emem ahb bus arbiter pause control        |
|       |          |             | PERI AHB bus arbiter pause control             |
|       |          |             | peri_usb_pause                                 |
| 8     | RW       | 0x0         | peri usb ahb bus arbiter pause control         |
| _     | - 1      |             | USB AHB bus arbiter pause control              |
| 7     | RO       | 0x0         | reserved                                       |
|       | 5)//     |             | smc_mux_mode_0                                 |
| 6     | RW       | 0x0         | When high, the smc memory interface            |
|       | <b>Y</b> |             | operates in multiplexed address/data mode.     |
|       |          |             | smc_sram_mw_0                                  |
|       |          |             | Sets the memory width for smc chip select0, on |
|       |          |             | memory interface 0, when                       |
| E. 4  | DW       | 0.0         | remap_0(grf_soc_con[14]) is high, the          |
| 5:4   | RW       | 0x0         | encoding is: 00: 8 bit                         |
|       |          |             | 01: 16 bit                                     |
|       |          |             | 10: 32bit                                      |
|       |          |             |                                                |
|       |          |             | 11: reserved                                   |



| Bit | Attr | Reset Value | Description                                      |
|-----|------|-------------|--------------------------------------------------|
|     |      |             | smc_remap_0                                      |
| 3   | RW   | 0x0         | If high, remap smc controller chip select 0 , on |
|     |      |             | memory interface 0 , to address 0x0              |
|     |      |             | smc_a_gt_m0_sync                                 |
|     |      |             | Indicate that if aclk is faster than and         |
| 2   | RW   | 0x1         | synchronous to mclk0 in smc controller           |
|     |      |             | 1: aclk is faster than and synochrounous to      |
|     |      |             | mclk0                                            |
|     |      |             | emac_speed                                       |
| 1   | RW   | 0x0         | 0:10MHz speed mode                               |
|     |      |             | 1:100MHz speed mode                              |
|     |      |             | emac_mode                                        |
| 0   | RW   | 0x0         | 0: rmii                                          |
|     |      |             | 1: mii                                           |

## GRF\_SOC\_CON2

Address: Operational Base + offset (0x0158)

soc control register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0×0000      | write_enable bit0~bit15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 cannot be written by software; |
| 15:8  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                |
| 7     | RW   | 0x0         | msch4_mainddr3 When DDR3 is used , software should configure this bit to 1.                                                                                                                                                                                                                                                                                                                             |
| 6     | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                |
| 5     | RW   | 0×0         | sw_addr15_en 1 : The axiaddr[15] of L2C axi bus 1 is switched with axiaddr[12] of L2C axi bus 1                                                                                                                                                                                                                                                                                                         |



| Bit | Attr | Reset Value | Description                                 |
|-----|------|-------------|---------------------------------------------|
|     |      |             | sw_addr16_en                                |
| 4   | RW   | 0x0         | 1 : The axiaddr[16] of L2C axi bus 1 is     |
|     |      |             | switched with axiaddr[13] of L2C axi bus 1  |
|     |      |             | sw_addr17_en                                |
| 3   | RW   | 0x0         | 1 : The axiaddr[17] of L2C axi bus 1 is     |
|     |      |             | switched with axiaddr[14] of L2C axi bus 1  |
| 2   | DW   | 0x0         | bank2_to_rank_en                            |
| 2   | RW   |             | 1: bank[2] connect to rank                  |
| 1   | RW   | 0x0         | rank_to_row15_en                            |
| 1   | KVV  |             | 1: ddr rank bit connect to row[15]          |
|     |      |             | upctl_c_active_in                           |
|     |      | 0×0         | ddr clock active in. External signal from   |
|     |      |             | system that flags if a hardware low power   |
| 0   | RW   |             | request can be accepted or should always be |
|     |      |             | denied.                                     |
|     |      |             | 0: may be accepted                          |
|     |      |             | 1: will be denied                           |

# GRF\_SOC\_STATUS0

Address: Operational Base + offset (0x015c)

soc status register

| Bit   | Attr | Reset Value | Description                    |
|-------|------|-------------|--------------------------------|
|       |      |             | -                              |
| 31:25 | RO   | 0x0         | reserved                       |
|       |      |             | host20_linestate               |
| 24:23 | RW   | 0x0         | host 2.0 linestate status      |
|       |      |             | Y                              |
|       |      |             | host20_bvalid                  |
| 22    | RW   | 0x0         | host 2.0 bvalid status         |
|       |      |             |                                |
|       |      | <b>Y</b>    | host20_vbusvalid               |
| 21    | RW   | 0x0         | host 2.0 vbus valid status     |
|       |      |             |                                |
|       |      |             | otg0_iddig                     |
| 20    | DW   | 0.40        | otg iddig status               |
| 20    | RW   | 0x0         | 0: indicate otg work as host   |
|       |      |             | 1: indicate otg work as device |
|       |      |             | otg_linestate                  |
| 19:18 | RW   | 0x0         | otg linestate status           |
|       |      |             |                                |
|       |      |             | otg_bvalid                     |
| 17    | RW   | 0x0         | otg bvalid status              |
|       |      |             |                                |



reserved

timer\_en\_status

#### **GRF\_DMACO\_CONO**

RO

RO

2:0

Address: Operational Base + offset (0x0160)

0x0

0x0

DMAC0 control register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                      |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0x0000      | write_enable bit0~bit15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. |
|       |      |             | When bit 31=0, bit 15 cannot be written by software;                                                                                                                                                                                                                                             |
| 15:7  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                         |



| Bit | Attr | Reset Value | Description                                      |
|-----|------|-------------|--------------------------------------------------|
|     |      |             | dmac0_boot_addr                                  |
|     |      |             | dmac0_boot_addr[18:16]                           |
| 6:4 | RW   | 0×0         | DMAC0 boot_addr[18:16] input control             |
| 0.4 | KVV  | UXU         | Configures the address location that contains    |
|     |      |             | the first instruction the DMAC executes, when    |
|     |      |             | it exits from reset.                             |
| 3   | RO   | 0x0         | reserved                                         |
|     |      |             | dmac0_drtype                                     |
|     |      |             | DMAC0 type of acknowledgement or request         |
|     |      | 0×1         | for peripheral signals:                          |
| 2:1 | RW   |             | 00 : single level request                        |
|     |      |             | 01 : burst level request                         |
|     |      |             | 10 : acknowledging a flush request               |
|     |      |             | 11 : reserved                                    |
|     |      |             | dmac0_boot_from_pc                               |
|     |      |             | DMAC0 boot_from_pc input control                 |
|     |      |             | Controls the location in which the DMAC0         |
|     |      |             | executes its initial instruction, after it exits |
| 0   | RW   | 0x0         | from reset :                                     |
| ا   | IXVV | V UXU       | 0= DMAC0 waits for an instruction from APB       |
|     |      |             | interface                                        |
|     |      |             | 1= DMAC manager thread executes the              |
|     |      |             | instruction that is located at the address that  |
|     |      |             | boot_addr[31:0] provided.                        |

Address: Operational Base + offset (0x0164)

DMAC0 control register

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
|-----|------|-------------|-------------|



the first instruction the DMAC executes, when

#### GRF\_DMAC0\_CON2

Address: Operational Base + offset (0x0168)

DMAC0 control register

| Bit   | Attr | Reset Value | Description                                |
|-------|------|-------------|--------------------------------------------|
|       |      |             | write_enable                               |
|       |      | C           | bit0~bit15 write enable                    |
|       | 1    |             | When bit 16=1, bit 0 can be written by     |
|       |      | 7           | software .                                 |
|       |      |             | When bit 16=0, bit 0 cannot be written by  |
|       |      |             | software;                                  |
|       | ,    |             | When bit 17=1, bit 1 can be written by     |
| 31:16 | WO   | 0x0000      | software .                                 |
|       |      |             | When bit 17=0, bit 1 cannot be written by  |
|       |      |             | software;                                  |
|       |      |             |                                            |
|       |      |             | When bit 31=1, bit 15 can be written by    |
|       |      |             | software .                                 |
|       |      |             | When bit 31=0, bit 15 cannot be written by |
|       |      |             | software;                                  |

it exits from reset.



| Bit  | Attr | Reset Value | Description                                  |
|------|------|-------------|----------------------------------------------|
|      |      |             | dmac0_boot_irq_ns                            |
|      |      |             | dmac0_boot_irq_ns[11:4]                      |
|      |      |             | DMAC1 boot_irq_ns[11:4] input control        |
| 15:8 | RW   | 0×00        | Controls the security state of an            |
| 15.6 | KVV  | UXUU        | event-interrupt resource , when the DMAC1    |
|      |      |             | exits from reset.                            |
|      |      |             | Note: DMAC1 don't support secure feature,    |
|      |      |             | these bits don't need to be configured.      |
|      |      |             | dmac0_boot_periph_ns                         |
|      |      | 0×00        | dmac0_boot_periph_ns[11:4]                   |
|      |      |             | DMAC1 boot_peri_ns[11:4] input control       |
| 7.0  | DW   |             | Controls the security state of a peripheral  |
| 7:0  | RW   |             | request interface, when the DMAC1 exits from |
|      |      |             | reset.                                       |
|      |      |             | Note: DMAC1 don't support secure feature,    |
|      |      |             | these bits don't need to be configured.      |

Address: Operational Base + offset (0x016c)

| DMAC1 control register |      |             |                                            |
|------------------------|------|-------------|--------------------------------------------|
| Bit                    | Attr | Reset Value | Description                                |
|                        |      |             | write_enable                               |
|                        |      |             | bit0~bit15 write enable                    |
|                        |      |             | When bit 16=1, bit 0 can be written by     |
|                        |      | . (         | software .                                 |
|                        |      | 1           | When bit 16=0, bit 0 cannot be written by  |
|                        |      |             | software;                                  |
|                        |      |             | When bit 17=1, bit 1 can be written by     |
| 31:16                  | WO   | 0×0000      | software .                                 |
|                        |      | 7           | When bit 17=0, bit 1 cannot be written by  |
|                        |      |             | software;                                  |
|                        |      |             |                                            |
|                        | 7    |             | When bit 31=1, bit 15 can be written by    |
| 7                      |      |             | software .                                 |
|                        |      |             | When bit 31=0, bit 15 cannot be written by |
|                        |      |             | software;                                  |
|                        |      |             | dmac1_boot_irq_ns                          |
|                        |      |             | DMAC1 boot_irq_ns input control            |
|                        |      |             | Controls the security state of an          |
| 15:2                   | RW   | 0x3fff      | event-interrupt resource , when the DMAC1  |
|                        |      |             | exits from reset.                          |
|                        |      |             | Note: DMAC1 don't support secure feature , |
|                        |      |             | these bits don't need to be configured.    |



| Bit | Attr  | Reset Value | Description                                      |
|-----|-------|-------------|--------------------------------------------------|
|     |       |             | dmac1_boot_manager_ns                            |
|     |       |             | DMAC1 boot_manager_ns input control              |
|     |       |             | When the DMAC1 exits from reset , this signal    |
| 1   | RW    | 0×1         | controls the security state of the DMA manager   |
| 1   | IK VV | OXI         | thread:                                          |
|     |       |             | 0 = assigns DMA manager to the secure state      |
|     |       |             | 1 = assigns DMA manager to the Non-secure        |
|     |       |             | state                                            |
|     | RW    | 0×0         | dmac1_boot_from_pc                               |
|     |       |             | DMAC1 boot_from_pc input control                 |
|     |       |             | Controls the location in which the DMAC1         |
|     |       |             | executes its initial instruction, after it exits |
| 0   |       |             | from reset :                                     |
|     |       |             | 0= DMAC1 waits for an instruction from APB       |
|     |       |             | interface                                        |
|     |       |             | 1= DMAC manager thread executes the              |
|     |       |             | instruction that is located at the address that  |
|     |       |             | boot_addr[31:0] provided.                        |

Address: Operational Base + offset (0x0170)

DMAC1 control register

| Bit       | Attr | Reset Value         | Description                                                                                                                                                                                                                                                                                                                                          |
|-----------|------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 |      | Reset Value  0x0000 | write_enable bit0~bit15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. |
|           |      |                     | When bit 31=0, bit 15 cannot be written by software;                                                                                                                                                                                                                                                                                                 |



| Bit  | Attr | Reset Value | Description                                   |
|------|------|-------------|-----------------------------------------------|
|      |      | 0x3fff      | dmac1_boot_addr                               |
| 15:0 |      |             | dmac1_boot_addr[27:12]                        |
|      | RW C |             | DMAC1 boot_addr[27:12] input control          |
|      |      |             | Configures the address location that contains |
|      |      |             | the first instruction the DMAC executes, when |
|      |      |             | it exits from reset.                          |

Address: Operational Base + offset (0x0174)

DMAC1 control register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0×0000      | write_enable bit0~bit15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 cannot be written by software; |
| 15:10 | RO   | 0×0         | reserved                                                                                                                                                                                                                                                                                                                                              |
| 9:6   | RW   | 0x0         | dmac1_boot_periph_ns dmac1_boot_periph_ns[19:16] DMAC1 boot_peri_ns[19:16] input control Controls the security state of a peripheral request interface , when the DMAC1 exits from reset. Note: DMAC1 don't support secure feature, these bits don't need to be configured.                                                                           |
| 5:4   | RW   | 0x0         | dmac1_drtype DMAC1 type of acknowledgement or request for peripheral signals: 00 : single level request 01 : burst level request 10 : acknowledging a flush request 11 : reserved                                                                                                                                                                     |



| Bit | Attr   | Reset Value | Description                                      |
|-----|--------|-------------|--------------------------------------------------|
| 3:0 |        | 0xf         | dmac1_boot_addr                                  |
|     |        |             | dmac1_boot_addr[31:28]                           |
|     | RW 0xf |             | DMAC1 boot_addr[31:28] input control             |
|     |        |             | Configures the address location that contains    |
|     |        |             | the first instruction the DMAC executes, when it |
|     |        |             | exits from reset.                                |

Address: Operational Base + offset (0x0178)

DMAC1 control register

| DMAC1 | control r | egister     |                                                                                                                                                                                                                                                                                                                                                      |
|-------|-----------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit   | Attr      | Reset Value | Description                                                                                                                                                                                                                                                                                                                                          |
| 31:16 | WO        | 0×0000      | write_enable bit0~bit15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software . When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software . When bit 31=1, bit 15 can be written by software; |
|       | <b>\1</b> | C.          | dmac1_boot_perph_ns  DMAC1 boot_peri_ns[19:16] input control  Controls the security state of a peripheral                                                                                                                                                                                                                                            |
| 15:0  | RW        | 0x3fff      | request interface , when the DMAC1 exits from reset.                                                                                                                                                                                                                                                                                                 |
|       |           |             | Note: DMAC1 don't support secure feature,                                                                                                                                                                                                                                                                                                            |
|       |           |             | these bits don't need to be configured.                                                                                                                                                                                                                                                                                                              |

## GRF\_UOCO\_CONO

Address: Operational Base + offset (0x017c)

otg0 control register

| Bit Attr Reset Value Description |
|----------------------------------|
|----------------------------------|





| Bit   | Attr | Reset Value | Description                                     |
|-------|------|-------------|-------------------------------------------------|
|       |      |             | usbphy_port_reset                               |
|       |      |             | Per-Port Reset                                  |
|       |      |             | Function: When asserted, this                   |
|       |      |             | customer-specific signal resets the             |
|       |      |             | corresponding                                   |
|       |      |             | port transmit and receive logic without         |
|       |      |             | disabling the clocks within the USB 2.0         |
| 12    | RW   | 0x0         | nanoPHY.                                        |
|       |      |             | 1: The transmit and receive finite state        |
|       |      |             | machines (FSMs) are reset, and the              |
|       |      |             | line_state logic combinatorially reflects the   |
|       |      |             | state of the single-ended receivers.            |
|       |      |             | 0: The transmit and receive FSMs are            |
|       |      |             | operational, and the line_state logic           |
|       |      |             | becomes sequential after 11 PHYCLOCK cycles.    |
|       |      |             | usbphy_refclk_sel                               |
|       |      |             | Reference Clock Select for PLL Block            |
|       |      |             | Function: This signal selects the reference     |
|       |      |             | clock source for the PLL block.                 |
| 11:10 | RW   | 0x2         | 11: The PLL uses CLKCORE as reference.          |
|       |      |             | 10: The PLL uses CLKCORE as reference.          |
|       |      |             | 01: The XO block uses an external, 2.5-V clock  |
|       |      |             | supplied on the XO pin.                         |
|       |      |             | 00: The XO block uses the clock from a crystal. |
|       |      | • 1         | usbphy_refclk_div                               |
|       |      | 0x1         | Reference Clock Frequency Select                |
|       |      |             | Function: This bus selects the USB 2.0          |
| 9:8   | RW   |             | nanoPHY reference clock frequency.              |
|       | 1    |             | 11: 19.2 MHz<br>10: 48 MHz                      |
|       |      |             | 01: 24 MHz                                      |
|       |      |             |                                                 |
|       |      |             | 00: 12 MHz                                      |



| Bit | Attr     | Reset Value | Description                                            |
|-----|----------|-------------|--------------------------------------------------------|
|     |          |             | usbphy_otg_tune                                        |
|     |          |             | VBUS Valid Threshold Adjustment                        |
|     |          |             | Function: This bus adjusts the voltage level for       |
|     |          |             | the VBUS Valid threshold.                              |
|     |          |             | 111: + 9%                                              |
| 7:5 | RW       | 0x3         | 110: + 6%                                              |
| 7.5 | IXVV     | 0.0.5       | 101: + 3%                                              |
|     |          |             | 100: Design default                                    |
|     |          |             | 011:- 3%                                               |
|     |          |             | 010:- 6%                                               |
|     |          |             | 001: - 9%                                              |
|     |          |             | 000: - 12%                                             |
| 4   | RW       | 0×0         | usbphy_otg_disable                                     |
|     |          | o x o       | OTG Block Disable                                      |
|     |          |             | usbphy_compdistune                                     |
|     |          |             | Disconnect Threshold Adjustment                        |
|     |          |             | Function: This bus adjusts the voltage level for       |
|     |          |             | the threshold used to detect                           |
|     |          |             | a disconnect event at the host.                        |
|     | RW       |             | 111: + 4.5%                                            |
| 3:1 |          | 0x1         | 110: + 3%                                              |
|     |          |             | 101: + 1.5%                                            |
|     |          |             | 100: Design default                                    |
|     |          |             | 011: - 1.5%                                            |
|     |          | • (1)       | 010: - 3%                                              |
|     |          |             | 001: - 4.5%                                            |
|     |          |             | 000: - 6%                                              |
|     |          |             | usb_phy_common_on_n                                    |
|     |          |             | Common Block Power-Down Control                        |
|     |          | 7           | Function: This signal controls the power-down          |
| - ( |          |             | signals in the XO, Bias, and PLL                       |
| 0   | $\cup$   |             | blocks when the USB 2.0 PHY is in Suspend or           |
|     | 7        |             | Sleep mode.  1: In Suspend mode, the XO, Bias, and PLL |
| 0   | RW       | 0×1         | blocks are powered down. In Sleep                      |
|     | 1244     | 0.7.1       | mode, the Bias and PLL blocks are powered              |
|     |          |             | down.                                                  |
|     |          |             | 0: In Suspend mode, the XO, Bias, and PLL              |
|     |          |             | blocks remain powered in Suspend                       |
|     |          |             | mode. In Sleep mode, if the reference clock is         |
|     |          |             | a crystal, the XO block remains                        |
|     |          |             | powered.                                               |
| L   | <u> </u> | l           | 1.                                                     |



Address: Operational Base + offset (0x0180) otg0 control register

| otg0 cor | Attr   | Reset Value | Description                                       |
|----------|--------|-------------|---------------------------------------------------|
|          |        |             | write enable                                      |
|          |        |             | bit0~bit15 write enable                           |
|          |        |             | When bit 16=1, bit 0 can be written by            |
|          |        |             | software.                                         |
|          |        |             | When bit 16=0, bit 0 cannot be written by         |
|          |        |             | software;                                         |
|          |        |             | When bit 17=1, bit 1 can be written by            |
| 31:16    | wo     | 0×0000      | software.                                         |
| 31.10    |        | enococ      | When bit 17=0, bit 1 cannot be written by         |
|          |        |             | software;                                         |
|          |        |             |                                                   |
|          |        |             | When bit 31=1, bit 15 can be written by           |
|          |        |             | software .                                        |
|          |        |             | When bit 31=0, bit 15 cannot be written by        |
|          |        |             | software;                                         |
| 15       | RO     | 0x0         | reserved                                          |
|          |        |             | usbphy_txrise_tune                                |
|          |        |             | HS Transmitter Rise/Fall Time Adjustment          |
| 1.4      | RW     | 0x0         | Function: This bus adjusts the rise/fall times of |
| 14       | KVV    | UXU         | the high-speed waveform.                          |
|          |        |             | 1: - 8%                                           |
|          |        |             | 0: Design default                                 |
|          |        |             | usbphy_txhsxv_tune                                |
|          |        |             | Transmitter High-Speed Crossover Adjustment       |
|          |        |             | Function: This bus adjusts the voltage at which   |
|          | 1      |             | the DP and DM signals                             |
| 13:12    | RW     | 0x1         | cross while transmitting in HS mode.              |
| /        |        |             | 11: Default setting                               |
|          | $\cup$ |             | 10: + 15 mV                                       |
|          |        |             | 01: - 15 mV                                       |
| 7        |        |             | 00: Reserved                                      |



| Bit  | Attr | Reset Value | Description                                     |
|------|------|-------------|-------------------------------------------------|
|      |      |             | usbphy_txvref_tune                              |
|      |      |             | HS DC Voltage Level Adjustment                  |
|      |      |             | Function: This bus adjusts the high-speed DC    |
|      |      |             | level voltage.                                  |
|      |      |             | 1111: + 8.75%                                   |
|      |      |             | 1110: + 7.5%                                    |
|      |      |             | 1101: + 6.25%                                   |
|      |      |             | 1100: + 5%                                      |
|      |      |             | 1011: + 3.75%                                   |
| 11:8 | RW   | 0x6         | 1010: + 2.5%                                    |
| 11:0 | KVV  | UXO         | 1001: + 1.25%                                   |
|      |      |             | 1000: Design default                            |
|      |      |             | 0111: -1.25%                                    |
|      |      |             | 0110: -2.5%                                     |
|      |      |             | 0101: - 3.75%                                   |
|      |      |             | 0100: - 5%                                      |
|      |      |             | 0011: - 6.25%                                   |
|      |      |             | 0010: - 7.5%                                    |
|      |      |             | 0001: - 8.75%                                   |
|      |      |             | 0000: - 10%                                     |
|      |      |             | usbphy_txfsls_tune                              |
|      |      |             | FS/LS Source Impedance Adjustment               |
|      |      |             | Function: This bus adjusts the low- and         |
|      |      |             | full-speed single-ended source                  |
|      |      |             | impedance while driving high. The following     |
| 7:4  | RW   | 0xf         | adjustment values are based on                  |
| 7.4  |      | OXI         | nominal process, voltage, and temperature.      |
|      | A 1  | C           | 1111: - 5%                                      |
|      |      |             | 0111: -2.5%                                     |
|      |      |             | 0011: Design default                            |
|      |      |             | 0001: + 2.5%                                    |
|      |      |             | 0000: + 5%                                      |
|      |      |             | usbphy_txfreemphasis_tune                       |
|      |      |             | HS Transmitter Pre-Emphasis Enable              |
|      |      |             | Function: This signal controls the pre-emphasis |
|      |      |             | for a J-K or K-J state                          |
| 3    | RW   | 0x1         | transition in HS mode.                          |
|      |      |             | 1: The HS Transmitter pre-emphasis is           |
|      |      |             | enabled.                                        |
|      |      |             | 0 (design default): The HS Transmitter          |
|      |      |             | pre-emphasis is disabled                        |



| Bit | Attr | Reset Value | Description                                      |                     |
|-----|------|-------------|--------------------------------------------------|---------------------|
|     |      |             | usbphy_sqrxtune                                  |                     |
|     |      |             | Squelch Threshold Adjustment                     |                     |
|     |      |             | Function: This bus adjusts the voltage level for |                     |
|     |      |             | the threshold used to detect                     |                     |
|     |      |             | valid high-speed data.                           |                     |
|     |      |             | 111: - 20%                                       |                     |
| 2:0 | RW   | 0x3         | 110: -15%                                        |                     |
|     |      |             | 101: -10%                                        |                     |
|     |      |             | 100: -5%                                         |                     |
|     |      |             |                                                  | 011: Design default |
|     |      |             | 010: + 5%                                        |                     |
|     |      |             | 001: + 10%                                       |                     |
|     |      |             | 000: + 15%                                       |                     |

**GRF\_UOC0\_CON2**Address: Operational Base + offset (0x0184)

otg0 control register

| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
|       |      |             | write_enable                                  |
| 31:16 | WO   | 0x0000      | bit0~bit15 write enable                       |
|       |      |             |                                               |
| 15:13 | RO   | 0x0         | reserved                                      |
|       |      |             | scaledown                                     |
|       |      |             | Scale-Down Mode                               |
|       |      | • ()        | 00: Disables all scale-downs. Actual timing   |
|       |      |             | values are used. Required for                 |
|       |      |             | synthesis.                                    |
|       | RW   |             | 01: Enables scale-down of all timing values   |
|       |      |             | except Device mode suspend                    |
| 12.11 |      | 0x0         | and resume. These include:                    |
| 12:11 |      |             | - Speed enumeration.                          |
|       |      |             | - HNP/SRP.                                    |
|       | ,    |             | - Host mode suspend and resume.               |
|       |      |             | 10: Enables scale-down of Device mode         |
|       |      |             | suspend and resume timing values              |
|       |      |             | only.                                         |
|       |      |             | 11: Enables bit 0 and bit 1 scale-down timing |
|       |      |             | values.                                       |
|       |      |             | sleepm                                        |
| 10    | RW   | 0×1         | Sleep Assertion                               |
| 10    |      |             | 1: Normal operating mode                      |
|       |      |             | 0: Sleep mode                                 |



| Bit | Attr | Reset Value | Description                                     |
|-----|------|-------------|-------------------------------------------------|
| 0   | DW   | 0.40        | vregtune                                        |
| 9   | RW   | 0×0         | 2.5-V Voltage Regulator HS Boost Adjustment     |
|     |      |             | utmi_termselect                                 |
| 0   | DW   | 0.40        | USB Termination Select                          |
| 8   | RW   | 0×0         | 1: Full-speed terminations are enabled.         |
|     |      |             | 0: High-speed terminations are enabled.         |
|     |      |             | utmi_xcvrselect                                 |
|     |      |             | Transceiver Select                              |
|     |      |             | 11: Sends an LS packet on an FS bus or          |
| 7:6 | RW   | 0x0         | receives an LS packet.                          |
|     |      |             | 10: LS Transceiver                              |
|     |      |             | 01: FS Transceiver                              |
|     |      |             | 00: HS Transceiver                              |
|     |      |             | utmi_opmode                                     |
|     |      |             | UTMI+ Operational Mode                          |
|     |      |             | Function: This controller bus selects the UTMI+ |
|     |      |             | operational mode.                               |
|     |      | 0×0         | 11: Normal operation without SYNC or EOP        |
| 5:4 | RW   |             | generation. If the XCVRSEL bus is               |
| 5:4 |      |             | not set to 00 while OPMODE[1:0] is set to 11,   |
|     |      |             | USB PHY                                         |
|     |      |             | behavior is undefined.                          |
|     |      |             | 10: Disable bit stuffing and NRZI encoding      |
|     |      |             | 01: Non-Driving                                 |
|     |      |             | 00: Normal                                      |
|     | RW   | 1           | utmi_suspend_n                                  |
| 2   |      | 0v1         | Suspend Assertion                               |
| 3   |      | 0x1         | 1: Normal operating mode                        |
|     | 41   |             | 0: Suspend mode                                 |
|     |      | 7           | usbphy_soft_con_sel                             |
| 2   | RW   | 0x0         | 0: software control usb phy disable             |
|     |      |             | 1 : software control usb phy enable             |
|     |      |             | usbphy_vbus_vld_extsel                          |
|     |      |             | External VBUS Valid Select                      |
|     |      |             | Function: This signal selects the VBUSVLDEXT    |
|     |      |             | input or the internal Session                   |
| 1   | RW   | 0x0         | Valid comparator to indicate when the VBUS      |
|     |      |             | signal on the USB cable is valid.               |
|     |      |             | 1: The VBUSVLDEXT input is used.                |
|     |      |             | 0: The internal Session Valid comparator is     |
|     |      |             | used.                                           |



resistor on D+ is enabled.

resistor on D+ is disabled.

0: The VBUS signal is not valid, and the pull-up

#### **GRF\_UOC1\_CON0**

Address: Operational Base + offset (0x0188)

otq1 control register

| Bit      | Attr | Reset Value | Description                                   |
|----------|------|-------------|-----------------------------------------------|
|          |      |             | write_enable                                  |
|          |      |             | bit0~bit15 write enable                       |
|          |      |             | When bit 16=1, bit 0 can be written by        |
|          |      |             | software .                                    |
|          |      |             | When bit 16=0, bit 0 cannot be written by     |
|          |      |             | software;                                     |
|          |      | • ()        | When bit 17=1, bit 1 can be written by        |
| 31:16    | WO   | 0x0000      | software .                                    |
|          |      |             | When bit 17=0, bit 1 cannot be written by     |
|          |      |             | software;                                     |
|          | 1    |             |                                               |
|          | C    | <i>y</i>    | When bit 31=1, bit 15 can be written by       |
|          |      |             | software .                                    |
|          |      |             | When bit 31=0, bit 15 cannot be written by    |
|          | /    |             | software;                                     |
| <b>Y</b> |      |             | usbphy_txbitstuff_enh                         |
|          |      |             | High-Byte Transmit Bit-Stuffing Enable        |
|          |      |             | Function: This controller signal controls bit |
| 15       | RW   | 0x1         | stuffing on DATAINH[7:0] when                 |
|          |      |             | OPMODE[1:0] = 2'b11.                          |
|          |      |             | 1: Bit stuffing is enabled.                   |
|          |      |             | 0: Bit stuffing is disabled.                  |



| Bit   | Attr | Reset Value | Description                                     |
|-------|------|-------------|-------------------------------------------------|
|       |      |             | usbphy_txbitstuff_en                            |
|       |      |             | Low-Byte Transmit Bit-Stuffing Enable           |
|       |      |             | Function: This controller signal controls bit   |
| 14    | RW   | 0x1         | stuffing on DATAINH[7:0] when                   |
|       |      |             | OPMODE[1:0] = 2'b11.                            |
|       |      |             | 1: Bit stuffing is enabled.                     |
|       |      |             | 0: Bit stuffing is disabled.                    |
|       |      |             | usbphy_siddq                                    |
|       |      |             | IDDQ Test Enable                                |
|       |      |             | Function: This test signal enables you to       |
| 13    | RW   | 0x0         | perform IDDQ testing by powering down           |
|       |      |             | all analog blocks.                              |
|       |      |             | 1: The analog blocks are powered down.          |
|       |      |             | 0: The analog blocks are powered up.            |
|       |      |             | usbphy_port_reset                               |
|       |      |             | Per-Port Reset                                  |
|       |      |             | Function: When asserted, this                   |
|       |      |             | customer-specific signal resets the             |
|       |      |             | corresponding                                   |
|       |      |             | port transmit and receive logic without         |
|       |      |             | disabling the clocks within the USB 2.0         |
| 12    | RW   | 0x0         | nanoPHY.                                        |
|       |      |             | 1: The transmit and receive finite state        |
|       |      |             | machines (FSMs) are reset, and the              |
|       |      |             | line_state logic combinatorially reflects the   |
|       |      |             | state of the single-ended receivers.            |
|       |      | No. y       | 0: The transmit and receive FSMs are            |
|       |      |             | operational, and the line_state logic           |
|       | 4.1  | $\cup$      | becomes sequential after 11 PHYCLOCK cycles.    |
|       |      |             | usbphy_refclk_sel                               |
|       |      |             | Reference Clock Select for PLL Block            |
|       |      |             | Function: This signal selects the reference     |
| V     |      |             | clock source for the PLL block.                 |
| 11:10 | RW   | 0x2         | 11: The PLL uses CLKCORE as reference.          |
|       |      |             | 10: The PLL uses CLKCORE as reference.          |
|       |      |             | 01: The XO block uses an external, 2.5-V clock  |
|       |      |             | supplied on the XO pin.                         |
|       |      |             | 00: The XO block uses the clock from a crystal. |



| Bit | Attr     | Reset Value | Description                                      |
|-----|----------|-------------|--------------------------------------------------|
|     |          |             | usbphy_refclk_div                                |
|     |          |             | Reference Clock Frequency Select                 |
|     |          |             | Function: This bus selects the USB 2.0           |
| 9:8 | RW       | 0×1         | nanoPHY reference clock frequency.               |
| 9.0 | KVV      | UXI         | 11: 19.2 MHz                                     |
|     |          |             | 10: 48 MHz                                       |
|     |          |             | 01: 24 MHz                                       |
|     |          |             | 00: 12 MHz                                       |
|     |          |             | usbphy_otg_tune                                  |
|     |          |             | VBUS Valid Threshold Adjustment                  |
|     |          |             | Function: This bus adjusts the voltage level for |
|     |          |             | the VBUS Valid threshold.                        |
|     |          |             | 111: + 9%                                        |
| 7:5 | RW       | 0x3         | 110: + 6%                                        |
| 7.5 |          |             | 101: + 3%                                        |
|     |          |             | 100: Design default                              |
|     |          |             | 011:- 3%                                         |
|     |          |             | 010:- 6%                                         |
|     |          |             | 001: - 9%                                        |
|     |          |             | 000: - 12%                                       |
| 4   | RW       | 0x0         | usbphy_otg_disable                               |
| -   |          |             | OTG Block Disable                                |
|     |          |             | usbphy_compdistune                               |
|     |          |             | Disconnect Threshold Adjustment                  |
|     |          | • 1         | Function: This bus adjusts the voltage level for |
|     |          |             | the threshold used to detect                     |
|     |          |             | a disconnect event at the host.                  |
|     |          |             | 111: + 4.5%                                      |
| 3:1 | RW       | 0x1         | 110: + 3%                                        |
|     | C.       | 7           | 101: + 1.5%                                      |
| /   |          |             | 100: Design default                              |
|     | $\cup$   |             | 011: - 1.5%                                      |
|     | <b>Y</b> |             | 010: - 3%                                        |
| Y   |          |             | 001: - 4.5%                                      |
|     |          |             | 000: - 6%                                        |



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                           |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit | Attr | Reset Value | usb_phy_common_on_n Common Block Power-Down Control Function: This signal controls the power-down signals in the XO, Bias, and PLL blocks when the USB 2.0 PHY is in Suspend or Sleep mode. 1: In Suspend mode, the XO, Bias, and PLL                 |
| 0   | RW   | 0x1         | blocks are powered down. In Sleep mode, the Bias and PLL blocks are powered down.  0: In Suspend mode, the XO, Bias, and PLL blocks remain powered in Suspend mode. In Sleep mode, if the reference clock is a crystal, the XO block remains powered. |

## GRF\_UOC1\_CON1

Address: Operational Base + offset (0x018c) otg1 control register

| otgi coi | ntrol reg  | ister       |                                                   |
|----------|------------|-------------|---------------------------------------------------|
| Bit      | Attr       | Reset Value | Description                                       |
|          |            |             | write_enable                                      |
|          |            |             | bit0~bit15 write enable                           |
|          |            |             | When bit 16=1, bit 0 can be written by            |
|          |            |             | software .                                        |
|          |            |             | When bit 16=0, bit 0 cannot be written by         |
|          |            | 1           | software;                                         |
|          |            | Y           | When bit 17=1, bit 1 can be written by            |
| 31:16    | WO         | 0x0000      | software .                                        |
|          | <b>A</b> 1 |             | When bit 17=0, bit 1 cannot be written by         |
|          |            |             | software;                                         |
|          |            | ,           |                                                   |
|          |            |             | When bit 31=1, bit 15 can be written by           |
|          | ,          |             | software .                                        |
|          |            |             | When bit 31=0, bit 15 cannot be written by        |
|          |            |             | software;                                         |
| 15       | RO         | 0x0         | reserved                                          |
|          |            |             | usbphy_txrise_tune                                |
|          |            | 00          | HS Transmitter Rise/Fall Time Adjustment          |
| 14       | RW         |             | Function: This bus adjusts the rise/fall times of |
|          | KVV        | 0x0         | the high-speed waveform.                          |
|          |            |             | 1: - 8%                                           |
|          |            |             | 0: Design default                                 |



| Bit   | Attr | Reset Value | Description                                     |
|-------|------|-------------|-------------------------------------------------|
|       |      |             | usbphy_txhsxv_tune                              |
|       |      |             | Transmitter High-Speed Crossover Adjustment     |
|       |      |             | Function: This bus adjusts the voltage at which |
|       |      |             | the DP and DM signals                           |
| 13:12 | RW   | 0x1         | cross while transmitting in HS mode.            |
|       |      |             | 11: Default setting                             |
|       |      |             | 10: + 15 mV                                     |
|       |      |             | 01: - 15 mV                                     |
|       |      |             | 00: Reserved                                    |
|       |      |             | usbphy_txvref_tune                              |
|       |      |             | HS DC Voltage Level Adjustment                  |
|       |      |             | Function: This bus adjusts the high-speed DC    |
|       |      |             | level voltage.                                  |
|       |      |             | 1111: + 8.75%                                   |
|       |      |             | 1110: + 7.5%                                    |
|       |      |             | 1101: + 6.25%                                   |
|       |      |             | 1100: + 5%                                      |
|       |      | 0x6         | 1011: + 3.75%                                   |
| 11:8  | RW   |             | 1010: + 2.5%                                    |
| 11.0  |      |             | 1001: + 1.25%                                   |
|       |      |             | 1000: Design default                            |
|       |      |             | 0111: -1.25%                                    |
|       |      |             | 0110: -2.5%                                     |
|       |      |             | 0101: - 3.75%                                   |
|       |      |             | 0100: - 5%                                      |
|       |      |             | 0011: - 6.25%                                   |
|       |      |             | 0010: - 7.5%                                    |
|       |      |             | 0001: - 8.75%                                   |
|       | 1    |             | 0000: - 10%                                     |
|       |      | · ·         | usbphy_txfsls_tune                              |
|       |      |             | FS/LS Source Impedance Adjustment               |
|       |      |             | Function: This bus adjusts the low- and         |
|       |      |             | full-speed single-ended source                  |
| 7:4   |      |             | impedance while driving high. The following     |
|       | RW   | 0xf         | adjustment values are based on                  |
|       |      |             | nominal process, voltage, and temperature.      |
|       |      |             | 1111: - 5%                                      |
|       |      |             | 0111: -2.5%                                     |
|       |      |             | 0011: Design default                            |
|       |      |             | 0001: + 2.5%                                    |
|       |      |             | 0000: + 5%                                      |



| Bit | Attr | Reset Value | Description                                      |
|-----|------|-------------|--------------------------------------------------|
|     |      |             | usbphy_txfreemphasis_tune                        |
|     |      |             | HS Transmitter Pre-Emphasis Enable               |
|     |      |             | Function: This signal controls the pre-emphasis  |
|     |      |             | for a J-K or K-J state                           |
| 3   | RW   | 0x1         | transition in HS mode.                           |
|     |      |             | 1: The HS Transmitter pre-emphasis is            |
|     |      |             | enabled.                                         |
|     |      |             | 0 (design default): The HS Transmitter           |
|     |      |             | pre-emphasis is disabled                         |
|     |      |             | usbphy_sqrxtune                                  |
|     |      |             | Squelch Threshold Adjustment                     |
|     |      |             | Function: This bus adjusts the voltage level for |
|     |      |             | the threshold used to detect                     |
|     |      |             | valid high-speed data.                           |
|     |      |             | 111: - 20%                                       |
| 2:0 | RW   | 0x3         | 110: -15%                                        |
|     |      |             | 101: -10%                                        |
|     |      |             | 100: -5%                                         |
|     |      |             | 011: Design default                              |
|     |      |             | 010: + 5%                                        |
|     |      |             | 001: + 10%                                       |
|     |      |             | 000: + 15%                                       |

## GRF\_UOC1\_CON2

Address: Operational Base + offset (0x0190)

otg1 control register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                          |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000      | write_enable bit0~bit15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by |
| 15.11 | P.O. | 0.0         | software;  When bit 31=1, bit 15 can be written by software.  When bit 31=0, bit 15 cannot be written by software;                                                                                                                   |
| 15:11 | RO   | 0x0         | reserved                                                                                                                                                                                                                             |



| Bit | Attr  | Reset Value | Description                                     |
|-----|-------|-------------|-------------------------------------------------|
|     |       |             | sleepm                                          |
| 1.0 | RW    | 0×1         | Sleep Assertion                                 |
| 10  | KVV   | UXI         | 1: Normal operating mode                        |
|     |       |             | 0: Sleep mode                                   |
| 9   | RW    | 0×0         | vregtune                                        |
| 9   | KVV   | UXU         | 2.5-V Voltage Regulator HS Boost Adjustment     |
|     |       |             | utmi_termselect                                 |
| 8   | RW    | 0×0         | USB Termination Select                          |
| 0   | IK VV | UXU         | 1: Full-speed terminations are enabled.         |
|     |       |             | 0: High-speed terminations are enabled.         |
|     |       |             | utmi_xcvrselect                                 |
|     |       |             | Transceiver Select                              |
|     |       |             | 11: Sends an LS packet on an FS bus or          |
| 7:6 | RW    | 0x0         | receives an LS packet.                          |
|     |       |             | 10: LS Transceiver                              |
|     |       |             | 01: FS Transceiver                              |
|     |       |             | 00: HS Transceiver                              |
|     |       |             | utmi_opmode                                     |
|     |       |             | UTMI+ Operational Mode                          |
|     |       |             | Function: This controller bus selects the UTMI+ |
|     |       | 0×0         | operational mode.                               |
|     |       |             | 11: Normal operation without SYNC or EOP        |
| 5:4 | RW    |             | generation. If the XCVRSEL bus is               |
| 3.1 |       |             | not set to 00 while OPMODE[1:0] is set to 11,   |
|     |       |             | USB PHY                                         |
|     |       |             | behavior is undefined.                          |
|     |       |             | 10: Disable bit stuffing and NRZI encoding      |
|     |       |             | 01: Non-Driving                                 |
|     | 1     |             | 00: Normal                                      |
|     |       | · ·         | utmi_suspend_n                                  |
| 3   | RW    | 0x1         | Suspend Assertion                               |
|     |       | OXI         | 1: Normal operating mode                        |
|     |       |             | 0: Suspend mode                                 |
| 7   |       |             | usbphy_soft_con_sel                             |
| 2   | RW    | 0x0         | 0: software control usb phy disable             |
|     |       |             | 1 : software control usb phy enable             |



| Bit | Attr | Reset Value | Description                                      |
|-----|------|-------------|--------------------------------------------------|
|     |      |             | usbphy_vbus_vld_extsel                           |
|     |      |             | External VBUS Valid Select                       |
|     |      |             | Function: This signal selects the VBUSVLDEXT     |
|     |      |             | input or the internal Session                    |
| 1   | RW   | 0x0         | Valid comparator to indicate when the VBUS       |
|     |      |             | signal on the USB cable is valid.                |
|     |      |             | 1: The VBUSVLDEXT input is used.                 |
|     |      |             | 0: The internal Session Valid comparator is      |
|     |      |             | used.                                            |
|     |      |             | usbphy_vbus_vld_ext                              |
|     |      |             | External VBUS Valid Indicator                    |
|     |      |             | Function: This signal is valid in Device mode    |
|     |      |             | and only when the                                |
|     |      |             | VBUSVLDEXTSEL signal is set to 1.                |
|     |      |             | VBUSVLDEXT indicates whether the                 |
| 0   | RW   | 0x0         | VBUS signal on the USB cable is valid. In        |
|     |      |             | addition, VBUSVLDEXT enables the pullup          |
|     |      |             | resistor on the D+ line.                         |
|     |      |             | 1: The VBUS signal is valid, and the pull-up     |
|     |      |             | resistor on D+ is enabled.                       |
|     |      |             | 0: The VBUS signal is not valid, and the pull-up |
|     |      |             | resistor on D+ is disabled.                      |

## GRF\_UOC1\_CON3

Address: Operational Base + offset (0x0194)

otg1 control register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                          |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0x0000      | write_enable bit0~bit15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by |
| 15.0  | PO   | 0.0         | software;  When bit 31=1, bit 15 can be written by software.  When bit 31=0, bit 15 cannot be written by software;                                                                                                                   |
| 15:8  | RO   | 0x0         | reserved                                                                                                                                                                                                                             |

| Bit | Attr | Reset Value | Description                                       |
|-----|------|-------------|---------------------------------------------------|
|     |      |             | scaledown                                         |
|     |      |             | Scale-Down Mode                                   |
|     |      |             | 00: Disables all scale-downs. Actual timing       |
|     |      |             | values are used. Required for                     |
|     |      |             | synthesis.                                        |
|     |      | 0×0         | 01: Enables scale-down of all timing values       |
|     |      |             | except Device mode suspend                        |
| 7:6 | RW   |             | and resume. These include:                        |
| 7.0 | IXVV |             | - Speed enumeration.                              |
|     |      |             | - HNP/SRP.                                        |
|     |      |             | - Host mode suspend and resume.                   |
|     |      |             | 10: Enables scale-down of Device mode             |
|     |      |             | suspend and resume timing values                  |
|     |      |             | only.                                             |
|     |      |             | 11: Enables bit 0 and bit 1 scale-down timing     |
|     |      |             | values.                                           |
|     |      | 0×0         | utmiotg_idpullup                                  |
|     |      |             | Analog ID Input Sample Enable                     |
|     | RW   |             | Function: This controller signal controls ID line |
| 5   |      |             | sampling.                                         |
|     |      |             | 1: ID pin sampling is enabled, and the IDDIG      |
|     |      |             | output is valid.                                  |
|     |      |             | 0: ID pin sampling is disabled, and the IDDIG     |
|     |      |             | output is not valid.                              |
| 4   | RW   | 0x1         | utmiotg_dppulldown                                |
|     |      |             | D+ Pull-Down Resistor Enable                      |
| 3   | RW   | 0x1         | utmiotg_dmpulldown                                |
|     |      |             | D- Pull-Down Resistor Enable                      |
| 2   | RW   |             | utmiotg_drvvbus                                   |
|     |      | 0×1         | Drive VBUS                                        |
|     |      |             | 1: The VBUS Valid comparator is enabled.          |
| -0  | u    |             | 0: The VBUS Valid comparator is disabled.         |
| 1   | RW   | 0x0         | utmisrp_chrgvbus                                  |
| 7   |      |             | VBUS Input Charge Enable                          |
| 0   | RW   | 0x0         | utmisrp_dischrgvbus                               |
|     |      |             | VBUS Input Discharge Enable                       |

## GRF\_DDRC\_CON0

Address: Operational Base + offset (0x0198)

DDRC control register

| Bit Attr Reset Value Description |  |
|----------------------------------|--|
|----------------------------------|--|



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                            |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000      | write_enable bit0~ bit15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 cannot be written by software; |
| 15:13 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                               |
| 12:11 | RW   | 0×0         | dto_lb DTO Loopback Enable DTO I/O internal loopback enable                                                                                                                                                                                                                                                                                            |
| 10:9  | RW   | 0×0         | dto_te DTO On-Die Termination Enable DTO I/O on-die termination enable                                                                                                                                                                                                                                                                                 |
| 8:7   | RW   | 0x0         | dto_pdr DTO Power Down Receiver DTO I/O receiver power down                                                                                                                                                                                                                                                                                            |
| 6:5   | RW   | 0×0         | dto_pdd DTO Power Down Driver DTO I/O driver power down                                                                                                                                                                                                                                                                                                |
| 4:3   | RW   | 0×0         | dto_iom DTO I/O Mode DTO I/O mode select                                                                                                                                                                                                                                                                                                               |
| 2:1   | RW   | 0×0         | dto_oe<br>DTO Output Enable<br>DTO I/O output enable                                                                                                                                                                                                                                                                                                   |
| 0     | RW   | 0×0         | ato_ae Analog Test Enable Enables, if set, the analog test output I/O. Connects to the AE pin of the analog test output I/O                                                                                                                                                                                                                            |

## **GRF\_DDRC\_STAT**

Address: Operational Base + offset (0x019c)

DDRC status



| Bit   | Attr | Reset Value | Description                                 |
|-------|------|-------------|---------------------------------------------|
|       |      |             | gpu_idle                                    |
| 31:21 | RW   | 0x000       | gpu idle staus                              |
|       |      |             |                                             |
| 20:19 | RO   | 0x0         | reserved                                    |
|       | RO   | 0×0         | ddrupctl_stat                               |
|       |      |             | Current state of the protocol controller    |
|       |      |             | 3'b000 = Init_mem                           |
| 18:16 |      |             | 3'b001 = Config                             |
|       |      |             | 3'b010 = Config_req                         |
|       |      |             | 3'b011 = Access                             |
|       |      |             | 3'b100 = Access_req                         |
|       |      |             | 3'b101 = Low_power                          |
|       |      |             | 3'b110 = Low_power_entry_req                |
|       |      |             | 3'b111 = Low_power_exit_req                 |
| 15:0  | RO   | 0×0000      | ddrupctl_bbflags                            |
|       |      |             | Bank busy indication                        |
|       |      |             | NIF output vector which provides combined   |
|       |      |             | information about the status of each memory |
|       |      |             | bank. The de-assertion is based on when     |
|       |      |             | precharge, activates, reads/writes.         |
|       |      |             | Bit0 indication Bank0 busy, bit1 indication |
|       |      |             | Bank1 busy, and so on.                      |

## GRF\_OS\_REG0

Address: Operational Base + offset (0x01c8)

software OS register

| Bit      | Attr | Reset Value | Description                                         |
|----------|------|-------------|-----------------------------------------------------|
|          |      |             | write_enable                                        |
|          | 1    |             | bit0~bit15 write enable                             |
|          |      | Y           | When bit 16=1, bit 0 can be written by software.    |
| 2        |      |             | When bit 16=0, bit 0 cannot be written by software; |
| <b>*</b> |      |             | When bit 17=1, bit 1 can be written by              |
| 31:16    | WO   | 0x0000      | software .                                          |
|          |      |             | When bit 17=0, bit 1 cannot be written by software; |
|          |      |             |                                                     |
|          |      |             | When bit 31=1, bit 15 can be written by software.   |
|          |      |             | When bit 31=0, bit 15 cannot be written by          |
|          |      |             | software;                                           |



| Bit  | Attr | Reset Value | Description                    |
|------|------|-------------|--------------------------------|
| 15:0 | RW   | 0×0000      | os_reg<br>software OS register |

#### **GRF\_OS\_REG1**

Address: Operational Base + offset (0x01cc)

software OS register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 31:16 | wo   | 0×0000      | write_enable bit0~bit15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software . When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software . When bit 31=1, bit 15 can be written by software; |  |  |  |  |
| 15:0  | RW   | 0x0000      | os_reg<br>software OS register                                                                                                                                                                                                                                                                                                                       |  |  |  |  |

# GRF\_OS\_REG2

Address: Operational Base + offset (0x01d0)

software OS register

| 33.3.3.3.2.2.2. |     |      |             |             |  |  |
|-----------------|-----|------|-------------|-------------|--|--|
|                 | Bit | Attr | Reset Value | Description |  |  |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 31:16 | wo   | 0×0000      | write_enable bit0~bit15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 cannot be written by software; |  |  |  |  |
| 15:0  | RW   | 0x0000      | os_reg<br>software OS register                                                                                                                                                                                                                                                                                                                        |  |  |  |  |

# GRF\_OS\_REG3

Address: Operational Base + offset (0x01d4)

software OS register

| software;                              | Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                            |
|----------------------------------------|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                        |      | 7    | 37.79       | write_enable bit0~bit15 write enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by |
| os_reg   os_reg   software OS register | 15:0 | RW   | 0×0000      | os_reg                                                                                                                                                                                                                                                                                 |

# **Chapter 8 Embedded Processor: Cortex-A9**

#### 8.1 Overview

The Cortex<sup>™</sup>-A9 MP subsystem of the device is based on the symmetric multiprocessor (SMP) architecture, thus the dual Cortex-A9 MPU subsystem delivers higher performance and optimal power management, debug and emulation capabilities.

The Cortex-A9 MP subsystem incorporates two Cortex-A9 central processing units (CPUs), level 2(L2) cache shared between the two CPUs, and uses PL310 as L2 cache controller. Each CPU has 32KBof level 1 (L1) instruction cache, 32KB of L1 data cache, separate dedicated power domain, and includes one Neon<sup>TM</sup> and Vector Floating Point Unit (VFPv3) coprocessors. The Cortex-A9 MP subsystemalso includes standard CoreSight<sup>TM</sup> components to support SMP debug and emulation, snoop control unit(SCU), interrupt controller (GIC), and clock and reset manager.

The Cortex-A9 MP subsystem supports following feature:

- Coretex-A9 Processor
  - Cortex-A9 core revision r3p0
  - SMP architecture
  - Superscalar, variable length, out-of-order pipeline with dynamic branch prediction, 8-stage pipeline
  - Full implementation of the ARM architecture v7-A instruction setARM Neon Advanced SIMD (single instruction, multiple data) support for accelerated media and signal processing computation.
  - Include VFPv3 hardware to support single and double-precision add, subtract, divide, multiply andaccumulate, and square root operations.
  - 32KB L1 instruction and 32KB L1 data cache 32-byte line size, 4-way set associative
  - Memory management unit (MMU)
  - SCU ensures memory coherency between the two CPUs
  - Integrated timer and watchdog timer per CPU
  - Interrupt controller with 128 hardware interrupt inputs
- PL310 L2 cache controller (revision r3p2) with 512KB cache size
  - 16-way set associative
  - 32-byte line size
  - Two slave ports and two master ports
  - Includes four 256-bit line-fill-buffers (LFBs) shared by the master ports
  - Each slave port includes two 256-bit line-read-buffers (LRBs)
  - Includes four 256-bit store buffers with merge capability
  - Lockdown by line supported
  - Lockdown by master ID supported
  - Speculative Read supported
  - Address filter
- CoreSight
  - Program trace macrocell (PTM)
  - Emulation logic (cross-triggers)
  - TPIU and AMBA advanced trace bus (ATB) trace port



# 8.2 Block Diagram

Fig. 8-1MP Subsystem architecture

PL310

# 8.3 Function description

The SCU connects dual Cortex-A9 processors to the memory system through the AXI interfaces. The SCU functions are tomaintain data cache coherency between the Cortex-A9 processors; initiate L2 AXI memory accesses; arbitrate between Cortex-A9 processors requesting L2 accesses.

The Interrupt Controller is compliant with the ARM Generic Interrupt Controller Architecture Specification 1.0. Please refer to Chapter 12 GIC.

The global timer is accessible to all Cortex-A9 processors in the cluster. Each Cortex-A9 processor has a private 64-bit comparator that is used to assert a private interrupt when the global timer has reached the comparator value. All the Cortex-A9 processors in a design use the banked ID, ID27, for this interrupt. ID27 is sent to the GIC as a Private Peripheral Interrupt. The global timer is a 64-bit incrementing counter with an auto-incrementing feature. It continues incrementing after sending interrupts.

The private timer and watchdog can only be accessed by the corresponding processor. It has a 32-bit counter that generates an interrupt when it reaches zero.

# 8.4 Register description

### 8.4.1 Registers Summary

**Cortex-A9 MP SCU Registers Summary** 

| Name        | Offset             | Size | Reset           | Description                               |  |  |  |  |
|-------------|--------------------|------|-----------------|-------------------------------------------|--|--|--|--|
| MP SCU CTRL | 0×0000 W 0×0000000 |      | 0×00000000      | Global timer counter low                  |  |  |  |  |
| MP_SCU_CTRL |                    |      | 32bits register |                                           |  |  |  |  |
| MD CCIL CEC | 0x0004             |      |                 |                                           |  |  |  |  |
| MP_SCU_CFG  | UXUUU4             | VV   | 000000000       | Global timer counter high 32bits register |  |  |  |  |



| Name                | Offset                          | Size | Reset                   | Description             |
|---------------------|---------------------------------|------|-------------------------|-------------------------|
| MP_SCU_PWR_STATUS   | 0x0008                          | ۱۸/  | 0x00000000              | Global timer control    |
| MF_3CO_FWK_3TATO3   | 0,0000                          | VV   | 0x00000000              | register                |
| MP_SCU_INVALIDATE   | 0x000c                          | ۱۸/  | 0x00000000              | Global timer interrupt  |
| MF_SCO_INVALIDATE   | UXUUUC                          | VV   | 0x00000000              | status register         |
| MP_SCU_FILTER_START | 020010                          | ۱۸/  | 0x00000000              | Global timer comparator |
| MF_3CU_IILILK_3TAKT | 000010                          | VV   | 0x00000000              | low 32bits register     |
| MP SCU FILTER END   | U FILTER END 0x0014 W 0x0000000 |      | Global timer comparator |                         |
| MP_SCO_LILILK_LIND  | 00014                           | VV   | 0x00000000              | high 32bits register    |
| MP SCU SAC          | 0x0018                          | ۱۸/  | 0x00000000              | Global timer auto       |
| MF_SCO_SAC          | 0,0010                          | VV   | 0x0000000               | increment register      |
| MP SCU SNSAC        | 0x001c                          | ۱۸/  | 0x00000000              | Global timer auto       |
| INF_3CU_SINSAC      | OXUUIC                          | VV   |                         | increment register      |

# **Cortex-A9 MP Global Timer Registers Summary**

| Name                   | Offset | Size | Reset<br>Value | Description                                        |
|------------------------|--------|------|----------------|----------------------------------------------------|
| MP_GTIMER_COUNTER_LOW  | 0x0000 | W    | 0x00000000     | Global timer counter low 32bits register           |
| MP_GTIMER_COUNTER_HIGH | 0x0004 | W    | 0x00000000     | Global timer counter high 32bits register          |
| MP_GTIMER_CONTROL      | 0x0008 | w    | 0x00000000     | Global timer control register                      |
| MP_GTIMER_INT_STATUS   | 0x000c | W    | 0×00000000     | Global timer interrupt status register             |
| MP_GTIMER_COMPARE_LOW  | 0x0010 | W    | 0×00000000     | Global timer<br>comparator low<br>32bits register  |
| MP_GTIMER_COMPARE_HIGH | 0x0014 | W    | 0×00000000     | Global timer<br>comparator high<br>32bits register |
| MP_GTIMER_AUTO_INCR    | 0x0018 | W    | 0×00000000     | Global timer auto increment register               |

# **Cortex-A9 MP Private Timer Registers Summary**

| Name                    | Offset | Size | Reset<br>Value | Description                    |
|-------------------------|--------|------|----------------|--------------------------------|
| MP_PTIMER_TIMER_LOAD    | 0x0000 | W    | 0x00000000     | Private timer load register    |
| MP_PTIMER_TIMER_COUNTER | 0x0004 | W    | 0×00000000     | Private timer counter register |



| Name                       | Offset | Size | Reset<br>Value | Description                                         |
|----------------------------|--------|------|----------------|-----------------------------------------------------|
| MP_PTIMER_TIMER_CONTROL    | 0x0008 | W    | 0x00000000     | Private timer control register                      |
| MP_PTIMER_TIMER_INT_STATUS | 0x000c | W    | 0x00000000     | Private timer interrupt status register             |
| MP_PTIMER_WDT_LOAD         | 0x0020 | W    | 0×00000000     | Private<br>watchdogload<br>register                 |
| MP_PTIMER_WDT_COUNTER      | 0x0024 | W    | 0x00000000     | Private<br>watchdog<br>counter register             |
| MP_PTIMER_WDT_CONTROL      | 0x0028 | W    | 0x00000000     | Private<br>watchdog<br>control register             |
| MP_PTIMER_WDT_INT_STATUS   | 0x002c | w    | 0x00000000     | Private<br>watchdog<br>interrupt status<br>register |
| MP_PTIMER_WDT_RESET_STATUS | 0x0030 | W    | 0x00000000     | Private<br>watchdog reset<br>status register        |
| MP_PTIMER_WDT_DISABLE      | 0x0034 | W    | 0×00000000     | private<br>watchdog<br>disable                      |

# **L2C Registers Summary**

| Name                      | Offset | Size | Reset<br>Value | Description                           |
|---------------------------|--------|------|----------------|---------------------------------------|
| L2C_reg0_cache_id         | 0x0000 | W    | 0x410000c6     | Cache ID Register                     |
| L2C_reg0_cache_type       | 0x0004 | W    | 0x00000000     | Cache Type<br>Register                |
| L2C_reg1_control          | 0x0100 | W    | 0x0000000      |                                       |
| L2C_reg1_aux_control      | 0x0104 | W    | 0×00000000     | Auxiliary Control<br>Register         |
| L2C_reg1_tag_ram_control  | 0x0108 | W    | 0x00000000     | Tag RAM Latency<br>Control Registers  |
| L2C_reg1_data_ram_control | 0x010c | W    | 0x00000000     | Data RAM Latency<br>Control Registers |
| L2C_reg2_ev_counter_ctrl  | 0x0200 | W    | 0x00000000     | Event Counter<br>Control Register     |



|                          |        |      | Reset      |                 |
|--------------------------|--------|------|------------|-----------------|
| Name                     | Offset | Size | Value      | Description     |
|                          |        |      |            | Event Counter   |
| L2C_reg2_ev_counter1_cfg | 0x0204 | W    | 0x00000000 | Configuration   |
|                          |        |      |            | Registers       |
|                          |        |      |            | Event Counter   |
| L2C_reg2_ev_counter0_cfg | 0x0208 | W    | 0x00000000 | Configuration   |
|                          |        |      |            | Registers       |
| L2C_reg2_ev_counter1     | 0x020c | w    | 0x00000000 | Event counter   |
|                          | 0,0200 | ••   |            | value registers |
| L2C_reg2_ev_counter0     | 0x0210 | w    | 0x00000000 | Event counter   |
|                          |        |      |            | value registers |
| L2C_reg2_int_mask        | 0x0214 | W    | 0x00000000 |                 |
| L2C_reg2_int_mask_status | 0x0218 |      | 0x00000000 | X               |
| L2C_reg2_int_raw_status  | 0x021c | 1    | 0x00000000 |                 |
| L2C_reg2_int_clear       | 0x0220 | W    | 0x0000000  | <b>Y</b>        |
| L2C_reg7_cache_sync      | 0x0730 | W    | 0x0000000  | )               |
| L2C_reg7_inv_pa          | 0x0770 | W    | 0x0000000  |                 |
| L2C_reg7_inv_way         | 0x077c | W    | 0x0000000  |                 |
| L2C_reg7_clean_pa        | 0x07b0 | W    | 0x00000000 |                 |
| L2C_reg7_clean_index     | 0x07b8 | W    | 0x0000000  |                 |
| L2C_reg7_clean_way       | 0x07bc | W    | 0x0000000  |                 |
| L2C_reg7_clean_inv_pa    | 0x07f0 | W    | 0x0000000  |                 |
| L2C_reg7_clean_inv_index | 0x07f8 | W    | 0x0000000  |                 |
| L2C_reg7_clean_inv_way   | 0x07fc | W    | 0x0000000  |                 |
| L2C_reg9_d_lockdown0     | 0x0900 | W    | 0x00000000 |                 |
| L2C_reg9_i_lockdown0     | 0x0904 | W    | 0x00000000 |                 |
| L2C_reg9_d_lockdown1     | 0x0908 | W    | 0x00000000 |                 |
| L2C_reg_i_lockdown1      | 0x090c | W    | 0x0000000  |                 |
| L2C_reg9_d_lockdown2     | 0x0910 | W    | 0x0000000  |                 |
| L2C_reg9_i_lockdown2     | 0x0914 | W    | 0x0000000  |                 |
| L2C_reg9_d_lockdown3     | 0x0918 | W    | 0x0000000  |                 |
| L2C_reg9_i_lockdwon3     | 0x091c | W    | 0x0000000  |                 |
| L2C_reg9_d_lockdown4     | 0x0920 | W    | 0x0000000  |                 |
| L2C_reg9_i_lockdwon4     | 0x0924 | W    | 0x00000000 |                 |
| L2C_reg9_d_lockdwon5     | 0x0928 | W    | 0x0000000  |                 |
| L2C_reg9_i_lockdwon5     | 0x092c | W    | 0x00000000 |                 |
| L2C_reg9_d_lockdwon6     | 0x0930 | W    | 0x0000000  |                 |
| L2C_reg9_i_lockdwon6     | 0x0934 | W    | 0x00000000 |                 |
| L2C_reg9_d_lockdwon7     | 0x0938 | W    | 0x0000000  |                 |
| L2C_reg9_i_lockdwon7     | 0x093c | W    | 0x00000000 |                 |
| L2C_reg9_lock_line_en    | 0x0950 | W    | 0×00000000 |                 |
|                          | L      | l    |            |                 |



| Name                           | Offset | Size | Reset<br>Value | Description                  |
|--------------------------------|--------|------|----------------|------------------------------|
| L2C_reg9_unlock_way            | 0x0954 | W    | 0x0000000      |                              |
| L2C_reg12_addr_filtering_start | 0x0c00 | W    | 0x0000000      |                              |
| L2C_reg12_addr_filtering_end   | 0x0c04 | W    | 0x0000000      |                              |
| L2C_reg15_debug_ctrl           | 0x0f40 | W    | 0x0000000      | Debug Register o             |
| L2C_reg15_prefetch_ctrl        | 0x0f60 | W    | 0x00000000     | Prefetch Control<br>Register |
| L2C_reg15_power_ctrl           | 0x0f80 | W    | 0×00000000     | Power Control<br>Register    |

### 8.4.2 Detail Registers Description

### MP\_SCU\_CTRL

Address: Operational Base + offset (0x0000)

SCU Control Register

|      | SCU Control Register |             |                                                 |
|------|----------------------|-------------|-------------------------------------------------|
| Bit  | Attr                 | Reset Value | Description                                     |
| 31:7 | RO                   | 0x0         | reserved                                        |
|      |                      |             | ic_standby_en                                   |
| 6    | RW                   | 0x0         | when set, this stops the Interrupt Controller   |
|      |                      | o x o       | clock when no interrupts are pending, and no    |
|      |                      |             | CPU is performing a read/write request.         |
|      |                      |             | scu_stanby_en                                   |
|      |                      |             | When set, SCU CLK is turned off when all        |
| 5    | RW                   | 0×0         | processors are in WFI mode, and there is no     |
|      | IXVV                 | 0.00        | remaining activity in the SCU.                  |
|      |                      | * \         | The clock is turned on when any processor       |
|      |                      | 10 Y        | leaves WFI mode.                                |
|      |                      | 0×0         | force all device to port0 enable                |
| 4    | RW                   |             | When set, all requests from processors with     |
| _    |                      |             | AxCACHE = NonCacheable Bufferable are           |
|      |                      |             | forced to be issued on the AXI Master port M0.  |
|      |                      |             | scu speculative linefills enable                |
|      |                      |             | When set, coherent linefill requests are sent   |
|      |                      | 0×0         | speculatively to the L2C-310 in parallel with   |
|      |                      |             | the tag look-up. If the tag look-up misses, the |
| 3    | RW                   |             | confirmed linefill is sent to the L2C-310 and   |
|      |                      |             | gets RDATA earlier because the data request     |
|      |                      |             | was already initiated by the speculative        |
|      |                      |             | request. This feature works only if the         |
|      |                      |             | L2C-310 is present in the design.               |



| Bit | Attr | Reset Value | Description                                      |
|-----|------|-------------|--------------------------------------------------|
|     |      |             | scu rams parity enable                           |
|     |      |             | 1 = Parity on.                                   |
| 2   | RW   | 0x0         | 0 = Parity off. This is the default setting.     |
|     |      |             | This bit is always zero if support for parity is |
|     |      |             | not implemented.                                 |
|     |      |             | address filtering enable                         |
|     |      |             | 1 = Addressing filtering on.                     |
| 1   | RW   | 0x0         | 0 = Addressing filtering off.                    |
|     |      |             | The default value is the value of FILTEREN       |
|     |      |             | sampled when nSCURESET is deasserted.            |
| 0   | RW   | 0x0         | 1 = SCU enable.                                  |
| UK  | KVV  |             | 0 = SCU disable. This is the default setting.    |

MP\_SCU\_CFG Address: Operational Base + offset (0x0004)

SCU Configuration Register

| Bit      | Attr  | Reset Value                             | Description                                  |
|----------|-------|-----------------------------------------|----------------------------------------------|
| 31:16    | RO    | 0x0                                     | reserved                                     |
|          |       |                                         | tagram_size                                  |
|          |       |                                         | Bits [11:10] indicate Cortex-A9 processor    |
|          |       |                                         | CPU1 tag RAM size if present.                |
|          |       |                                         | Bits [9:8] indicate Cortex-A9 processor CPU0 |
| 15:8     | RW    | 0×00                                    | tag RAM size.                                |
| 13.6     | IK VV | UXUU                                    | The encoding is as follows:                  |
|          |       | • (1)                                   | b11 = reserved                               |
|          |       | \ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \ | b10 = 64KB cache, 256 indexes per tag RAM    |
|          |       |                                         | b01 = 32KB cache, 128 indexes per tag RAM    |
|          |       |                                         | b00 = 16KB cache, 64 indexes per tag RAM.    |
|          | RW    | 0x0                                     | cpus_smp                                     |
|          |       |                                         | 0 = this Cortex-A9 processor is in AMP mode  |
|          |       |                                         | not taking part in coherency or not present. |
| 7:4      |       |                                         | 1 = this Cortex-A9 processor is in SMP mode  |
|          |       |                                         | taking part in coherency.                    |
| <b>Y</b> |       |                                         | Bit 5 is for CPU1                            |
|          |       |                                         | Bit 4 is for CPU0.                           |
| 3:2      | RO    | 0x0                                     | reserved                                     |
|          |       |                                         | cpu_numbers                                  |
| 1:0      | RW    | 0x0                                     | Number of CPUs present in the Cortex-A9      |
|          |       |                                         | MPCore processor                             |
|          |       |                                         | b01 = two Cortex-A9 processors, CPU0 and     |
|          |       |                                         | CPU1                                         |
|          |       |                                         | b00 = one Cortex-A9 processor, CPU0.         |



#### MP\_SCU\_PWR\_STATUS

Address: Operational Base + offset (0x0008)

SCU CPU Power Status Register

| Bit      | Attr   | Reset Value                              | Description                              |
|----------|--------|------------------------------------------|------------------------------------------|
| 31:10    | RO     | 0x0                                      | reserved                                 |
| 0.8      | 9:8 RW | (()X()                                   | cpu1_status                              |
| 9.0      |        |                                          | Power status of the Cortex-A9 processor. |
| 7:2      | RO     | 0x0                                      | reserved                                 |
| 1:0 RW 0 | 0x0    | cpu0_status                              |                                          |
|          |        | Power status of the Cortex-A9 processor. |                                          |

#### MP\_SCU\_INVALIDATE

Address: Operational Base + offset (0x000c)

SCU Invalidate All Registers

| Bit   | Attr | Reset Value | Description                                                                                                                                                          |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                                                                                                                                             |
| 7:4   | RW   | 0x0         | cpu1_ways Specifies the ways that must be invalidated for CPU1. Writing to these bits has no effect if the Cortex-A9 MPCore processor has fewer than two processors. |
| 3:0   | RW   | 0x0         | cpu0_ways Specifies the ways that must be invalidated for CPU0.                                                                                                      |

#### MP\_SCU\_FILTER\_START

Address: Operational Base + offset (0x0010)

Filtering Start Address Register

| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
|       |      | 7           | filter start address                          |
|       |      |             | Start address for use with master port 1 in a |
|       |      | 0×000       | two-master port configuration when address    |
| 24 20 | RW   |             | filtering is enabled.                         |
| 31:20 |      |             | The default value is the value of             |
|       |      |             | FILTERSTART sampled on exit from reset.       |
|       |      |             | The value on the pin gives the upper address  |
|       |      |             | bits with 1MB granularity.                    |
| 19:0  | RO   | 0x000       | reserved                                      |

#### MP\_SCU\_FILTER\_END

Address: Operational Base + offset (0x0014)

Filtering End Address Register

|     | r moorming and resulting to the groups |             |             |  |  |  |
|-----|----------------------------------------|-------------|-------------|--|--|--|
| Bit | Attr                                   | Reset Value | Description |  |  |  |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                     |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | RW   | 0×000       | filter end address End address for use with master port 1 in a two-master port configuration, whenaddress filtering is enabled. The default value is the value of FILTEREND sampled on exit from reset. The value on the pin gives the upper address bits with 1MB granularity. |
| 19:0  | RO   | 0x000       | reserved                                                                                                                                                                                                                                                                        |

# MP\_SCU\_SAC

Address: Operational Base + offset (0x0018)

SCU Access Control Register

| Bit  | Attr | Reset Value           | Description                                 |
|------|------|-----------------------|---------------------------------------------|
| 31:4 | RO   | 0x0                   | reserved                                    |
| 3    | RW   | 0x0                   | cpu3 access                                 |
|      |      |                       | Field0002 Description                       |
| 2    | 2 RW | 0x0                   | cpu2 access                                 |
| Z    | UXU  | Field0001 Description |                                             |
|      |      |                       | cpu1 access                                 |
| 1    | RW   | 0.40                  | 0 = CPU1 cannot access the components.      |
| 1    | KVV  | 0x0                   | 1 = CPU1 can access the components. This is |
|      |      |                       | the default.                                |
|      |      |                       | cpu0 access                                 |
|      | DW   | 0x0                   | 0 = CPU0 cannot access the components.      |
| 0    | RW   |                       | 1 = CPU0 can access the components. This is |
|      |      |                       | the default.                                |

# MP\_SCU\_SNSAC

Address: Operational Base + offset (0x001c) SCU Non-secure Access Control Register

| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
| 31:12 | RO   | 0x0         | reserved                                      |
|       |      |             | global access controll for CPU <n></n>        |
|       |      |             | Non-secure access to the global timer for     |
|       |      |             | CPU <n>.</n>                                  |
|       |      |             | <n> is 1 for bit[1]</n>                       |
| 11:8  | RW   | 0x0         | <n $>$ is 0 for bit[0].                       |
|       |      |             | 0 = Secure accesses only. This is the default |
|       |      |             | value.                                        |
|       |      |             | 1 = Secure accesses and Non-Secure            |
|       |      |             | accesses.                                     |



| Bit | Attr | Reset Value | Description                                |
|-----|------|-------------|--------------------------------------------|
|     |      |             | private access controll for CPU <n></n>    |
|     |      |             | Non-secure access to the private timer and |
|     |      |             | watchdog for CPU <n>.</n>                  |
|     |      |             | <n> is 1 for bit[1]</n>                    |
| 7:4 | RW   | 0x0         | <n> is 0 for bit[0].</n>                   |
|     |      |             | 0 = Secure accesses only. Non-secure reads |
|     |      |             | return 0. This is the default value.       |
|     |      |             | 1 = Secure accesses and Non-secure         |
|     |      |             | accesses.                                  |
|     |      |             | component access control for CPU <n></n>   |
|     |      |             | Non-secure access to the components for    |
|     |      | 0x0         | CPU <n>.</n>                               |
| 3:0 | RW   |             | <n> is 1 for bit[1]</n>                    |
|     |      |             | <n> is 0 for bit[0].</n>                   |
|     |      |             | 0 = CPU cannot write the componentsa       |
|     |      |             | 1 = CPU can access the componentsa.        |

### MP\_GTIMER\_COUNTER\_LOW

Address: Operational Base + offset (0x0000) Global timer counter low 32bits register \( \infty

| Bit  | Attr | Reset Value | Description                              |
|------|------|-------------|------------------------------------------|
| 31:0 | RW   | 10×00000000 | load lower 32-bit timer counter register |

# MP\_GTIMER\_COUNTER\_HIGH

Address: Operational Base + offset (0x0004) Global timer counter high 32bits register

| Bit  | Attr | Reset Value | Description                                 |  |
|------|------|-------------|---------------------------------------------|--|
| 31:0 | RW   | 0x00000000  | counter upper 32-bit timer counter register |  |

### MP\_GTIMER\_CONTROL

Address: Operational Base + offset (0x0008)

Global timer control register

| Bit   | Attr | Reset Value | Description                                     |
|-------|------|-------------|-------------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                        |
|       |      |             | prescaler                                       |
| 15:8  | RW   | 0x00        | The prescaler modifies the clock period for the |
|       |      |             | decrementing event for the Counter Register.    |
| 7:4   | RO   | 0x0         | reserved                                        |

| Bit | Attr | Reset Value | Description                                      |
|-----|------|-------------|--------------------------------------------------|
|     |      |             | auto increment                                   |
|     |      |             | This bit is banked per Cortex-A9 processor.      |
|     |      |             | 1'b0: single shot mode.                          |
|     |      |             | When the counter reaches the comparator          |
|     |      |             | value, sets the event flag. It is the            |
|     |      |             | responsibility of software to update the         |
| 3   | RW   | 0x0         | comparator value to get further events.          |
|     |      |             | 1'b1: auto increment mode.                       |
|     |      |             | Each time the counter reaches the comparator     |
|     |      |             | value, the comparator register is incremented    |
|     |      |             | with the auto-increment register, so that        |
|     |      |             | further events can be set periodically without   |
|     |      |             | any software updates.                            |
|     |      |             | IRQ enable                                       |
|     |      |             | This bit is banked per Cortex-A9 processor.      |
| 2   | RW   | 0x0         | If set, the interrupt ID 27 is set as pending in |
|     |      |             | the Interrupt Distributor when the event flag is |
|     |      |             | set in the Timer Status Register                 |
|     |      |             | compare enable                                   |
|     |      |             | This bit is banked per Cortex-A9 processor.      |
| 1   | RW   | 0x0         | If set, it allows the comparison between the     |
|     |      |             | 64-bit Timer Counter and the related 64-bit      |
|     |      |             | Comparator Register.                             |
|     |      |             | Timer enable                                     |
|     |      | • ()        | 1'b0 = Timer is disabled and the counter does    |
| 0   | RW   | 0x0         | not increment.                                   |
|     |      |             | All registers can still be read and written      |
|     |      | ()          | 1'b1 = Timer is enabled and the counter          |
|     | A 1  |             | increments normally                              |

# MP\_GTIMER\_INT\_STATUS

Address: Operational Base + offset (0x000c)

Global timer interrupt status register

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:1 | RO   | 0x0         | reserved    |



| Attr              | Reset Value      | Description                                                                                                                                                                                                 |
|-------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Attr</b><br>RW | Reset Value  0x0 | event flag This is a banked register for all Cortex-A9 processors present. The event flag is a sticky bit that is automatically set when the Counter Register reaches the Comparator Register value. If the |
|                   |                  | timer interrupt is enabled, Interrupt ID 27 is set as pending in the Interrupt Distributor                                                                                                                  |
|                   |                  | after the event flag is set. The event flag is cleared when written to 1.                                                                                                                                   |
|                   |                  |                                                                                                                                                                                                             |

#### MP\_GTIMER\_COMPARE\_LOW

Address: Operational Base + offset (0x0010)Global timer comparator low 32bits register

| Bit  | Attr | Reset Value | Description                            |
|------|------|-------------|----------------------------------------|
| 31:0 | RW   | 0x0000000   | lower 32-bit Comparator Value Register |

#### MP\_GTIMER\_COMPARE\_HIGH

Address: Operational Base + offset (0x0014)Global timer comparator high 32bits register

| Bit  | Attr | Reset Value | Description                            |
|------|------|-------------|----------------------------------------|
| 31:0 | RW   | 0x00000000  | upper 32-bit Comparator Value Register |

# MP\_GTIMER\_AUTO\_INCR

Address: Operational Base + offset (0x0018)Global timer auto increment register

**Reset Value** Bit Attr **Description** Autoincrement This 32-bit register gives the increment value of the Comparator Register when the Auto-increment bit is set in the Timer Control Register. Each Cortex-A9 processor present has its own Auto-increment Register. 31:0 RW 0x00000000 If the comp enable and auto-increment bits are set when the global counter reaches the Comparator Register value, the comparator is incremented by the auto-increment value, so that a new event can be set periodically. The global timer is not affected and goes on incrementing.

#### MP\_PTIMER\_TIMER\_LOAD

Address: Operational Base + offset (0x0000)



Private timer load register

| Bit  | Attr | Reset Value Description |                                                                                                                                                                                                                                            |
|------|------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0×00000000              | The Timer Load Register contains the value copied to the Timer Counter Register when it decrements down to zero with auto reload mode enabled. Writing to the Timer Load Register means that you also write to the Timer Counter Register. |

# MP\_PTIMER\_TIMER\_COUNTER

Address: Operational Base + offset (0x0004)

Private timer counter register

| Bit  | Attr | Reset Value | Desc    | cription |
|------|------|-------------|---------|----------|
| 31:0 | RW   | 0x00000000  | counter | X        |

# MP\_PTIMER\_TIMER\_CONTROL

Address: Operational Base + offset (0x0008)

Private timer control register

| Bit   | Attr | Reset Value | Description                                      |
|-------|------|-------------|--------------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                         |
|       |      |             | prescaler                                        |
| 15:8  | RW   | 0x00        | The prescaler modifies the clock period for the  |
|       |      |             | decrementing event for the Counter Register.     |
| 7:3   | RO   | 0x0         | reserved                                         |
|       |      |             | IRQ enable                                       |
| 2     | RW   | 0x0         | If set, the interrupt ID 29 is set as pending in |
| _     | IXVV | 0.00        | the Interrupt Distributor when the event flag    |
|       |      |             | is set in the Timer Status Register              |
|       | RW   | 0x0         | auto reload                                      |
|       |      |             | 1'b0 = Single shot mode.                         |
|       |      |             | Counter decrements down to zero, sets the        |
| 1 (   |      |             | event flag and stops.                            |
|       |      |             | 1'b1 = Auto-reload mode.                         |
|       |      |             | Each time the Counter Register reaches zero,     |
| 7     |      |             | it is reloaded with the value contained in the   |
|       |      |             | Timer Load Register.                             |
|       |      | 0x0         | Timer enable                                     |
|       |      |             | 1'b0 = Timer is disabled and the counter does    |
| 0     | RW   |             | not decrement.                                   |
|       | KVV  |             | All registers can still be read and written      |
|       |      |             | 1'b1 = Timer is enabled and the counter          |
|       |      |             | decrements normally                              |



MP\_PTIMER\_TIMER\_INT\_STATUS Address: Operational Base + offset (0x000c)

Private timer interrupt status register

| Bit  | Attr | Reset Value | Description                                        |  |
|------|------|-------------|----------------------------------------------------|--|
| 31:1 | RO   | 0x0         | reserved                                           |  |
|      |      |             | event flag                                         |  |
|      |      |             | The event flag is a sticky bit that is             |  |
|      |      |             | automatically set when the Counter Register        |  |
| 0    | RW   | 0x0         | reaches zero. If the timer interrupt is enabled,   |  |
|      |      |             | Interrupt ID 29 is set as pending in the           |  |
|      |      |             | Interrupt Distributor after the event flag is set. |  |
|      |      |             | The event flag is cleared when written to 1.       |  |

### MP\_PTIMER\_WDT\_LOAD

Address: Operational Base + offset (0x0020)

Private watchdogload register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                          |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0×00000000  | The Watchdog Load Register contains the value copied to the Watchdog Counter Register when it decrements down to zero with auto reload mode enabled, in Timer mode. Writing to the Watchdog Load Register means that you also write to the Watchdog Counter Register |

# MP\_PTIMER\_WDT\_COUNTER

Address: Operational Base + offset (0x0024)

Private watchdog counter register

| Bit  | Attr | Reset Value | Description                              |
|------|------|-------------|------------------------------------------|
| 31:0 | RW   |             | It decrements if the Watchdog is enabled |
|      |      |             | using the Watchdog enable bit in the     |
|      |      | 7           | Watchdog Control Register.               |

### MP\_PTIMER\_WDT\_CONTROL

Address: Operational Base + offset (0x0028)

Private watchdog control register

| Bit   | Attr | Reset Value | Description                                                                                  |
|-------|------|-------------|----------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                                                                     |
| 15:8  | RW   | I()X()()    | The prescaler modifies the clock period for the decrementing event for the Counter Register. |
| 7:4   | RO   | 0x0         | reserved                                                                                     |



| Bit | Attr | Reset Value | Description                                      |
|-----|------|-------------|--------------------------------------------------|
|     |      |             | watchdog mode                                    |
|     |      |             | 1'b0 = Timer mode, default                       |
| 3   | RW   | 0×0         | Writing a zero to this bit has no effect. You    |
| 3   | KVV  | UXU         | must use the Watchdog Disable Register to        |
|     |      |             | put the watchdog into timer mode.                |
|     |      |             | 1'b1 = Watchdog mode                             |
|     |      |             | IT enable                                        |
|     |      |             | If set, the interrupt ID 30 is set as pending in |
| 2   | RW   | 0x0         | the Interrupt Distributor when the event flag is |
|     |      |             | set in the watchdog Status Register.             |
|     |      |             | In watchdog mode this bit is ignored             |
|     |      |             | auto reload                                      |
|     |      |             | 1'b0 = Single shot mode.                         |
|     |      |             | Counter decrements down to zero, sets the        |
|     |      |             | event flag and stops.                            |
| 1   | RW   | 0x0         | 1'b1 = Auto-reload mode.                         |
|     |      |             | Each time the Counter Register reaches zero,     |
|     |      |             | it is reloaded with the value contained in the   |
|     |      |             | Load Register and then continues                 |
|     |      |             | decrementing.                                    |
|     |      |             | watchdog enable                                  |
|     |      |             | Global watchdog enable                           |
|     |      |             | 1'b0 = Watchdog is disabled and the counter      |
| 0   | RW   | 0x0         | does not decrement. All registers can still be   |
|     |      | . ()        | read and /or written                             |
|     |      | 1           | 1'b1 = Watchdog is enabled and the counter       |
|     |      | My y        | decrements normally                              |

# MP\_PTIMER\_WDT\_INT\_STATUS

Address: Operational Base + offset (0x002c)
Private watchdog interrupt status register

| Bit      | Attr | Reset Value | Description                                      |
|----------|------|-------------|--------------------------------------------------|
| 31:1     | RO   | 0x0         | reserved                                         |
| <b>Y</b> |      |             | event flag                                       |
|          |      | 0×0         | The event flag is a sticky bit that is           |
|          | RW   |             | automatically set when the Counter Register      |
|          |      |             | reaches zero in timer mode. If the watchdog      |
| 0        |      |             | interrupt is enabled, Interrupt ID 30 is set as  |
|          |      |             | pending in the Interrupt Distributor after the   |
|          |      |             | event flag is set. The event flag is cleared     |
|          |      |             | when written with a value of 1. Trying to write  |
|          |      |             | a zero to the event flag or a one when it is not |
|          |      |             | set has no effect.                               |



Address: Operational Base + offset (0x0030)
Private watchdog reset status register

| Bit  | Attr | Reset Value | Description                                 |
|------|------|-------------|---------------------------------------------|
| 31:1 | RO   | 0x0         | reserved                                    |
|      |      |             | private watchdog reset flag                 |
|      |      |             | The reset flag is a sticky bit that is      |
| 0    | RW   | 0x0         | automatically set when the Counter Register |
|      |      |             | reaches zero and a reset request is sent    |
|      |      |             | accordingly. (In watchdog mode)             |

# MP\_PTIMER\_WDT\_DISABLE

Address: Operational Base + offset (0x0034)

private watchdog disable

| Bit  | Attr | Reset Value | Description                                   |
|------|------|-------------|-----------------------------------------------|
| 31:1 | RO   | 0x0         | reserved                                      |
|      |      |             | private watchdog disable                      |
|      |      |             | Use the Watchdog Disable Register to switch   |
|      |      |             | from watchdog to timer mode. The software     |
| 0    | WO   | 0x0         | must write 0x12345678 then 0x87654321         |
|      |      |             | successively to the Watchdog Disable Register |
|      |      |             | so that the watchdog mode bit in the          |
|      |      |             | Watchdog Control Register is set to zero.     |

#### L2C\_reg0\_cache\_id

Address: Operational Base + offset (0x0000)

Cache ID Register

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:24 | RW   | 0x41        | Implementer |
| 23:16 | RO   | 0x0         | reserved    |
| 15:10 | RW   | 0x00        | CacheID     |
| 9:6   | RW   | 0x3         | PartNumber  |
| 5:0   | RW   | 0x06        | RTL release |

#### L2C\_reg0\_cache\_type

Address: Operational Base + offset (0x0004)

Cache Type Register

|       | , po regiocol |                    |                                   |  |
|-------|---------------|--------------------|-----------------------------------|--|
| Bit   | Attr          | <b>Reset Value</b> | Description                       |  |
|       |               |                    | data_banking                      |  |
| 31    | RW            | 0x0                | 0 = Data banking not implemented. |  |
|       |               |                    | 1 = Data banking implemented      |  |
| 30:29 | RO            | 0x0                | reserved                          |  |



| Bit   | Attr | <b>Reset Value</b> | Description                                 |
|-------|------|--------------------|---------------------------------------------|
|       |      |                    | ctype                                       |
|       |      |                    | 11xy, where:                                |
| 28:25 | RW   | 0.0                | x=1 if pl310_LOCKDOWN_BY_MASTER is          |
| 20.23 | KVV  | 0x0                | defined, otherwise 0                        |
|       |      |                    | y=1 if pl310_LOCKDOWN_BY_LINE is defined,   |
|       |      |                    | otherwise 0.                                |
| 24:12 | RO   | 0x0                | reserved                                    |
| 11:7  | RW   | 0x00               | Isize                                       |
| 11./  |      |                    | Read from Auxiliary Control Register[19:17] |
| 6     | RW   | 0x0                | associativity                               |
| 6     | KVV  | UXU                | Read from Auxiliary Control Register[16]    |
| 5:2   | RO   | 0x0                | reserved                                    |
| 1.0   | DW   | 0.40               | line_length                                 |
| 1:0   | RW   | 0x0                | 00-32 bytes                                 |

#### L2C\_reg1\_control

Address: Operational Base + offset (0x0100)

reg1\_control

| Bit  | Attr | Reset Value | Description                                                                                                          |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x0         | reserved                                                                                                             |
| 0    | RW   | 0x0         | <ul><li>I2_en</li><li>0 = L2 Cache is disabled. This is the default value.</li><li>1 = L2 Cache is enabled</li></ul> |

# L2C\_reg1\_aux\_control

Address: Operational Base + offset (0x0104)

Auxiliary Control Register

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                            |
|-----|------|--------------------|------------------------------------------------------------------------------------------------------------------------|
| 31  | RO   | 0x0                | reserved                                                                                                               |
| 30  | RW   | 0x0                | early_bresp_en 0 = Early BRESP disabled. This is the default. 1 = Early BRESP enabled.                                 |
| 29  | RW   | 0×0                | <pre>inst_prf_en 0 = Instruction prefetching disabled. This is the default. 1 = Instruction prefetching enabled.</pre> |
| 28  | RW   | 0×0                | data_prf_en 0 = Data prefetching disabled. This is the default. 1 = Data prefetching enabled                           |



| Bit   | Attr | Reset Value | Description                                       |
|-------|------|-------------|---------------------------------------------------|
|       |      |             | ns_int_ac                                         |
|       |      |             | 0 = Interrupt Clear, 0x220, and Interrupt         |
|       |      |             | Mask, 0x214, can only be modified or read         |
| 27    | RW   | 0x0         | with secure accesses. This is the default.        |
|       |      |             | 1 = Interrupt Clear, 0x220, and Interrupt         |
|       |      |             | Mask, 0x214, can be modified or read with         |
|       |      |             | secure or non-secure accesses.                    |
|       |      |             | ns_lock_en                                        |
|       |      |             | 0 = Lockdown registers cannot be modified         |
| 26    | RW   | 0x0         | using non-secure accesses. This is the default.   |
|       |      |             | 1 = Non-secure accesses can write to the          |
|       |      |             | lockdown registers.                               |
|       |      |             | crp                                               |
| 25    | RW   | 0x0         | 0 = pseudo-random replacement using lfsr.         |
|       |      |             | 1 = round-robin replacement. This is the          |
|       |      |             | default.                                          |
|       |      |             | fwa                                               |
|       |      |             | b00 = Use AWCACHE attributes for WA. This is      |
|       |      |             | the default.                                      |
| 24:23 | RW   | 0x0         | b01 = Force no allocate, set WA bit always 0.     |
|       |      | one and     | b10 = Override AWCACHE attributes, set WA         |
|       |      |             | bit always 1, all cacheable write misses          |
|       |      |             | become write allocated.                           |
|       |      |             | b11 = Internally mapped to 00.                    |
|       |      | • 0         | sav_en                                            |
| 22    | RW   | 0x0         | 0 = Treats shared accesses as specified in        |
|       |      |             | Shareable attribute. This is the default.         |
|       |      | (,)         | 1 = Shared attribute internally ignored.          |
| 21    | DW   | 0.40        | parity_en                                         |
| 21    | RW   | 0x0         | 0 = Disabled. This is the default.<br>1 = Enabled |
|       |      |             |                                                   |
| 20    | DW   | 0.40        | evmb_en 0 = Disabled. This is the default.        |
| 20    | RW   | 0x0         |                                                   |
|       |      |             | 1 = Enable                                        |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                               |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19:17 | RW   | 0×0         | <pre>way_size b000 = Reserved, internally mapped to 16KB. b001 = 16KB. b010 = 32KB. b011 = 64KB. b100 = 128KB. b101 = 256KB. b110 = 512KB. b111 = Reserved, internally mapped to 512KB.</pre>                                                                                                                                             |
| 16    | RW   | 0×0         | associativity $0 = 8\text{-way}.$ $1 = 16\text{-way}.$                                                                                                                                                                                                                                                                                    |
| 15:14 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                  |
| 13    | RW   | 0x0         | sai_en 0 = Shared invalidate behavior disabled. This is the default. 1 = Shared invalidate behavior enabled, if Shared Attribute Override Enable bit not set.                                                                                                                                                                             |
| 12    | RW   | 0×0         | excc<br>0 = Disabled. This is the default.<br>1 = Enabled,                                                                                                                                                                                                                                                                                |
| 11    | RW   | 0×0         | sbdl_en 0 = Store buffer device limitation disabled. Device writes can take all slots in store buffer. This is the default. 1 = Store buffer device limitation enabled. Device writes cannot take all slots in store buffer when connected to the Cortex-A9 MPCore processor. There is always one available slot to service Normal Memory |
| 10    | RO   | 0x0         | stronly_priority  0 = Strongly Ordered and Device reads have lower priority than cacheable accesses when arbitrated in the L2CC (L2C-310) master ports. This is the default.  1 = Strongly Ordered and Device reads get the highest priority when arbitrated in the L2CC (L2C-310) master ports.                                          |
| 9:1   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                  |



| Bit | Attr | Reset Value | Description                                    |
|-----|------|-------------|------------------------------------------------|
|     | RO   | 0×0         | full_line_zero                                 |
|     |      |             | 0 = Full line of write zero behavior disabled. |
| U   |      |             | This is the default.                           |
|     |      |             | 1 = Full line of write zero behavior Enabled   |

# L2C\_reg1\_tag\_ram\_control

Address: Operational Base + offset (0x0108)

Tag RAM Latency Control Registers

| Bit   | Attr | / Control Registe  Reset Value | Description                                                                                                                                                                                                                                        |
|-------|------|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:11 | RO   | 0x0                            | reserved                                                                                                                                                                                                                                           |
| 02.22 |      |                                | write_ac_latency b000 = 1 cycle of latency, there is no additional latency.                                                                                                                                                                        |
| 10:8  | RW   | 0x0                            | b001 = 2 cycles of latency.<br>b010 = 3 cycles of latency.<br>b011 = 4 cycles of latency.<br>b100 = 5 cycles of latency.<br>b101 = 6 cycles of latency.<br>b110 = 7 cycles of latency.<br>b111 = 8 cycles of latency.                              |
| 7     | RO   | 0x0                            | reserved                                                                                                                                                                                                                                           |
| 6:4   | wo   | 0x0                            | read_ac_latency b000 = 1 cycle of latency, there is no additional latency. b001 = 2 cycles of latency. b010 = 3 cycles of latency. b011 = 4 cycles of latency. b100 = 5 cycles of latency. b101 = 6 cycles of latency. b111 = 8 cycles of latency. |
| 3     | RO   | 0x0                            | reserved                                                                                                                                                                                                                                           |
| 2:0   | wo   | 0x0                            | setup_latency b000 = 1 cycle of latency, there is no additional latency. b001 = 2 cycles of latency. b010 = 3 cycles of latency. b011 = 4 cycles of latency. b100 = 5 cycles of latency. b101 = 6 cycles of latency. b111 = 8 cycles of latency.   |



#### L2C\_reg1\_data\_ram\_control

Address: Operational Base + offset (0x010c)

Data RAM Latency Control Registers

| Bit   | Attr | Reset Value | Description                            |
|-------|------|-------------|----------------------------------------|
| 31:11 | RO   | 0x0         | reserved                               |
|       |      |             | write_ac_latency                       |
|       |      |             | b000 = 1 cycle of latency, there is no |
|       |      |             | additional latency.                    |
|       |      |             | b001 = 2 cycles of latency.            |
| 10:8  | RW   | 0x0         | b010 = 3 cycles of latency.            |
| 10.6  | FCVV | UXU         | b011 = 4 cycles of latency.            |
|       |      |             | b100 = 5 cycles of latency.            |
|       |      |             | b101 = 6 cycles of latency.            |
|       |      |             | b110 = 7 cycles of latency.            |
|       |      |             | b111 = 8 cycles of latency.            |
| 7     | RO   | 0x0         | reserved                               |
|       |      | 0×0         | read_ac_latency                        |
|       |      |             | b000 = 1 cycle of latency, there is no |
|       |      |             | additional latency.                    |
|       |      |             | b001 = 2 cycles of latency.            |
| 6:4   | RW   |             | b010 = 3 cycles of latency.            |
| 0.4   | IXVV | 0.00        | b011 = 4 cycles of latency.            |
|       |      |             | b100 = 5 cycles of latency.            |
|       |      |             | b101 = 6 cycles of latency.            |
|       |      |             | b110 = 7 cycles of latency.            |
|       |      | • 1         | b111 = 8 cycles of latency.            |
| 3     | RO   | 0x0         | reserved                               |
|       |      |             | setup_latency                          |
|       |      | . ( ) >     | b000 = 1 cycle of latency, there is no |
|       |      |             | additional latency.                    |
|       |      | <b>Y</b>    | b001 = 2 cycles of latency.            |
| 2:0   | RO   | 0x0         | b010 = 3 cycles of latency.            |
|       |      |             | b011 = 4 cycles of latency.            |
|       |      |             | b100 = 5 cycles of latency.            |
|       |      |             | b101 = 6 cycles of latency.            |
|       |      |             | b110 = 7 cycles of latency.            |
|       |      |             | b111 = 8 cycles of latency.            |

### L2C\_reg2\_ev\_counter\_ctrl

Address: Operational Base + offset (0x0200)

Event Counter Control Register

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:3 | RO   | 0x0         | reserved    |



| Bit | Attr | Reset Value | Description                                    |
|-----|------|-------------|------------------------------------------------|
|     |      |             | counter_rst                                    |
|     |      |             | Always Read as zero. The following counters    |
| 2:1 | RO   | 0×0         | are reset when a 1 is written to the following |
| 2.1 | RU   |             | bits:                                          |
|     |      |             | bit[2] = Event Counter1 reset                  |
|     |      |             | bit[1] = Event Counter0 reset.                 |
|     | RO   | 0x0         | ev_cnt_en                                      |
|     |      |             | 0 = Event Counting Disable. This is the        |
| U   |      |             | default.                                       |
|     |      |             | 1 = Event Counting Enable                      |

# L2C\_reg2\_ev\_counter1\_cfg

Address: Operational Base + offset (0x0204) **Event Counter Configuration Registers** 

| Bit  | Attr | Reset Value | Description                                                                                                                                                       |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | RO   | 0x0         | reserved                                                                                                                                                          |
| 5:2  | RW   | 0x0         | ev_source                                                                                                                                                         |
| 1:0  | RW   | 0x0         | ev_cnt_int_gen b00 = Disabled. This is the default. b01 = Enabled: Increment condition. b10 = Enabled: Overflow condition. b11 = Interrupt generation is disabled |

## L2C\_reg2\_ev\_counter0\_cfg

Address: Operational Base + offset (0x0208)**Event Counter Configuration Registers** 

| Bit  | Attr | Reset Value | Description    |
|------|------|-------------|----------------|
| 31:6 | RO   | 0x0         | reserved       |
| 5:2  | RW   | 0x0         | en_source      |
| 1:0  | RO   | 0x0         | ev_cnt_int_gen |

### L2C\_reg2\_ev\_counter1

Address: Operational Base + offset (0x020c)

Event counter value registers

| Bit  | Attr | Reset Value | Description                                |
|------|------|-------------|--------------------------------------------|
| 31:0 |      | 0×00000000  | cnt_val                                    |
|      | RW   |             | Total of the event selected.               |
|      | KVV  |             | If a counter reaches its maximum value, it |
|      |      |             | saturates at that value until it is reset. |

#### L2C\_reg2\_ev\_counter0

Address: Operational Base + offset (0x0210)



Event counter value registers

| Bit  | Attr | Reset Value | Description                                |
|------|------|-------------|--------------------------------------------|
| 31:0 | RO   | 0×00000000  | cnt_val                                    |
|      |      |             | Total of the event selected.               |
|      |      |             | If a counter reaches its maximum value, it |
|      |      |             | saturates at that value until it is reset. |

### L2C\_reg2\_int\_mask

Address: Operational Base + offset (0x0214)

reg2\_int\_mask

| Bit  | Attr | Reset Value | Description                      |
|------|------|-------------|----------------------------------|
| 31:9 | RO   | 0x0         | reserved                         |
|      |      |             | DECERR_MSK                       |
| 8    | RW   | 0x0         | 1 = Enabled.                     |
|      |      |             | 0 = Masked. This is the default. |
|      |      |             | SLVERR_MSK                       |
| 7    | RW   | 0x0         | 1 = Enabled.                     |
|      |      |             | 0 = Masked. This is the default. |
|      |      |             | ERRRD_MSK                        |
| 6    | RW   | 0x0         | 1 = Enabled.                     |
|      |      |             | 0 = Masked. This is the default. |
|      |      |             | ERRRT_MSK                        |
| 5    | RW   | 0x0         | 1 = Enabled.                     |
|      |      |             | 0 = Masked. This is the default. |
|      |      |             | ERRWD_MSK                        |
| 4    | RW   | 0x0         | 1 = Enabled.                     |
|      |      | 1,5         | 0 = Masked. This is the default. |
|      |      |             | ERRWT_MSK                        |
| 3    | RW   | 0x0         | 1 = Enabled.                     |
|      | 1    |             | 0 = Masked. This is the default. |
|      |      | y .         | PARRD_MSK                        |
| 2    | RW   | 0x0         | 1 = Enabled.                     |
|      |      |             | 0 = Masked. This is the default. |
|      | Y    |             | PARRT_MSK                        |
| 1    | RW   | 0x0         | 1 = Enabled.                     |
|      |      |             | 0 = Masked. This is the default. |
|      |      |             | ECNTR_MSK                        |
| 0    | RO   | 0x0         | 1 = Enabled.                     |
|      |      |             | 0 = Masked. This is the default. |

### L2C\_reg2\_int\_mask\_status

Address: Operational Base + offset (0x0218)

reg2\_int\_mask\_status



| Bit  | Attr | Reset Value    | Description                                                |
|------|------|----------------|------------------------------------------------------------|
| 31:9 | RO   | 0x0            | reserved                                                   |
|      |      |                | DECERR_MSKST                                               |
|      |      |                | Bits read can be HIGH or LOW:                              |
|      |      |                | HIGH If the bits read HIGH, they reflect the               |
| 8    | RW   | 0x0            | status of the inputlines triggering an interrupt.          |
|      |      |                | LOW If the bits read LOW, either no interrupt              |
|      |      |                | has been generated, or the interrupt is                    |
|      |      |                | masked                                                     |
|      |      |                | SLVERR_MSKST                                               |
|      |      |                | Bits read can be HIGH or LOW:                              |
|      |      |                | HIGH If the bits read HIGH, they reflect the               |
| 7    | RW   | 0×0            | status of the input lines triggering an                    |
|      | IXVV | 0.00           | interrupt.                                                 |
|      |      |                | LOW If the bits read LOW, either no interrupt              |
|      |      |                | has been generated, or the interrupt is                    |
|      |      |                | masked                                                     |
|      |      |                | ERRRD_MSKST                                                |
|      |      |                | Bits read can be HIGH or LOW:                              |
| 6    | RW   | 0x0            | HIGH If the bits read HIGH, they reflect the               |
|      |      |                | status of the input lines triggering an interrupt.         |
|      |      |                | LOW If the bits read LOW, either no interrupt              |
|      |      |                | has been generated, or the interrupt is masked             |
|      |      |                | ERRRT_MSKST                                                |
|      |      |                | Bits read can be HIGH or LOW:                              |
| 5    | RW   | 0x0            | HIGH If the bits read HIGH, they reflect the               |
|      |      | A ~ Y          | status of the input lines triggering an interrupt.         |
|      |      |                | LOW If the bits read LOW, either no interrupt              |
|      | h 4  | $(C)^{\gamma}$ | has been generated, or the interrupt is masked ERRWD MSKST |
|      |      | 7              | Bits read can be HIGH or LOW:                              |
|      |      | 7              | HIGH If the bits read HIGH, they reflect the               |
| 4    | RW   | 0x0            | status of the input lines triggering an interrupt.         |
|      |      |                | LOW If the bits read LOW, either no interrupt              |
|      |      |                | has been generated, or the interrupt is masked             |
|      |      |                | ERRWT_MSKST                                                |
|      |      |                | Bits read can be HIGH or LOW:                              |
|      |      | 0×0            | HIGH If the bits read HIGH, they reflect the               |
| 3    | RW   |                | status of the input lines triggering an interrupt.         |
|      |      |                | LOW If the bits read LOW, either no interrupt              |
|      |      |                | has been generated, or the interrupt is masked             |



| Bit | Attr   | Reset Value | Description                                        |
|-----|--------|-------------|----------------------------------------------------|
|     |        |             | PARRD_MSKST                                        |
|     |        |             | Bits read can be HIGH or LOW:                      |
| 2   | RW     | 0×0         | HIGH If the bits read HIGH, they reflect the       |
| 2   | IX V V | 0.00        | status of the input lines triggering an interrupt. |
|     |        |             | LOW If the bits read LOW, either no interrupt      |
|     |        | 0x0<br>0x0  | has been generated, or the interrupt is masked     |
|     |        |             | PARRT_MSKST                                        |
|     |        | RW 0x0      | Bits read can be HIGH or LOW:                      |
| 1   | DW     |             | HIGH If the bits read HIGH, they reflect the       |
| 1   | RW (   |             | status of the input lines triggering an interrupt. |
|     |        |             | LOW If the bits read LOW, either no interrupt      |
|     |        |             | has been generated, or the interrupt is masked     |
|     |        | 0×0         | ECNTR_MSKST                                        |
|     |        |             | Bits read can be HIGH or LOW:                      |
| 0   | RO     |             | HIGH If the bits read HIGH, they reflect the       |
| U   |        |             | status of the input lines triggering an interrupt. |
|     |        |             | LOW If the bits read LOW, either no interrupt      |
|     |        |             | has been generated, or the interrupt is masked     |

### L2C\_reg2\_int\_raw\_status

Address: Operational Base + offset (0x021c)

reg2 int raw status

| regz_iiii | t_raw_st | .acus       |                                                    |
|-----------|----------|-------------|----------------------------------------------------|
| Bit       | Attr     | Reset Value | Description                                        |
| 31:9      | RO       | 0x0         | reserved                                           |
|           |          | • ()        | DECERR_RAWST                                       |
|           |          |             | Bits read can be HIGH or LOW:                      |
| 8         | DW       | 0×0         | HIGH If the bits read HIGH, they reflect the       |
| 0         | RW       | UXU         | status of the input lines triggering an interrupt. |
|           | 1        |             | LOW If the bits read LOW, no interrupt has         |
|           |          | 7           | been generated.                                    |
|           |          | 0x0         | SLVERR_RAWST                                       |
|           | RW       |             | Bits read can be HIGH or LOW:                      |
| 7         |          |             | HIGH If the bits read HIGH, they reflect the       |
| /         |          |             | status of the input lines triggering an interrupt. |
|           |          |             | LOW If the bits read LOW, no interrupt has         |
|           |          |             | been generated.                                    |
|           |          | 0x0         | ERRRD_RAWST                                        |
|           |          |             | Bits read can be HIGH or LOW:                      |
| 6         | RW       |             | HIGH If the bits read HIGH, they reflect the       |
|           |          |             | status of the input lines triggering an interrupt. |
|           |          |             | LOW If the bits read LOW, no interrupt has         |
|           |          |             | been generated.                                    |



#### L2C\_reg2\_int\_clear

RO

0

Address: Operational Base + offset (0x0220)

0x0

reg2\_int\_clear

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:9 | RO   | 0x0         | reserved    |

been generated.

HIGH If the bits read HIGH, they reflect the

status of the input lines triggering an interrupt. LOW If the bits read LOW, no interrupt has



| Bit      | Attr | Reset Value | Description                                   |
|----------|------|-------------|-----------------------------------------------|
|          |      |             | DECERR_CL                                     |
|          |      |             | When a bit is written as 1, it clears the     |
| 8        | RW   | 0x0         | corresponding bit in the Raw Interrupt Status |
|          |      |             | Register.                                     |
|          |      |             | When a bit is written as 0, it has no effect  |
|          |      |             | SLVERR_CL                                     |
|          |      |             | When a bit is written as 1, it clears the     |
| 7        | RW   | 0x0         | corresponding bit in the Raw Interrupt Status |
|          |      |             | Register.                                     |
|          |      |             | When a bit is written as 0, it has no effect  |
|          |      |             | ERRRD_CL                                      |
|          |      |             | When a bit is written as 1, it clears the     |
| 6        | RW   | 0x0         | corresponding bit in the Raw Interrupt Status |
|          |      |             | Register.                                     |
|          |      |             | When a bit is written as 0, it has no effect  |
|          |      |             | ERRRT_CL                                      |
|          |      |             | When a bit is written as 1, it clears the     |
| 5        | RW   | 0x0         | corresponding bit in the Raw Interrupt Status |
|          |      |             | Register.                                     |
|          |      |             | When a bit is written as 0, it has no effect  |
|          |      |             | ERRWD_CL                                      |
|          |      |             | When a bit is written as 1, it clears the     |
| 4        | RW   | 0x0         | corresponding bit in the Raw Interrupt Status |
|          |      |             | Register.                                     |
|          |      | . ()        | When a bit is written as 0, it has no effect  |
|          |      |             | ERRWT_CL                                      |
|          |      |             | When a bit is written as 1, it clears the     |
| 3        | RW   | 0x0         | corresponding bit in the Raw Interrupt Status |
|          | 1    |             | Register.                                     |
|          |      | 7           | When a bit is written as 0, it has no effect  |
|          |      |             | PARRD_CL                                      |
|          |      |             | When a bit is written as 1, it clears the     |
| 2        | RW   | 0x0         | corresponding bit in the Raw Interrupt Status |
| <b>Y</b> |      |             | Register.                                     |
|          |      |             | When a bit is written as 0, it has no effect  |
|          |      |             | PARRT_CL                                      |
|          |      |             | When a bit is written as 1, it clears the     |
| 1        | RW   | 0x0         | corresponding bit in the Raw Interrupt Status |
|          |      |             | Register.                                     |
|          |      |             | When a bit is written as 0, it has no effect  |



## L2C\_reg7\_cache\_sync

Address: Operational Base + offset (0x0730)

reg7 cache sync

| Bit  | Attr | Reset Value | Description                                |
|------|------|-------------|--------------------------------------------|
| 31:1 | RO   | 0x0         | reserved                                   |
|      |      |             | sync                                       |
| 0    | RW   | 0x0         | Drain the STB. Operation complete when all |
|      |      |             | buffers, LRB, LFB, STB, and EB, are empty  |

## L2C\_reg7\_inv\_pa

Address: Operational Base + offset (0x0770)

reg7 inv pa

| Bit  | Attr | Reset Value | Description                                           |
|------|------|-------------|-------------------------------------------------------|
| 31:1 | RO   | 0x0         | reserved                                              |
| 0    | RW   | 0×0         | set_en Specific L2 cache line is marked as not valid. |

#### L2C\_reg7\_inv\_way

Address: Operational Base + offset (0x077c)

reg7\_inv\_way

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                            |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0×00000000  | Invalidate all data in specified ways, including dirty data. An Invalidate by way while selecting all cache ways is equivalent to invalidating all cache entries. Completes as a background task with the way, or ways, locked, preventing allocation. |

#### L2C\_reg7\_clean\_pa

Address: Operational Base + offset (0x07b0)

reg7\_clean\_pa

| Bit Attr Reset Value | Description |
|----------------------|-------------|
|----------------------|-------------|



| Bit  | Attr | Reset Value | Description                                                                                                                                                                      |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | set_en set enable bits Write the specific L2 cache line to L3 main memory if the line is marked as valid and dirty. The line is marked as not dirty. The valid bit is unchanged. |

L2C\_reg7\_clean\_index

Address: Operational Base + offset (0x07b8)

reg7\_clean\_index

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                              |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0×00000000  | set_en set enable bits Write the specific L2 cache line within the specified way to L3 main memory if the line is marked as valid and dirty. The line is marked as not dirty. The valid bit is unchanged |

L2C\_reg7\_clean\_way

Address: Operational Base + offset (0x07bc)

reg7 clean way

| reg/_cie | can_way |             |                                                                                                                                                                                                         |
|----------|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit      | Attr    | Reset Value | Description                                                                                                                                                                                             |
| 31:0     | RW      | 0x00000000  | clear_en clear enable bits Writes each line of the specified L2 cache ways to L3 main memory if the line is marked as valid and dirty. The lines are marked as not dirty. The valid bits are unchanged. |
|          |         |             | Completes as a background task with the way, or ways, locked, preventing allocation                                                                                                                     |

L2C\_reg7\_clean\_inv\_pa

Address: Operational Base + offset (0x07f0)

reg7\_clean\_inv\_pa

| Bit  | Attr | Reset Value | Description                                 |
|------|------|-------------|---------------------------------------------|
|      |      |             | clear_en                                    |
|      |      |             | clear enable bits                           |
| 31:0 | RW   | 0x00000000  | Write the specific L2 cache line to L3 main |
|      |      |             | memory if the line is marked as valid and   |
|      |      |             | dirty. The line is marked as not valid.     |



Address: Operational Base + offset (0x07f8)

reg7\_clean\_inv\_index

| Bit  | Attr | Reset Value | Description                                    |
|------|------|-------------|------------------------------------------------|
|      |      |             | clear_en                                       |
|      |      |             | Write the specific L2 cache line within the    |
| 31:0 | RW   | 0x00000000  | specified way to L3 main memory if the line is |
|      |      |             | marked as valid and dirty. The line is marked  |
|      |      |             | as not valid                                   |

L2C\_reg7\_clean\_inv\_way

Address: Operational Base + offset (0x07fc)

reg7 clean inv way

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                  |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | clear_en Writes each line of the specified L2 cache ways to L3 main memory if the line is marked as valid and dirty. The lines are marked as not valid. Completes as a background task with the way, or ways, locked, preventing allocation. |

# L2C\_reg9\_d\_lockdown0

Address: Operational Base + offset (0x0900)

rea9 d lockdown0

| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                      |
|       |      | VV X        | datalock000                                   |
|       | RW   | 0×0000      | each bit has the following meaning:           |
| 15:0  |      |             | 0 allocation can occur in the corresponding   |
| 15.0  |      |             | way.                                          |
|       |      | <i>Y</i>    | 1 there is no allocation in the corresponding |
|       |      |             | way                                           |

# L2C\_reg9\_i\_lockdown0

Address: Operational Base + offset (0x0904)

reg9\_i\_lockdown0

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



| Bit  | Attr | Reset Value | Description                                   |
|------|------|-------------|-----------------------------------------------|
|      | RW   | 0x0000      | instlock000                                   |
|      |      |             | each bit has the following meaning:           |
| 15:0 |      |             | 0 allocation can occur in the corresponding   |
| 15.0 |      |             | way.                                          |
|      |      |             | 1 there is no allocation in the corresponding |
|      |      |             | way                                           |

# L2C\_reg9\_d\_lockdown1

Address: Operational Base + offset (0x0908)

rea9 d lockdown1

| Bit   | Attr | Reset Value | Description                                                                                                                                        |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                                                                                                                           |
| 15:0  | RW   | 0×0000      | datalock001 each bit has the following meaning: 0 allocation can occur in the corresponding way. 1 there is no allocation in the corresponding way |

# L2C\_reg\_i\_lockdown1

Address: Operational Base + offset (0x090c)

rea i lockdown1

| reg_i_lockdowiri |      |             |                                               |
|------------------|------|-------------|-----------------------------------------------|
| Bit              | Attr | Reset Value | Description                                   |
| 31:16            | RO   | 0x0         | reserved                                      |
|                  |      | 0×0000      | instlock001                                   |
|                  | RW   |             | each bit has the following meaning:           |
| 15:0             |      |             | 0 allocation can occur in the corresponding   |
| 13.0             |      |             | way.                                          |
|                  |      |             | 1 there is no allocation in the corresponding |
|                  |      | y           | way                                           |

### L2C\_reg9\_d\_lockdown2

Address: Operational Base + offset (0x0910)

reg9\_d\_lockdown2

| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                      |
|       | RW   | 0x0000      | datalock002                                   |
|       |      |             | each bit has the following meaning:           |
| 15.0  |      |             | 0 allocation can occur in the corresponding   |
| 15:0  |      |             | way.                                          |
|       |      |             | 1 there is no allocation in the corresponding |
|       |      |             | way                                           |



Address: Operational Base + offset (0x0914)

reg9 i lockdown2

| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                      |
|       |      | 0x0000      | instlock002                                   |
|       | RW   |             | each bit has the following meaning:           |
| 15:0  |      |             | 0 allocation can occur in the corresponding   |
| 15.0  |      |             | way.                                          |
|       |      |             | 1 there is no allocation in the corresponding |
|       |      |             | way                                           |

### L2C\_reg9\_d\_lockdown3

Address: Operational Base + offset (0x0918)

rea9 d lockdown3

| Bit   | Attr | Reset Value | Description                                                                                                                                        |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                                                                                                                           |
| 15:0  | RW   | 0x0000      | datalock003 each bit has the following meaning: 0 allocation can occur in the corresponding way. 1 there is no allocation in the corresponding way |

### L2C\_reg9\_i\_lockdwon3

Address: Operational Base + offset (0x091c)

reg9 i lockdwon3

| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                      |
|       | RW   | 0×0000      | instlock003                                   |
|       |      |             | each bit has the following meaning:           |
| 15:0  |      |             | 0 allocation can occur in the corresponding   |
| 15.0  |      |             | way.                                          |
|       |      |             | 1 there is no allocation in the corresponding |
|       |      |             | way                                           |

### L2C\_reg9\_d\_lockdown4

Address: Operational Base + offset (0x0920)

reg9\_d\_lockdown4

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



| Bit  | Attr | Reset Value | Description                                   |
|------|------|-------------|-----------------------------------------------|
|      | RW   | 0x0000      | datalockoo4                                   |
|      |      |             | each bit has the following meaning:           |
| 15:0 |      |             | 0 allocation can occur in the corresponding   |
| 15.0 |      |             | way.                                          |
|      |      |             | 1 there is no allocation in the corresponding |
|      |      |             | way                                           |

### L2C\_reg9\_i\_lockdwon4

Address: Operational Base + offset (0x0924)

rea9 i lockdwon4

| Bit   | Attr | Reset Value | Description                                                                                                                                        |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                                                                                                                           |
| 15:0  | RW   | 0x0000      | instlock004 each bit has the following meaning: 0 allocation can occur in the corresponding way. 1 there is no allocation in the corresponding way |

# L2C\_reg9\_d\_lockdwon5

Address: Operational Base + offset (0x0928)

rea9 d lockdwon5

| 1eg3_u_lockuwoli3 |      |             |                                               |
|-------------------|------|-------------|-----------------------------------------------|
| Bit               | Attr | Reset Value | Description                                   |
| 31:16             | RO   | 0x0         | reserved                                      |
|                   | RW   | 0×0000      | datalock005                                   |
| 15:0              |      |             | each bit has the following meaning:           |
|                   |      |             | 0 allocation can occur in the corresponding   |
|                   |      |             | way.                                          |
|                   |      |             | 1 there is no allocation in the corresponding |
|                   |      | 7           | way                                           |

### L2C\_reg9\_i\_lockdwon5

Address: Operational Base + offset (0x092c)

reg9\_i\_lockdwon5

| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                      |
|       | RW   | 0x0000      | instlock005                                   |
| 15.0  |      |             | each bit has the following meaning:           |
|       |      |             | 0 allocation can occur in the corresponding   |
| 15:0  |      |             | way.                                          |
|       |      |             | 1 there is no allocation in the corresponding |
|       |      |             | way                                           |



Address: Operational Base + offset (0x0930)

rea9 d lockdwon6

| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                      |
|       |      | 0x0000      | datalock006                                   |
|       |      |             | each bit has the following meaning:           |
| 15.0  | RW   |             | 0 allocation can occur in the corresponding   |
| 15:0  | KVV  |             | way.                                          |
|       |      |             | 1 there is no allocation in the corresponding |
|       |      |             | way                                           |

### L2C\_reg9\_i\_lockdwon6

Address: Operational Base + offset (0x0934)

reg9 i lockdwon6

| rego_i_lockawono |      |             |                                                                                                                                                    |
|------------------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit              | Attr | Reset Value | Description                                                                                                                                        |
| 31:16            | RO   | 0x0         | reserved                                                                                                                                           |
| 15:0             | RW   | 0×0000      | instlock006 each bit has the following meaning: 0 allocation can occur in the corresponding way. 1 there is no allocation in the corresponding way |

# L2C\_reg9\_d\_lockdwon7

Address: Operational Base + offset (0x0938)

rea9 d lockdwon7

| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                      |
|       | RW   | 0x0000      | datalock007                                   |
|       |      |             | each bit has the following meaning:           |
| 15:0  |      |             | 0 allocation can occur in the corresponding   |
|       |      |             | way.                                          |
|       |      |             | 1 there is no allocation in the corresponding |
|       |      |             | way                                           |

# L2C\_reg9\_i\_lockdwon7

Address: Operational Base + offset (0x093c)

reg9\_i\_lockdwon7

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



| Bit  | Attr | Reset Value | Description                                   |
|------|------|-------------|-----------------------------------------------|
|      | RW   | 0x0000      | instlock007                                   |
|      |      |             | each bit has the following meaning:           |
| 15:0 |      |             | 0 allocation can occur in the corresponding   |
| 15.0 |      |             | way.                                          |
|      |      |             | 1 there is no allocation in the corresponding |
|      |      |             | way                                           |

# L2C\_reg9\_lock\_line\_en

Address: Operational Base + offset (0x0950)

reg9 lock line en

| Bit  | Attr | Reset Value | Description                                |  |  |
|------|------|-------------|--------------------------------------------|--|--|
| 31:1 | RO   | 0x0         | reserved                                   |  |  |
|      |      | 0×0         | lock_down_by_line_en                       |  |  |
| 0    | RW   |             | 0 = Lockdown by line disabled. This is the |  |  |
| U    | KVV  |             | default.                                   |  |  |
|      |      |             | 1 = Lockdown by line enabled.              |  |  |

# L2C\_reg9\_unlock\_way

Address: Operational Base + offset (0x0954)

reg9 unlock way

| Bit   | Attr | Reset Value | Description                                         |
|-------|------|-------------|-----------------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                            |
|       |      |             | unlock_all_lines_by_way_op                          |
|       |      |             | For all bits:                                       |
| 15:0  | RW   | 0x0000      | 0 = Unlock all lines disabled. This is the default. |
|       |      |             | 1 = Unlock all lines operation in progress for      |
|       |      |             | the corresponding way.                              |

# L2C\_reg12\_addr\_filtering\_start

Address: Operational Base + offset (0x0c00)

reg12 addr filtering start

| Bit   | Attr | Reset Value | Description                                      |  |  |
|-------|------|-------------|--------------------------------------------------|--|--|
|       |      |             | address_filtering_start                          |  |  |
| 31:20 | RW   | 0x000       | Address filtering start address for bits [31:20] |  |  |
|       |      |             | of the filtering address                         |  |  |
| 19:1  | RO   | 0x0         | reserved                                         |  |  |
|       |      |             | filter_en                                        |  |  |
| 0     | RW   | 0x0         | 0 = Address filtering disabled.                  |  |  |
|       |      |             | 1 = Address filtering enabled                    |  |  |

### L2C\_reg12\_addr\_filtering\_end

Address: Operational Base + offset (0x0c04)



reg12\_addr\_filtering\_end

| Bit      | Attr | Reset Value | Description                                    |  |  |
|----------|------|-------------|------------------------------------------------|--|--|
| 31:20 RW |      |             | address_filtering_end                          |  |  |
|          |      | 0x000       | Address filtering end address for bits [31:20] |  |  |
|          |      |             | of the filtering address.                      |  |  |
| 19:0     | RO   | 0x000       | reserved                                       |  |  |

L2C\_reg15\_debug\_ctrl

Address: Operational Base + offset (0x0f40)

Debug Register o

| Bit  | Attr | Reset Value | Description                                      |
|------|------|-------------|--------------------------------------------------|
| 31:3 | RO   | 0x0         | reserved                                         |
| 2    | DW   | 0.40        | SPNIDEN                                          |
| 2    | RW   | 0x0         | Reads value of SPNIDEN input.                    |
|      |      | 0x0         | DWB                                              |
| 1    | DW   |             | 0 = Enable write-back behavior. This is the      |
| 1    | RW   |             | default.                                         |
|      |      |             | 1 = Force write-through behavior.                |
|      |      |             | DCL                                              |
| 0    | RW   | 0×0         | 0 = Enable cache linefills. This is the default. |
|      |      |             | 1 = Disable cache linefills.                     |

# L2C\_reg15\_prefetch\_ctrl

Address: Operational Base + offset (0x0f60)

Prefetch Control Register

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                 |  |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                    |  |
| 30  | RW   | 0x0         | double_linefill_en You can set the following options for this register bit:  0 The L2CC always issues 4x64-bit read bursts to L3 on reads that miss in the L2 cache. This is the default.  1 The L2CC issues 8x64-bit read bursts to L3 on reads that miss in the L2 cache. |  |
| 29  | RW   | 0×0         | inst_prf_en You can set the following options for this register bit:  0 Instruction prefetching disabled. This is the default.  1 Instruction prefetching enabled.                                                                                                          |  |



| Bit   | Attr | Reset Value   | Description                                                                |
|-------|------|---------------|----------------------------------------------------------------------------|
|       |      |               | data_prf_en                                                                |
|       |      |               | You can set the following options for this                                 |
|       |      |               | register bit:                                                              |
| 28    | RW   | 0x0           | O Data prefetching disabled. This is the                                   |
|       |      |               | default.                                                                   |
|       |      |               | 1 Data prefetching enabled.                                                |
|       |      |               | double_linefill_on_wrap                                                    |
|       |      |               | You can set the following options for this                                 |
| 27    | DW   | 0.40          | register bit:                                                              |
| 27    | RW   | 0×0           | 0 Double linefill on WRAP read enabled. This                               |
|       |      |               | is the default.                                                            |
|       |      |               | 1 Double linefill on WRAP read disabled.                                   |
| 26:25 | RO   | 0x0           | reserved                                                                   |
|       |      |               | prf_drop_en                                                                |
|       |      |               | You can set the following options for this                                 |
|       |      |               | register bit:                                                              |
| 24    | RW   | 0×0           | 0 The L2CC does not discard prefetch reads                                 |
| 2     |      | OXO           | issued to L3. This is the default.                                         |
|       |      |               | 1 The L2CC discards prefetch reads issued to                               |
|       |      |               | L3 when there is                                                           |
|       |      |               | a resource conflict with explicit reads                                    |
|       |      |               | incr_db_lf_en                                                              |
|       |      |               | incr_db_lf_en                                                              |
|       |      |               | You can set the following options for this                                 |
| 22    | DW   |               | register bit:                                                              |
| 23    | RW   | 0x0           | O The L2CC does not issue INCR 8x64-bit                                    |
|       |      |               | read bursts to L3 on reads that miss in the L2 cache. This is the default. |
|       |      | $C_{\lambda}$ | 1 The L2CC can issue INCR 8x64-bit read                                    |
|       |      | 7             | bursts to L3 on reads that miss in the L2 cache.                           |
| 22    | RO   | 0×0           | reserved                                                                   |
| 22    | KU   | UXU           |                                                                            |
|       |      |               | excl_seq_en You can set the following options for this                     |
|       |      |               | register bit:                                                              |
|       |      |               | O Read and write portions of a non-cacheable                               |
| 21    | RW   | 0×0           | exclusive sequence have the same AXI ID                                    |
|       |      |               | when issued to L3. This is the default.                                    |
|       |      |               | 1 Read and write portions of a non-cacheable                               |
|       |      |               | exclusive sequence do not have the same AXI                                |
|       |      |               | ID when issued to L3.                                                      |
| 20:5  | RO   | 0x0           | reserved                                                                   |
|       |      |               | prf_offset                                                                 |
| 4:0   | RW   | 0x00          | Default = b00000                                                           |



### L2C\_reg15\_power\_ctrl

Address: Operational Base + offset (0x0f80)

Power Control Register

| Bit  | Attr | Reset Value | Description                      |  |  |  |
|------|------|-------------|----------------------------------|--|--|--|
| 31:2 | RO   | 0x0         | reserved                         |  |  |  |
|      |      |             | dynamic_clk_gating_en            |  |  |  |
| 1    | RW   | 0x0         | 1 = Enabled.                     |  |  |  |
|      |      |             | 0 = Masked. This is the default  |  |  |  |
|      |      |             | standby_mode_en                  |  |  |  |
| 0    | RW   | 0x0         | 1 = Enabled.                     |  |  |  |
|      |      |             | 0 = Masked. This is the default. |  |  |  |

# 8.5 Application Notes

#### 8.5.1 Address filtering

When address\_filtering\_enable is set, all accesses with address >= address\_filtering\_start and < address\_filtering\_end are automatically directed to M1. All other accesses are directed to M0.

Because the input pins provide the reset values of the address filtering registers, it is not expected that the values of these registers are changed dynamically after reset. Furthermore, changing these values without special attention can lead to unpredictable behavior.

It is recommended that you program the Address Filtering End Register before the Address Filtering Start Register to avoid unpredictable behavior between the two writes.

#### 8.5.2 L2 Cache initialization

A typical cache controller start-up programming sequence consists of the following register operations:

- Write to the Auxiliary, Tag RAM Latency, Data RAM Latency, Prefetch, and PowerControl registers using a read-modify-write to set up global configurations:
  - associativity, Way Size
  - Tatencies for RAM accesses
  - allocation policy
  - prefetch and power capabilities.
- 2. Secure write to the Invalidate by Way, offset 0x77C, to invalidate all entries in cache:
  - Write 0xFFFF to 0x77C
  - Poll cache maintenance register until invalidate operation is complete.
  - 3. Write to the Lockdown D and Lockdown I Register 9 if required.
  - 4. Write to interrupt clear register to clear any residual raw interrupts set.
  - 5. Write to the Interrupt Mask Register if you want to enable interrupts.
  - 6. Write to Control Register 1 with the LSB set to 1 to enable the cache.

If you write to the Auxiliary, Tag RAM Latency, or Data RAM Latency Control

Tag RAM Latency, or Data RAM Latency Control Register.



### 8.5.3 L2 ram latency programming

Programmable RAM latencies enable the cache controller to manage RAMs requiring several clock cycles for dealing with accesses. For each RAM, there are three programmable latencies:

- setup
- read access
- write access.

Setup latency is the number of cycles that the RAM control signals remain valid prior to the RAM clock edge. Following figure shows a timing diagram where the tag RAM setup latency has been programmed with the value 0x1.



Read access latency is the number of cycles taken by the read data to become valid after the RAM clock edge. Following figure shows a timing diagram where the tag RAM read latency has been programmed with the value 0x1.



Write access latency is the minimum number of cycles between a RAM clock edge for a write access and the next RAM clock edge corresponding to another access, read or write. Following figure shows a timing diagram where the tag RAM write access latency has been programmed with the value 0x1.



In typical use, the tag ram latency constrained for setup/read/write and correspond register values should be set are like following:

| Item                 | Setup latency | Read latency | Write latency |
|----------------------|---------------|--------------|---------------|
| Cycles               | 1             | 1            | 1             |
| Register filed value | 0x0           | 0x0          | 0x0           |

As the tag ram's min period width is 0.8ns, the write latency must be set to 2 cycles if the core is over-frequency to 1.25Ghz.



The data ram setup/read/write latency is like the tag ram. The only difference is data ram use the banking technology. Following figure shows the benefit of the banking when two consecutive reads targeting different banks are treated with the following programmed latencies:

- Data RAM setup latency = 2 cycles, programmed value = 0x1
- Data RAM read latency = 4 cycles, programmed value = 0x3.



In typical use, the data ram latency constrained for setup/read/write and correspond register values should be set are like following:

| Item                 | Setup latency | Read latency | Write latency |
|----------------------|---------------|--------------|---------------|
| Cycles               | 2             | 4            | 1             |
| Register filed value | 0x1           | 0x3          | 0x0           |

The data ram read latency is constrained as 4-cycles. Following table shows the data ram read latency's most reasonable value under different core frequency.

| Core frequency mhz   | 0~380 | 380~560 | 560~750 | >750 |
|----------------------|-------|---------|---------|------|
| Cycles               | 2     | 3       | 4       | 4    |
| Register filed value | 0x0   | 0x1     | 0x2     | 0x3  |

The data ram setup latency is constrained as 2-cycles. Following table shows the data ram read latency's most reasonable value under different core frequency.

| Core frequency mhz   | 0~560 | 560~750 | >750 |
|----------------------|-------|---------|------|
| Cycles               | 1     | 2       | 2    |
| Register filed value | 0x0   | 0x1     | 0x1  |

#### 8.5.4 L2 data ram mutiplexing

The data ram size is 512KB and reside in the pd\_cpu power domain. There are 3 ways to use the data ram:

- 512KB used as I2c data ram
- 512KB used as share memory
- 256KB used as I2c data ram, the rest 256KB used as share memory It's default to use the 512KB ram as I2c data ram.

The register grf\_soc\_con0[6:5] need to be set to 0x01, when use 512KB as share memory. And need to be set to 0x10, when use 256KB as share memory.

The register grf cpu con0[11:9] need to be set to 0x001, when use 256KB as share memory.



# **Chapter 9 AXI interconnect**

The chip-level interconnect consists of one cpu\_sys interconnect and peri\_sys interconnects. It enables communication among themodules and subsystems in the device.

The cpu sys interconnect handles many types of data transfers, especially exchanges with system-on-chip (SoC)/external memories. It transfers data with amaximum width of 128 bits from the initiator to the target. It is a little-endian platform.

The peri\_sys interconnect belong to peri system which is responsible for peripheral devices control such as usb device, flash device, uart, spi etc.

# **Chapter 10 DMACO(DMA Controller)**

#### 10.1 Overview

This device supports 2 Direct Memory Access (DMA) tops, one for cpu system (DMAC0), and the other one for Peripheral system(DMAC1). Both of these two dma support transfers between memory and memory, peripheral and memory.

DMACO supports TrustZone technology and is under secure state after reset. The secure state can be changed by configuring TZPC module.

DMAC0 is mainly used for data transfer of the following slaves: I2S0/I2S1/SPDIF/UART0/Embedded SRAM and transfer data from/to external DDR SDRAM.

Following table shows the DMACO peripheral request mapping scheme.

Table 10-1DMAC0 Request Mapping Table

| Req number | Source           | Polarity   |
|------------|------------------|------------|
| 0          | Uart0 tx         | High level |
| 1          | Uart0 rx         | High level |
| 2          | Uart1 tx         | High level |
| 3          | Uart1 rx         | High level |
| 4          | I2S0/PCM(8ch) tx | High level |
| 5          | I2S0/PCM(8ch) rx | High level |
| 6          | I2S1/PCM(2ch) tx | High level |
| 7          | I2S1/PCM(2ch) rx | High level |
| 8          | SPDIF tx         | High level |
| 9          | I2S2/PCM(2ch) tx | High level |
| 10         | I2S2/PCM(2ch) rx | High level |

DMAC0 supports the following features:

- Supports Trustzone technology.
- Supports 10 perihpral request.
- Up to 64bits data size.
- 6 channel at the same time.
- Up to burst 16.
- 1 interrupt output and one abort output.
- Supports 32 MFIFO depth.

# 10.2 Block Diagram

Figure 10-1 shows the block diagram of DMAC0





Fig. 10-1 Block diagram of dmac0

As the DMACO supports Trustzone technology, so dual APB interfaces enable the operation of the DMAC0 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 DMACO. The default interface after reset is secure apb interface.

# 10.3 Function Description

#### 10.3.1 Introduction

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

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

The DMAC uses variable-length instructions that consist of one to six bytes. It provides a separate Program Counter (PC) register for each DMA channel. When a thread requests an instruction from an address, the cache performs a look-up. If a cache hit occurs, then the cache immediately provides the data. Otherwise, the thread is stalled while the DMAC uses the AXI interface to perform a cache line fill. If an instruction is greater than 4 bytes, or spans the end of a cache line, the DMAC performs multiple cache accesses to fetch the instruction.

When a cache line fill is in progress, the DMAC enables other threads to access the cache, but if another cache miss occurs, this stalls the pipeline until the first line fill is complete.

When a DMA channel thread executes a load or store instruction, the DMAC adds the instruction to the relevant read or write queue. The DMAC uses these queues as an instruction storage buffer prior to it issuing the instructions on the AXI bus. The DMAC also contains a Multi First-In-First-Out (MFIFO) data buffer that it uses to store data that it reads, or writes, during a DMA transfer.

#### 10.3.2 Operating states

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



Fig. 10-2 DMAC0 operation states

#### Note:

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

C DMA channel threads only.

M DMA manager thread only.

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

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

# 10.4 Register Description

#### 10.4.1 Register summary

| Name                | Offset | Size | Reset<br>Value | Description                           |
|---------------------|--------|------|----------------|---------------------------------------|
| DMAC0_DSR           | 0x0000 | W    | 0x0            | DMA Status Register.                  |
| DMAC0_DPC           | 0x0004 | W    | 0x0            | DMA Program Counter<br>Register.      |
| -                   | -      | -    | -              | reserved                              |
| DMACO_INTEN         | 0x0020 | W    | 0x0            | Interrupt Enable Register             |
| DMACO_EVENT_R<br>IS | 0x0024 | W    | 0x0            | Event Status Register.                |
| DMAC0_INTMIS        | 0x0028 | W    | 0x0            | Interrupt Status Register             |
| DMAC0_INTCLR        | 0x002C | W    | 0x0            | Interrupt Clear Register              |
| DMAC0_FSRD          | 0x0030 | W    | 0x0            | Fault Status DMA Manager<br>Register. |
| DMAC0_FSRC          | 0x0034 | W    | 0x0            | Fault Status DMA Channel              |



|               |         |     |       | Register.                    |
|---------------|---------|-----|-------|------------------------------|
|               |         |     |       | Fault Type DMA Manager       |
| DMAC0_FTRD    | 0x0038  | W   | 0x0   | Register.                    |
| _             | _       | _   | _     | reserved                     |
| DMAC0 FTR0    | 0x0040  | W   | 0x0   | Fault type for DMA Channel 0 |
| DMACO_FTR1    | 0x0040  | W   | 0x0   | Fault type for DMA Channel 1 |
|               |         | W   |       |                              |
| DMACO_FTR2    | 0x0048  |     | 0x0   | Fault type for DMA Channel 2 |
| DMACO_FTR3    | 0x004C  | W   | 0x0   | Fault type for DMA Channel 3 |
| DMACO_FTR4    | 0x0050  | W   | 0x0   | Fault type for DMA Channel 4 |
| DMAC0_FTR5    | 0x0054  | W   | 0x0   | Fault type for DMA Channel 5 |
| -             | -       | -   | _     | reserved                     |
| DMAC0_CSR0    | 0x0100  | W   | 0x0   | Channel Status for DMA       |
| _             |         |     |       | Channel 0                    |
| DMAC0_CSR1    | 0x0108  | w   | 0x0   | Channel Status for DMA       |
|               |         |     |       | Channel 1                    |
| DMAC0_CSR2    | 0x0110  | W   | 0x0   | Channel Status for DMA       |
|               | 0,10220 |     | 0710  | Channel 2                    |
| DMAC0 CSR3    | 0x0118  | w   | 0x0   | Channel Status for DMA       |
| D11/100_05105 | OXOTIO  | • • | OXO   | Channel 3                    |
| DMAC0_CSR4    | 0x0120  | W   | 0x0   | Channel Status for DMA       |
| DMACO_CSK4    | UNUIZU  | **  | 0.00  | Channel 4                    |
| DMAC0_CSR5    | 0x0128  | W   | 0x0   | Channel Status for DMA       |
| DMACU_CSNS    | 0.0120  |     | UXU . | Channel 5                    |
| DMAC0_CPC0    | 0x0104  | W   | 0x0   | Channel PC for DMA Channel 0 |
| DMAC0_CPC1    | 0x010c  | W   | 0x0   | Channel PC for DMA Channel 1 |
| DMAC0_CPC2    | 0x0114  | W   | 0x0   | Channel PC for DMA Channel 2 |
| DMAC0_CPC3    | 0x011c  | W   | 0x0   | Channel PC for DMA Channel 3 |
| DMAC0_CPC4    | 0x0124  | W   | 0x0   | Channel PC for DMA Channel 4 |
| DMAC0_CPC5    | 0x012c  | W   | 0x0   | Channel PC for DMA Channel 5 |
| DM4.C0, C4.D0 |         | 147 | 00    | Source Address for DMA       |
| DMAC0_SAR0    | 0x0400  | W   | 0x0   | Channel 0                    |
| DMAGO CADA    | 0.0420  | X.  | 0.0   | Source Address for DMA       |
| DMAC0_SAR1    | 0x0420  | W   | 0x0   | Channel 1                    |
| D144 C0 C4 D2 | 0.0440  |     | 0.0   | Source Address for DMA       |
| DMAC0_SAR2    | 0x0440  | W   | 0x0   | Channel 2                    |
|               | 2       |     |       | Source Address for DMA       |
| DMAC0_SAR3    | 0x0460  | W   | 0x0   | Channel 3                    |
|               |         |     |       | Source Address for DMA       |
| DMAC0_SAR4    | 0x0480  | W   | 0x0   | Channel 4                    |
| - ()          |         |     |       | Source Address for DMA       |
| DMAC0_SAR5    | 0x04a0  | W   | 0x0   | Channel 5                    |
|               |         |     |       | Dest Address for DMAChannel  |
| DMAC0_DAR0    | 0x0404  | W   | 0x0   | 0                            |
|               |         |     |       | Dest Address for DMAChannel  |
| DMAC0_DAR1    | 0x0424  | W   | 0x0   | 1                            |
|               |         |     |       | Dest Address for DMAChannel  |
| DMAC0_DAR2    | 0x0444  | W   | 0x0   | 2                            |
|               |         |     |       | Dest Address for DMAChannel  |
| DMAC0_DAR3    | 0x0464  | W   | 0x0   |                              |
|               |         |     |       | Doct Address for DMAChannel  |
| DMAC0_DAR4    | 0x0484  | W   | 0x0   | Dest Address for DMAChannel  |
|               |         |     |       | Doct Address for DMAChannel  |
| DMAC0_DAR5    | 0x04a4  | W   | 0x0   | Dest Address for DMAChannel  |
| <u> </u>      | I       | Ī   | 1     | 5                            |



| DMAC0_CCR0                | 0x0408         | W | 0x0 | Channel Control for DMA Channel 0    |
|---------------------------|----------------|---|-----|--------------------------------------|
| DMAC0_CCR1                | 0x0428         | W | 0x0 | Channel Control for DMA<br>Channel 1 |
| DMAC0_CCR2                | 0x0448         | W | 0x0 | Channel Control for DMA<br>Channel 2 |
| DMAC0_CCR3                | 0x0468         | W | 0x0 | Channel Control for DMA<br>Channel 3 |
| DMAC0_CCR4                | 0x0488         | W | 0x0 | Channel Control for DMA<br>Channel 4 |
| DMAC0_CCR5                | 0x04a8         | W | 0x0 | Channel Control for DMA<br>Channel 5 |
| DMAC0_LC0_0               | 0x040C         | W | 0x0 | Loop Counter 0 for DMA<br>Channel 0  |
| DMAC0_LC0_1               | 0x042C         | W | 0x0 | Loop Counter 0 for DMA<br>Channel 1  |
| DMAC0_LC0_2               | 0x044C         | W | 0x0 | Loop Counter 0 for DMA<br>Channel 2  |
| DMAC0_LC0_3               | 0x046C         | W | 0x0 | Loop Counter 0 for DMA<br>Channel 3  |
| DMAC0_LC0_4               | 0x048C         | W | 0x0 | Loop Counter 0 for DMA<br>Channel 4  |
| DMAC0_LC0_5               | 0x04aC         | W | 0x0 | Loop Counter 0 for DMA<br>Channel 5  |
| DMAC0_LC1_0               | 0x0410         | W | 0x0 | Loop Counter 1 for DMA<br>Channel 0  |
| DMAC0_LC1_1               | 0x0430         | W | 0x0 | Loop Counter 1 for DMA<br>Channel 1  |
| DMAC0_LC1_2               | 0x0450         | W | 0x0 | Loop Counter 1 for DMA<br>Channel 2  |
| DMAC0_LC1_3               | 0x0470         | W | 0x0 | Loop Counter 1 for DMA<br>Channel 3  |
| DMAC0_LC1_4               | 0x0490         | W | 0x0 | Loop Counter 1 for DMA<br>Channel 4  |
| DMAC0_LC1_5               | 0x04b0         | W | 0x0 | Loop Counter 1 for DMA<br>Channel 5  |
| -                         | , <del>-</del> | - | -   | reserved                             |
| DMAC0_DBGST<br>DMAC0_ATUS | 0x0D00         | W | 0x0 | Debug Status Register.               |
| DMAC0_DBGCMD              | 0x0D04         | W | 0x0 | Debug Command Register.              |
| DMACO_DBGINS<br>T0        | 0x0D08         | W | 0x0 | Debug Instruction-0 Register.        |
| DMAC0_DBGINS<br>T1        | 0x0D0C         | W | 0x0 | Debug Instruction-1 Register.        |
| DMAC0_CR0                 | 0x0E00         | W |     | Configuration Register 0.            |
| DMAC0_CR1                 | 0x0E04         | W |     | Configuration Register 1.            |
| DMAC0_CR2                 | 0x0E08         | W |     | Configuration Register 2.            |
| DMAC0 CR3                 | 0x0E0C         | W |     | Configuration Register 3.            |
| DMAC0_CR4                 | 0x0E10         | W |     | Configuration Register 4.            |
| DMAC0_CRDn                | 0x0E14         | W |     | Configuration Register Dn.           |
| DMAC0_WD                  | 0x0E80         | W | 0x0 | Watchdog Register.                   |
| • • •                     | _              |   |     |                                      |

Notes:

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



# 10.4.2 Detail Register Description

### DMACO\_DSR

Address: Operational Base+0x0 DMA Manager Status Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                         |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | -    | -           | Reserved                                                                                                                                                                            |
| 9     | R    | 0x0         | Provides the security status of the DMA manager thread:  0 = DMA manager operates in the Secure state  1 = DMA manager operates in the Non-secure state.                            |
| 8:4   | R    | 0x0         | When the DMA manager thread executes a DMAWFE instruction, it waits for the following event to occur: b00000 = event[0] b00001 = event[1] b00010 = event[2] b11111 = event[31].     |
| 3:0   | R    | 0x0         | The operating state of the DMA manager: b0000 = Stopped b0001 = Executing b0010 = Cache miss b0011 = Updating PC b0100 = Waiting for event b0101-b1110 = reserved b1111 = Faulting. |

# DMACO\_DPC

Address:Operational Base+0x4 DMA Program Counter Register

| Bit  | Attr | Reset Value | Description                                |
|------|------|-------------|--------------------------------------------|
| 31:0 | R    | 0x0         | Program counter for the DMA manager thread |

# DMACO\_INTEN

Address:Operational Base+0x20 Interrupt Enable Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                      |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x0         | Program the appropriate bit to control how the DMAC responds when it executes DMASEV: Bit [N] = 0 If the DMAC executes DMASEV for the event-interrupt resource N then the DMAC signals event N to all of the threads. Set bit [N] to 0 if your system design does not use irq[N] to signal an interrupt request. |
|      |      |             | Bit $[N] = 1$ 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.                                                                                                      |



# **DMACO\_EVENT\_RIS**

Address:Operational Base+0x24

Event-Interrupt Raw Status Register

| Bit  | Attr | Reset Value                                          | Description                               |  |  |  |
|------|------|------------------------------------------------------|-------------------------------------------|--|--|--|
|      |      |                                                      | Returns the status of the event-interrupt |  |  |  |
| 31:0 | R    | 0x0                                                  | resources:   Bit [N] = 0                  |  |  |  |
|      |      | Bit $[N] = 1$ Event N is active or $irq[N]$ is HIGH. |                                           |  |  |  |

### **DMACO\_INTMIS**

Address:Operational Base+0x28

Interrupt Status Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                          |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | R    | 0x0         | Provides the status of the interrupts that are active in the DMAC:  Bit [N] = 0 Interrupt N is inactive and therefore irq[N] is LOW.  Bit [N] = 1 Interrupt N is active and therefore irq[N] is HIGH |

### DMACO\_INTCLR

Address:Operational Base+0x2c

Interrupt Clear Register

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                          |
|------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | W    | 0x0                | Controls the clearing of the irq outputs:  Bit [N] = 0 The status of irq[N] does not change.  Bit [N] = 1 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. |

### DMACO\_FSRD

Address: Operational Base+0x30

Fault Status DMA Manager Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                           |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | R)   | 0x0         | Provides the fault status of the DMA manager. Read as:  0 = the DMA manager thread is not in the Faulting state  1 = the DMA manager thread is in the Faulting state. |

# DMACO\_FSRC

Address:Operational Base+0x34

Fault Status DMA Channel Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                              |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | R    | 0x0         | Each bit provides the fault status of the corresponding channel. Read as:  Bit [N] = 0 No fault is present on DMA channel N.  Bit [N] = 1 DMA channel N is in the Faulting or Faulting completing state. |



# DMACO\_FTRD

Address:Operational Base+0x38 Fault Type DMA Manager Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                       |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | -    | -           | reserved                                                                                                                                                                                                                                                                                                                                                          |
| 30    | R    | 0x0         | If the DMA manager aborts, this bit indicates if the erroneous instruction was read from the system memory or from the debug interface:  0 = instruction that generated an abort was read from system memory  1 = instruction that generated an abort was read from the debug interface.                                                                          |
| 29:17 | -    | -           | reserved                                                                                                                                                                                                                                                                                                                                                          |
| 16    | R    | 0x0         | Indicates the AXI response that the DMAC receives on the RRESP bus, after the DMA manager performs an instruction fetch:  0 = OKAY response  1 = EXOKAY, SLVERR, or DECERR response                                                                                                                                                                               |
| 15:6  | -    | -           | reserved                                                                                                                                                                                                                                                                                                                                                          |
| 5     | R    | 0x0         | Indicates if the DMA manager was attempting to execute DMAWFE or DMASEV with inappropriate security permissions:  0 = DMA manager has appropriate security to execute DMAWFE or DMASEV  1 = a DMA manager thread in the Non-secure state attempted to execute either:  • DMAWFE to wait for a secure event  • DMASEV to create a secure event or secure interrupt |
| 4     | R    | 0×0         | ndicates if the DMA manager was attempting to execute DMAGO with inappropriate security permissions:  0 = DMA manager has appropriate security to execute DMAGO  1 = 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   | -    | ) –         | reserved                                                                                                                                                                                                                                                                                                                                                          |
| 1     | Ŕ    | 0x0         | Indicates if the DMA manager was attempting to execute an instruction operand that was not valid for the configuration of the DMAC:  0 = valid operand  1 = invalid operand.                                                                                                                                                                                      |
| 0     | R    | 0x0         | Indicates if the DMA manager was attempting to execute an undefined instruction:  0 = defined instruction  1 = undefined instruction.                                                                                                                                                                                                                             |

# DMACO\_FTR0~DMACO\_FTR5

Address:Operational Base+0x40

Operational Base+0x44 Operational Base+0x48 Operational Base+0x4c



Operational Base+0x50 Operational Base+0x54

Fault Type DMA Channel Register

| Bit   | Attr    | Reset Value | Description                                                               |
|-------|---------|-------------|---------------------------------------------------------------------------|
| 2.0   | Atti    | value       | Indicates if the DMA channel has locked-up                                |
|       |         |             | because of resource starvation:                                           |
|       |         |             | 0 = DMA channel has adequate resources                                    |
| 31    | R       | 0x0         | 1 = DMA channel has locked-up because of                                  |
|       |         |             | insufficient resources.                                                   |
|       |         |             | This fault is an imprecise abort                                          |
|       |         |             | If the DMA channel aborts, this bit indicates if                          |
|       |         |             | the erroneous instruction was read from the                               |
|       |         |             | system memory or from the debug interface:                                |
|       |         |             | 0 = instruction that generated an abort was read                          |
| 30    | R       | 0x0         | from system memory                                                        |
|       |         |             | 1 = instruction that generated an abort was read                          |
|       |         |             | from the debug interface.                                                 |
|       |         |             | This fault is an imprecise abort but the bit is only                      |
|       |         |             | valid when a precise abort occurs.                                        |
| 29:19 |         | -           | reserved                                                                  |
|       |         |             | Indicates the AXI response that the DMAC                                  |
|       |         |             | receives on the RRESP bus, after the DMA                                  |
| 18    | R       | 0x0         | channel thread performs a data read:                                      |
| 10    | K       | UXU         | 0 = OKAY response                                                         |
|       |         |             | 1 = EXOKAY, SLVERR, or DECERR response.                                   |
|       |         |             | This fault is an imprecise abort                                          |
|       |         |             | Indicates the AXI response that the DMAC                                  |
|       |         |             | receives on the BRESP bus, after the DMA                                  |
| 17    | R       | 0x0         | channel thread performs a data write:                                     |
| 17    | 1       | OXO         | 0 = OKAY response                                                         |
|       |         |             | 1 = EXOKAY, SLVERR, or DECERR response.                                   |
|       |         | • 1         | This fault is an imprecise abort.                                         |
|       |         |             | Indicates the AXI response that the DMAC                                  |
|       |         |             | receives on the RRESP bus, after the DMA                                  |
| 16    | R       | 0x0         | channel thread performs an instruction fetch:                             |
|       |         | 1           | 0 = OKAY response                                                         |
|       |         | -           | 1 = EXOKAY, SLVERR, or DECERR response.<br>This fault is a precise abort. |
| 15:14 |         | 1 -         | reserved                                                                  |
| 13.14 |         | <i>y</i>    | Indicates if the MFIFO did not contain the data to                        |
|       |         |             | enable the DMAC to perform the DMAST:                                     |
|       |         |             | 0 = MFIFO contains all the data to enable the                             |
| 13    | R       | 0x0         | DMAST to complete                                                         |
|       | ``      |             | 1 = previous DMALDs have not put enough data                              |
|       |         |             | in the MFIFO to enable the DMAST to complete.                             |
|       |         |             | This fault is a precise abort.                                            |
|       |         |             | Indicates if the MFIFO prevented the DMA                                  |
|       |         |             | channel thread from executing DMALD or                                    |
|       |         |             | DMAST. Depending on the instruction:                                      |
| 12    | <u></u> | 0.40        | DMALD $0 = MFIFO$ contains sufficient space                               |
| 12    | R       | 0x0         | 1 = MFIFO is too small to hold the data that                              |
|       |         |             | DMALD requires.                                                           |
|       |         |             | DMAST 0 = MFIFO contains sufficient data                                  |
|       |         |             | 1 = MFIFO is too small to store the data to                               |



|      |   |     | LL DMACT L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|---|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |   |     | enable DMAST to complete.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 44.0 |   |     | This fault is an imprecise abort                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 11:8 | - | -   | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 7    | R | 0x0 | Indicates if a DMA channel thread, in the Non-secure state, attempts to program the CCRn Register to perform a secure read or secure write:  0 = a DMA channel thread in the Non-secure state is not violating the security permissions  1 = a DMA channel thread in the Non-secure state attempted to perform a secure read or secure write.  This fault is a precise abort                                                                                                                                    |
| 6    | R | 0x0 | Indicates if a DMA channel thread, in the Non-secure state, attempts to execute DMAWFP, DMALDP, DMASTP, or DMAFLUSHP with inappropriate security permissions:  0 = a DMA channel thread in the Non-secure state is not violating the security permissions  1 = a DMA channel thread in the Non-secure state attempted to execute either:  • DMAWFP to wait for a secure peripheral  • DMALDP or DMASTP to notify a secure peripheral  • DMAFLUSHP to flush a secure peripheral.  This fault is a precise abort. |
| 5    | R | 0x0 | Indicates if the DMA channel thread attempts to execute DMAWFE or DMASEV with inappropriate security permissions:  0 = a DMA channel thread in the Non-secure state is not violating the security permissions  1 = a DMA channel thread in the Non-secure state attempted to execute either:  • DMAWFE to wait for a secure event  • DMASEV to create a secure event or secure interrupt.  This fault is a precise abort.                                                                                       |
| 4:2  | - | 1   | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1    | R | 0x0 | Indicates if the DMA channel thread was attempting to execute an instruction operand that was not valid for the configuration of the DMAC:  0 = valid operand  1 = invalid operand.  This fault is a precise abort.                                                                                                                                                                                                                                                                                             |
| 0    | R | 0x0 | Indicates if the DMA channel thread was attempting to execute an undefined instruction:  0 = defined instruction  1 = undefined instruction.  This fault is a precise abort                                                                                                                                                                                                                                                                                                                                     |

**DMACO\_CSR0~DMACO\_CSR5**Address:Operational Base+0x100 Operational Base+0x108



Operational Base+0x110 Operational Base+0x118 Operational Base+0x120 Operational Base+0x128

Channel Status Registers

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | _    | -           | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 21    | R    | 0x0         | The channel non-secure bit provides the security of the DMA channel:  0 = DMA channel operates in the Secure state  1 = DMA channel operates in the Non-secure state                                                                                                                                                                                                                                                                      |
| 20:16 | -    | -           | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 15    | R    | 0x0         | When the DMA channel thread executes DMAWFP this bit indicates if the periph operand was set:  0 = DMAWFP executed with the periph operand not set  1 = DMAWFP executed with the periph operand set                                                                                                                                                                                                                                       |
| 14    | R    | 0x0         | When the DMA channel thread executes DMAWFP this bit indicates if the burst or single operand were set:  0 = DMAWFP executed with the single operand set  1 = DMAWFP executed with the burst operand set.                                                                                                                                                                                                                                 |
| 13:9  | -    | -           | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 8:4   | R    | 0×0         | If the DMA channel is in the Waiting for event state or the Waiting for peripheral state then these bits indicate the event or peripheral number that the channel is waiting for:  b00000 = DMA channel is waiting for event, or peripheral, 0  b00001 = DMA channel is waiting for event, or peripheral, 1  b00010 = DMA channel is waiting for event, or peripheral, 2  .  b11111 = DMA channel is waiting for event, or peripheral, 31 |
| 3:0   | R    | 0x0         | The channel status encoding is:  b0000 = Stopped  b0001 = Executing  b0010 = Cache miss  b0011 = Updating PC  b0100 = Waiting for event  b0101 = At barrier  b0110 = reserved  b0111 = Waiting for peripheral  b1000 = Killing                                                                                                                                                                                                            |



| b1001 = Completing<br>b1010-b1101 = reserved    |
|-------------------------------------------------|
| b1110 = Faulting completing<br>b1111 = Faulting |

### DMACO\_CPCO~DMACO\_CPC5

Address: Operational Base+0x104 Operational Base+0x10c Operational Base+0x114

Operational Base+0x11c Operational Base+0x124 Operational Base+0x12c

Channel Program Counter Registers

| Bit  | Attr | Reset Value | Description                                  |
|------|------|-------------|----------------------------------------------|
| 31:0 | R    | 0x0         | Program counter for the DMA channel n thread |

### DMACO SARO~DMACO SAR5

Address: Operational Base+0x400

Operational Base+0x420 Operational Base+0x440 Operational Base+0x460 Operational Base+0x480

Operational Base+0x4a0

Source Address Registers

| Bit  | Attr | Reset Value | Description                                  |
|------|------|-------------|----------------------------------------------|
| 31:0 | R    | 0x0         | Address of the source data for DMA channel n |

#### DMACO\_DARO~DMACO\_DAR5

Address: Operational Base+0x404

Operational Base+0x424 Operational Base+0x444 Operational Base+0x464

Operational Base+0x484 Operational Base+0x4a4

Destination Address Registers

| DC3till | DestinationAddress Registers |             |                                                  |  |  |
|---------|------------------------------|-------------|--------------------------------------------------|--|--|
| Bit     | Attr                         | Reset Value | Description                                      |  |  |
| 31:0    | R                            | 0x0         | Address of the Destinationdata for DMA channel n |  |  |

#### DMACO\_CCRO~DMACO\_CCR5

Address: Operational Base+0x408

Operational Base+0x428

Operational Base+0x448 Operational Base+0x468

Operational Base+0x488

Operational Base+0x4a8

Channel Control Registers

| Bit   | Attr | Reset Value | Description                                                                                                                                                               |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | ı    | -           | reserved                                                                                                                                                                  |
| 27:25 | R    | 0x0         | Programs the state of AWCACHE[3,1:0]a when the DMAC writes the destination data.  Bit [27] 0 = AWCACHE[3] is LOW  1 = AWCACHE[3] is HIGH.  Bit [26] 0 = AWCACHE[1] is LOW |



|       | ı   | Г       |                                                 |
|-------|-----|---------|-------------------------------------------------|
|       |     |         | 1 = AWCACHE[1] is HIGH.                         |
|       |     |         | Bit $[25]$ 0 = AWCACHE[0] is LOW                |
|       |     |         | 1 = AWCACHE[0] is HIGH                          |
|       |     |         | Programs the state of AWPROT[2:0]a when the     |
|       |     |         | DMAC writes the destination data.               |
|       |     |         | Bit $[24]$ 0 = AWPROT $[2]$ is LOW              |
| 24:22 | R   | 0x0     | 1 = AWPROT[2] is HIGH.                          |
| 24.22 | K   | UXU     | Bit $[23]$ 0 = AWPROT $[1]$ is LOW              |
|       |     |         | 1 = AWPROT[1] is HIGH.                          |
|       |     |         | Bit $[22]$ 0 = AWPROT $[0]$ is LOW              |
|       |     |         | 1 = AWPROT[0] is HIGH                           |
|       |     |         | For each burst, these bits program the number   |
|       |     |         | of data transfers that the DMAC performs when   |
|       |     |         | it writes the destination data:                 |
|       |     |         | b0000 = 1 data transfer                         |
|       |     |         | b0001 = 2 data transfers                        |
|       |     |         | b0010 = 3 data transfers                        |
| 21:18 | R   | 0x0     |                                                 |
| 21.10 | , , | UXU     |                                                 |
|       |     |         |                                                 |
|       |     |         | b1111 = 16 data transfers.                      |
|       |     |         | The total number of bytes that the DMAC writes  |
|       |     |         | out of the MFIFO when it executes a DMAST       |
|       |     |         | instruction is the product of dst_burst_len and |
|       |     |         | dst_burst_size                                  |
|       |     |         | For each beat within a burst, it programs the   |
|       |     |         | number of bytes that the DMAC writes to the     |
|       |     |         | destination:                                    |
|       |     |         | b000 = writes 1 byte per beat                   |
|       |     |         | b001 = writes 2 bytes per beat                  |
|       |     |         | b010 = writes 4 bytes per beat                  |
| 17:15 | R   | 0x0     | b011 = writes 8 bytes per beat                  |
|       |     |         | b100 = writes 16 bytes per beat                 |
|       |     | AOY     | b101-b111 = reserved.                           |
|       |     |         | The total number of bytes that the DMAC writes  |
|       |     | , ( ) , | out of the MFIFO when it executes a DMAST       |
|       |     |         | instruction is the product of dst_burst_len and |
|       |     |         | dst_burst_size.                                 |
|       |     | ) *     | Programs the burst type that the DMAC           |
|       |     |         | performs when it writes the destination data:   |
| 14    | R   | 0x0     | 0 = Fixed-address burst. The DMAC signals       |
| - '   |     |         | AWBURST[0] LOW.                                 |
| ,     |     |         | 1 = Incrementing-address burst. The DMAC        |
|       |     |         | signals AWBURST[0] HIGH.                        |
|       |     |         | Set the bits to control the state of            |
|       |     |         | ARCACHE[2:0]a when the DMAC reads the           |
|       |     |         | source data.                                    |
|       | _   |         | Bit [13] $0 = ARCACHE[2]$ is LOW                |
| 13:11 | R   | 0x0     | 1 = ARCACHE[2] is HIGH.                         |
|       |     |         | Bit [12] $0 = ARCACHE[1]$ is LOW                |
|       |     |         | 1 = ARCACHE[1] is HIGH.                         |
|       |     |         | Bit [11] $0 = ARCACHE[0]$ is LOW                |
| 1     |     |         | 1 = ARCACHE[0] is HIGH.                         |
| 10:8  | R   | 0x0     | Programs the state of ARPROT[2:0]a when the     |



|     |    |         | DMAC reads the source data.  Bit [10] 0 = ARPROT[2] is LOW                                                                                                                                      |
|-----|----|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |         | 1 = ARPROT[2] is HIGH.<br>Bit [9] 0 = ARPROT[1] is LOW                                                                                                                                          |
|     |    |         | 1 = ARPROT[1]  is HIGH.                                                                                                                                                                         |
|     |    |         | Bit [8] $0 = ARPROT[0]$ is LOW                                                                                                                                                                  |
|     |    |         | 1 = ARPROT[0] is HIGH.                                                                                                                                                                          |
|     |    |         | For each burst, these bits program the number of data transfers that the DMAC performs when it reads the source data: b0000 = 1 data transfer b0001 = 2 data transfers b0010 = 3 data transfers |
| 7:4 | R  | 0x0     |                                                                                                                                                                                                 |
|     |    |         | b1111 = 16 data transfers.                                                                                                                                                                      |
|     |    |         | The total number of bytes that the DMAC reads                                                                                                                                                   |
|     |    |         | into the MFIFO when it executes a DMALD                                                                                                                                                         |
|     |    |         | instruction is the product of src_burst_len and                                                                                                                                                 |
|     |    |         | src_burst_size                                                                                                                                                                                  |
|     |    |         | For each beat within a burst, it programs the                                                                                                                                                   |
|     |    |         | number of bytes that the DMAC reads from the source:                                                                                                                                            |
|     |    |         | b000 = reads 1 byte per beat                                                                                                                                                                    |
|     |    |         | b001 = reads 2 bytes per beat                                                                                                                                                                   |
|     |    |         | b010 = reads 4 bytes per beat                                                                                                                                                                   |
| 3:1 | R  | 0x0     | b011 = reads 8 bytes per beat                                                                                                                                                                   |
| 3.1 | '` | o no    | b100 = reads 16 bytes per beat                                                                                                                                                                  |
|     |    |         | b101-b111 = reserved.                                                                                                                                                                           |
|     |    |         | The total number of bytes that the DMAC reads into the MFIFO when it executes a DMALD                                                                                                           |
|     |    |         | instruction                                                                                                                                                                                     |
|     |    | 40 >    | is the product of src_burst_len and                                                                                                                                                             |
|     |    |         | src_burst_size                                                                                                                                                                                  |
|     | _  | , ( ) , | Programs the burst type that the DMAC                                                                                                                                                           |
|     |    |         | performs when it reads the source data:                                                                                                                                                         |
| 0   | R  | 0x0     | 0 = Fixed-address burst. The DMAC signals ARBURST[0] LOW.                                                                                                                                       |
|     |    | /       | 1 = Incrementing-address burst. The DMAC                                                                                                                                                        |
|     |    |         |                                                                                                                                                                                                 |

# DMACO\_LCO\_0~DMACO\_LCO\_5

Address:Operational Base+0x40c

Operational Base+0x42c

Operational Base+0x44c

Operational Base+0x46c

Operational Base+0x48c

Operational Base+0x4ac

Loop Counter 0 Registers

| Bit  | Attr | Reset Value | Description               |
|------|------|-------------|---------------------------|
| 31:8 | -    | -           | reserved                  |
| 7:0  | R    | 0x0         | Loop counter 0 iterations |



# DMACO\_LC1\_0~DMACO\_LC1\_5

Address:Operational Base+0x410

Operational Base+0x430

Operational Base+0x450

Operational Base+0x470

Operational Base+0x490

Operational Base+0x4b0

Loop Counter 1 Registers

| Bit  | Attr | Reset Value | Description               |  |  |  |
|------|------|-------------|---------------------------|--|--|--|
| 31:8 | -    | -           | reserved                  |  |  |  |
| 7:0  | R    | 0x0         | Loop counter 1 iterations |  |  |  |

### DMACO\_DBGSTATUS

Address: Operational Base+0xd00

Debug Status Register

| Bit  | Attr | Reset Value | Description                                                                                                                                            |  |  |  |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 31:2 | -    | -           | reserved                                                                                                                                               |  |  |  |
| 1:0  | R    | 0x0         | The debug encoding is as follows: b00 = execute the instruction that the DBGINST [1:0] Registers contain b01 = reserved b10 = reserved b11 = reserved. |  |  |  |

### DMACO\_DBGCMD

Address:Operational Base+0xd04

Debug Command Register

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                           |  |  |
|------|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31:2 | ı    | -                  | reserved                                                                                                                                              |  |  |
| 1:0  | W    | 0x0                | The debug encoding is as follows: b00 = execute the instruction that the DBGINST [1:0] Registers contain b01 = reserved b10 = reserved b11 = reserved |  |  |

# DMACO\_DBGINSTO

Address:Operational Base+0xd08 Debug Instruction-0 Register

| Bit   | Attr | Reset Value | Description                                                                                                             |  |  |  |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 31:24 | W    | 0x0         | Instruction byte 1                                                                                                      |  |  |  |
| 23:16 | W    | 0x0         | Instruction byte 0                                                                                                      |  |  |  |
| 15:11 | -    | -           | reserved                                                                                                                |  |  |  |
| 10:8  | W    | 0x0         | DMA channel number:<br>b000 = DMA channel 0<br>b001 = DMA channel 1<br>b010 = DMA channel 2<br><br>b111 = DMA channel 7 |  |  |  |
| 7:1   | -    | -           | reserved                                                                                                                |  |  |  |
| 0     | W    | 0x0         | The debug thread encoding is as follows:  0 = DMA manager thread  1 = DMA channel.                                      |  |  |  |



# **DMACO\_DBGINST1**

Address:Operational Base+0xd0c Debug Instruction-1 Register

| Bit   | Attr | Reset Value | Description        |
|-------|------|-------------|--------------------|
| 31:24 | W    | 0x0         | Instruction byte 5 |
| 23:16 | W    | 0x0         | Instruction byte 4 |
| 15:8  | W    | 0x0         | Instruction byte 3 |
| 7:0   | W    | 0x0         | Instruction byte 2 |

# DMACO\_CRO

Address:Operational Base+0xe00

| Configuration Register 0 |      |             |                                                                                                                                                                                                                                          |  |
|--------------------------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit                      | Attr | Reset Value | Description                                                                                                                                                                                                                              |  |
| 31:22                    | -    | -           | reserved                                                                                                                                                                                                                                 |  |
| 21:17                    | R    | 0x2         | Number of interrupt outputs that the DMAC provides:  b00000 = 1 interrupt output, irq[0]  b00001 = 2 interrupt outputs, irq[1:0]  b00010 = 3 interrupt outputs, irq[2:0]  .  b11111 = 32 interrupt outputs, irq[31:0].                   |  |
| 16:12                    | R    | 0x7         | Number of peripheral request interfaces that the DMAC provides:  b00000 = 1 peripheral request interface  b00001 = 2 peripheral request interfaces  b00010 = 3 peripheral request interfaces  b11111 = 32 peripheral request interfaces. |  |
| 11:7                     | -    | - ^ ×       | reserved                                                                                                                                                                                                                                 |  |
| 6:4                      | R    | 0x5         | Number of DMA channels that the DMAC supports:  b000 = 1 DMA channel  b001 = 2 DMA channels  b010 = 3 DMA channels  .                                                                                                                    |  |
| 2                        |      |             | b111 = 8 DMA channels.                                                                                                                                                                                                                   |  |
| 2                        | R    | 0x0         | reserved Indicates the status of the boot_manager_ns signal when the DMAC exited from reset: 0 = boot_manager_ns was LOW 1 = boot_manager_ns was HIGH.                                                                                   |  |
| 1                        | R    | 0x0         | Indicates the status of the boot_from_pc signal when the DMAC exited from reset:  0 = boot_from_pc was LOW  1 = boot_from_pc was HIGH                                                                                                    |  |
| 0                        | R    | 0x1         | Supports peripheral requests:<br>0 = the DMAC does not provide a peripheral                                                                                                                                                              |  |



|  | request   | interface   |        |       |        |          |      |
|--|-----------|-------------|--------|-------|--------|----------|------|
|  | 1 = the D | DMAC provio | des th | e nur | nber o | f periph | eral |
|  | request   | interfaces  | that   | the   | num_   | _periph_ | _req |
|  | field spe | cifies.     |        |       |        |          |      |

# DMACO\_CR1

Address:Operational Base+0xe04

Configuration Register 1

| Bit  | Attr | Reset Value | Description                                                                                                                                              |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | reserved                                                                                                                                                 |
| 7:4  | R    | 0x5         | [7:4] num_i-cache_lines Number of i-cache lines: b0000 = 1 i-cache line b0001 = 2 i-cache lines b0010 = 3 i-cache lines b1111 = 16 i-cache lines.        |
| 3    | -    | -           | reserved                                                                                                                                                 |
| 2:0  | R    | 0×7         | The length of an i-cache line:<br>b000-b001 = reserved<br>b010 = 4 bytes<br>b011 = 8 bytes<br>b100 = 16 bytes<br>b101 = 32 bytes<br>b110-b111 = reserved |

# DMACO\_CR2

Address:Operational Base+0xe08

Configuration Register 2

| Bit  | Attr | <b>Reset Value</b> | Description                                                           |
|------|------|--------------------|-----------------------------------------------------------------------|
| 31:0 | R    | 0x0                | Provides the value of boot_addr[31:0] when the DMAC exited from reset |

# DMACO\_CR3

Address:Operational Base+0xe0c

Configuration Register 3

| Bit  | Attr | Reset Value | Description                                                                                                                                                                      |  |  |  |  |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 31:0 | R    | 0x0         | Provides the security state of an event-interrupt resource:  Bit [N] = 0 Assigns event <n> or irq[N] to the Secure state.  Bit [N] = 1 Assigns event<n> or irq[N] to the</n></n> |  |  |  |  |
|      |      |             | Non-secure state.                                                                                                                                                                |  |  |  |  |

# DMACO\_CR4

Address:Operational Base+0xe10

Configuration Register 4

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                            |  |  |  |  |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 31:0 | R    | 0x6         | Provides the security state of the peripheral request interfaces:  Bit [N] = 0 Assigns peripheral request interface N to the Secure state.  Bit [N] = 1 Assigns peripheral request interface N to the Non-secure state |  |  |  |  |



# DMACO\_CRDn

Address: Operational Base+0xe14

| DMA | Confia | uration | Register |
|-----|--------|---------|----------|
|-----|--------|---------|----------|

| Bit   | Attr | Reset Value | Description                                                                                                              |  |  |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------|--|--|
| 31:30 | -    | -           | reserved                                                                                                                 |  |  |
| 29:20 | R    | 0x20        | The number of lines that the data buffer contains:  b000000000 = 1 line b00000001 = 2 lines  b111111111 = 1024 lines     |  |  |
| 19:16 | R    | 0x9         | The depth of the read queue: b0000 = 1 line b0001 = 2 lines b1111 = 16 lines.                                            |  |  |
| 15    | -    | -           | reserved                                                                                                                 |  |  |
| 14:12 | R    | 0x4         | Read issuing capability that programs the number of outstanding read transactions: $b000 = 1$ $b001 = 2$ $b111 = 8$      |  |  |
| 11:8  | R    | 0x7         | The depth of the write queue: b0000 = 1 line b0001 = 2 lines b1111 = 16 lines.                                           |  |  |
| 7     | -    | - • 1       | reserved                                                                                                                 |  |  |
| 6:4   | R    | 0x3         | Write issuing capability that programs the number of outstanding write transactions: b000 = 1 b001 = 2 b111 = 8          |  |  |
| 3     | _ (  | ) _         | ,                                                                                                                        |  |  |
| 2:0   |      | 0x3         | The data bus width of the AXI interface:  b000 = reserved  b001 = reserved  b010 = 32-bit  b011 = 64-bit  b100 = 128-bit |  |  |
|       |      |             | b100  = 128-bit $ b101-b111  = reserved.$                                                                                |  |  |

# DMAC0\_WD

Address: Operational Base+0xe80

DMA Watchdog Register

| Brint Waterlady Register |      |             |                                        |  |  |
|--------------------------|------|-------------|----------------------------------------|--|--|
| Bit                      | Attr | Reset Value | Description                            |  |  |
| -                        | -    | -           | reserved                               |  |  |
| 0                        | RW   | 0x0         | Controls how the DMAC responds when it |  |  |
|                          |      |             | detects a lock-up condition:           |  |  |



| 0 = the DMAC aborts all of the contributing DMA channels and sets irg_abort HIGH |
|----------------------------------------------------------------------------------|
| 1 = the DMAC sets irq_abort HIGH.                                                |

# 10.5 Timing Diagram

Following picture shows the relationship between dma reg and dma ack.



Fig. 10-3 DMAC0 request and acknowledge timing

# **10.6 Interface Description**

DMACO has the following tie-off signals. It can be configured by GRF register or TZPC register. (Please refer to these two chapters to find how to configure)

|                 | <u> </u>    |                |
|-----------------|-------------|----------------|
| interface       | Reset value | Control source |
| boot_addr       | 0x0         | GRF            |
| boot_from_pc    | 0x0         | GRF            |
| boot_manager_ns | 0x1         | TZPC           |
| boot_irq_ns     | 0x6         | TZPC           |
| boot_periph_ns  | 0xff        | TZPC           |

#### boot\_addr

Configures the address location that contains the first instruction the DMAC executes, when it exits from reset.

#### boot\_from\_pc

Controls the location in which the DMAC executes its initial instruction, after it exits from reset:

- 0 = DMAC waits for an instruction from either APB interface
- 1 = DMA manager thread executes the instruction that is located at the address that

#### boot\_manager\_ns

When the DMAC exits from reset, this signal controls the security state of the DMA manager thread:

- 0 = assigns DMA manager to the Secure state
- 1 = assigns DMA manager to the Non-secure state.

#### boot\_irq\_ns

Controls the security state of an event-interrupt resource, when the DMAC exits from reset:

boot\_irq\_ns[x] is LOW

The DMAC assigns event<x> or irg[x] to the Secure state.

boot irg ns[x] is HIGH

The DMAC assigns event<x> or irg[x] to the Non-secure state.



#### boot\_periph\_ns

Controls the security state of a peripheral request interface, when the DMAC exits from reset:

boot periph ns[x] is LOW

The DMAC assigns peripheral request interface x to the Secure state. boot\_periph\_ns[x] is HIGH

The DMAC assigns peripheral request interface x to the Non-secure state.

# 10.7 Application Notes

### 10.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 dbastatus bit is 0.
- 4. Write to the DBGINSTO Register and enter the:
- Instruction byte 0 encoding for DMAGO.
- Instruction byte 1 encoding for DMAGO.
- Debug thread bit to 0. This selects the DMA manager thread.
- 5. Write to the DBGINST1 Register with the DMAGO instruction byte [5:2] data, see Debug Instruction-1 Register o. You must set these four bytes to the address of the first instruction in the program, that was written to system memory in step 2.
- 6. Writing zero to the DBGCMD Register. The DMAC starts the DMA channel thread and sets the dbgstatus bit to 1.

### 10.7.2 Security usage

When the DMAC exits from reset, the status of the configuration signals that tie-off signals which descripted in chapter 10.6.

#### DMA manager thread is in the Secure state

If the DNS bit is 0, the DMA manager thread operates in the Secure state and it only performs secure instruction fetches. When a DMA manager thread in the Secure state processes:

#### **DMAGO**

It uses the status of the ns bit, to set the security state of the DMA

channel thread by writing to the CNS bit for that channel.

#### **DMAWFE**

It halts execution of the thread until the event occurs. When the event occurs, the DMAC continues execution of the thread, irrespective of the security state of the corresponding INS bit.

#### **DMASEV**

It sets the corresponding bit in the INT\_EVENT\_RIS Register, irrespective of the security state of the corresponding INS bit.

#### DMA manager thread is in the Non-secure state

If the DNS bit is 1, the DMA manager thread operates in the Non-secure state, and it only performs non-secure instruction fetches. When a DMA manager thread in the Non-secure state processes:

#### **DMAGO**

The DMAC uses the status of the ns bit, to control if it starts a DMA channel thread. If:

ns = 0

The DMAC does not start a DMA channel thread and instead it:

- 1. Executes a NOP.
- 2. Sets the FSRD Register, see Fault Status DMA Manager
- 3. Sets the dmago\_err bit in the FTRD Register, see Fault Type DMA Manager Register.
- 4. Moves the DMA manager to the Faulting state.

ns = 1

The DMAC starts a DMA channel thread in the Non-secure state and programs the CNS bit to be non-secure.

#### **DMAWFE**

The DMAC uses the status of the corresponding INS bit, in the CR3 Register, to control if it waits for the event. If:

INS = 0

The event is in the Secure state. The DMAC:

- 1. Executes a NOP.
- 2. Sets the FSRD Register, see Fault Status DMA Manager Register.
- 3. Sets the mgr\_evnt\_err bit in the FTRD Register, see Fault Type DMA Manager Register.
- 4. Moves the DMA manager to the Faulting state.

INS = 1

The event is in the Non-secure state. The DMAC halts execution of the thread and waits for the event to occur.

#### **DMASEV**

The DMAC uses the status of the corresponding INS bit, in the CR3Register, to control if it creates the event-interrupt. If:

INS = 0

The event-interrupt resource is in the Secure state. The DMAC:

- 1. Executes a NOP.
- 2. Sets the FSRD Register, see Fault Status DMA Manager Register.



- 3. Sets the mgr\_evnt\_err bit in the FTRD Register, see Fault Type DMA Manager Register.
- 4. Moves the DMA manager to the Faulting state.

#### INS = 1

The event-interrupt resource is in the Non-secure state. The DMAC creates the event-interrupt.

#### **DMA** channel thread is in the Secure state

When the CNS bit is 0, the DMA channel thread is programmed to operate in the Secure state and it only performs secure instruction fetches. When a DMA channel thread in the Secure state processes the following instructions:

#### **DMAWFE**

The DMAC halts execution of the thread until the event occurs. When the event occurs, the DMAC continues execution of the thread, irrespective of the security state of the corresponding INS bit, in the CR3 Register.

#### **DMASEV**

The DMAC creates the event-interrupt, irrespective of the security state of the corresponding INS bit, in the CR3 Register.

#### **DMAWFP**

The DMAC halts execution of the thread until the peripheral signals a DMA request. When this occurs, the DMAC continues execution of the thread, irrespective of the security state of the corresponding PNS bit, in the CR4 Register.

### **DMALDP, DMASTP**

The DMAC sends a message to the peripheral to communicate that data transfer is complete, irrespective of the security state of the corresponding PNS bit, in the CR4 Register.

#### **DMAFLUSHP**

The DMAC clears the state of the peripheral and sends a message to the peripheral to resend its level status, irrespective of the security state of the corresponding PNS bit, in the CR4 Register.

When a DMA channel thread is in the Secure state, it enables the DMAC to perform secure and non-secure AXI accesses

#### DMA channel thread is in the Non-secure state

When the CNS bit is 1, the DMA channel thread is programmed to operate in the Non-secure state and it only performs non-secure instruction fetches. When a DMA channel thread in the Non-secure state processes the following instructions:

#### **DMAWFE**

The DMAC uses the status of the corresponding INS bit, in the CR3 Register, to control if it waits for the event. If:

INS = 0 The event is in the Secure state. The DMAC:



- 1. Executes a NOP.
- 2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register.
- 3. Sets the cheevnt err bit in the FTRn Register, see Fault Type DMA Channel Registers.
- 4. Moves the DMA channel to the Faulting completing state.

INS = 1 The event is in the Non-secure state. The DMAC halts execution of the thread and waits for the event to occur.

#### **DMASEV**

The DMAC uses the status of the corresponding INS bit, in the CR3 Register, to control if it creates the event. If:

INS = 0 The event-interrupt resource is in the Secure state. The DMAC:

- 1. Executes a NOP.
- 2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register.
- 3. Sets the ch\_evnt\_err bit in the FTRn Register, see Fault Type DMA Channel Registers.
- 4. Moves the DMA channel to the Faulting completing state.

INS = 1 The event-interrupt resource is in the Non-secure state. The DMAC creates the event-interrupt.

#### **DMAWFP**

The DMAC uses the status of the corresponding PNS bit, in the CR4 Register, to control if it waits for the peripheral to signal a request. If:

PNS = 0 The peripheral is in the Secure state. The DMAC:

- 1. Executes a NOP.
- 2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register.
- 3. Sets the chaperipherr bit in the FTRn Register, see Fault Type DMA Channel Registers.
- 4. Moves the DMA channel to the Faulting completing state.

PNS = 1 The peripheral is in the Non-secure state. The DMAC halts execution of the thread and waits for the peripheral to signal a request.

### **DMALDP, DMASTP**

The DMAC uses the status of the corresponding PNS bit, in the CR4 Register, to control if it sends an acknowledgement to the peripheral. If:

PNS = 0 The peripheral is in the Secure state. The DMAC:

- 1. Executes a NOP.
- 2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register.
- 3. Sets the ch\_periph\_err bit in the FTRn Register, see Fault Type DMA Channel
- 4. Moves the DMA channel to the Faulting completing state.
- PNS = 1 The peripheral is in the Non-secure state. The DMAC sends a message to the peripheral to communicate when the data transfer is complete.



#### **DMAFLUSHP**

The DMAC uses the status of the corresponding PNS bit, in the CR4 Register, to control if it sends a flush request to the peripheral. If:

PNS = 0 The peripheral is in the Secure state. The DMAC:

- 1. Executes a NOP.
- 2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Registe.
- 3. Sets the chaperigher pit in the FTRn Register, see Fault Type DMA Channel Registers.
- 4. Moves the DMA channel to the Faulting completing state.

PNS = 1 The peripheral is in the Non-secure state. The DMAC 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 Registe.
- 3. Sets the ch\_rdwr\_err bit in the FTRn Register, see Fault Type DMA Channel
- 4. Moves the DMA channel thread to the Faulting completing state.

### 10.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 cyclerestrictions

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.

### 10.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)

Depending upon the programmed values for the DMA transfer, one beat of read data from the AXI interface mneed to be split across two lines in the internal data buffer. This occurs when the read data beat contains datbytes 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 thisdefect.

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

| Source size in CCRn | Allowed offset between SARn and DARn |
|---------------------|--------------------------------------|
| SS8                 | any offset allowed.                  |
| SS16                | 0,2,4,6,8,10,12,14                   |
| SS32                | 0,4,8,12                             |
| SS64                | 0,8                                  |

#### 10.7.5 Interrupt shares between channel.

As the DMACO does not record which channel (or list of channels) have asserted an interrupt. So it will depend on your program and whether any of the visible information for that program can be used to determine progress, and help



identify the interrupt source.

There are 4 likely information sources that can be used to determine the progress made by a program:

- Program counter (PC)
- Source address
- Destination address
- Loop counters (LC)

For example, a program might emit an interrupt each time that it iterates around a loop. In this case, the interrupt service routine (ISR) would need to store the loop value of each channel when it is called, and then compare against the new value when it is next called. A change in value would indicate that the program has progressed.

The ISR must be carefully written to ensure that no interrupts are lost. The sequence of operations is as follows:

- 1. Disable interrupts
- 2. Immediately clear the interrupt in DMA-330
- 3. Check the relevant registers for both channels to determine which must be serviced
- 4. Take appropriate action for the channels
- 5. Re-enable interrupts and exit ISR

#### 10.7.6 Instruction sets

Table 10-2 DMAC Instruction sets

| Mnemonic  | Instruction                 | Thread usage:  • M = DMA manager  • C = DMA channel |
|-----------|-----------------------------|-----------------------------------------------------|
| DMAADDH   | Add Halfword                | С                                                   |
| DMAEND    | End                         | M/C                                                 |
| DMAFLUSHP | Flush and notify Peripheral | С                                                   |
| DMAGO     | Go                          | M                                                   |
| DMAKILL   | Kill                        | С                                                   |
| DMALD     | Load                        | С                                                   |
| DMALDP    | Load Peripheral             | С                                                   |
| DMALP     | Loop                        | С                                                   |
| DMALPEND  | Loop End                    | С                                                   |
| DMALPFE   | Loop Forever                | С                                                   |
| DMAMOV    | Move                        | С                                                   |
| DMANOP    | No operation                | M/C                                                 |
| DMARMB    | Read Memory Barrier         | С                                                   |
| DMASEV    | Send Event                  | M/C                                                 |
| DMAST     | Store                       | С                                                   |
| DMASTP    | Store and notify Peripheral | С                                                   |
| DMASTZ    | Store Zero                  | С                                                   |
| DMAWFE    | Wai t For Event M           | M/C                                                 |
| DMAWFP    | Wait For Peripheral         | С                                                   |
| DMAWMB    | Write Memory Barrier        | С                                                   |
| DMAADNH   | Add Negative Halfword       | С                                                   |

#### 10.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 DMA C 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 betwe en -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.

| Imm[15:8]    | Imm[7:0]                                | 0 | 1 | 0 | 1 | 1 | 1 | ra  | 0 |
|--------------|-----------------------------------------|---|---|---|---|---|---|-----|---|
| 111111[1310] | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 |   | - | _ | _ | _ | _ | , u | _ |

#### **Assembler syntax**

DMAADNH <address\_register>, <16-bit immediate>

where:

<address register>

Selects the address register to use. It must be either:

SAR

SARn Register and sets ra to 0.

DAR

DARn Register and sets ra to 1.

<16-bit immediate>

The immediate value to be added to the <address register>.

You should specify the 16-bit immediate as the number that is to be represented in the instruction encoding. For example, DMAADNH DAR, 0xFFF0 causes the value 0xFFFFFFF0 to be added to the current value of the Destination Address Register, effectively subtracting 16 from the DAR.

You can only use this instruction in a DMA channel thread.

10.7.8 MFIFO usage

For MFIFO usage , please refer to pl330\_trm.pdf

# **Chapter 11 DMAC1(DMA Controller)**

# 11.1 Overview

DMAC1 does not support TrustZone technology and work under non-secure state only.

DMAC1 is mainly used for data transfer of the following slaves: SMC , HSADC, PID\_FILTER, SD/MMC, SDIO, eMMC, HIF, UART1, UART2, UART3, SPI0, SPI1.

Following table shows the DMAC1 request mapping scheme.

Table 11-1DMAC1 Request Mapping Table

| Req number | Source     | Polarity   |
|------------|------------|------------|
| 0          | HSADC/TSI  | High level |
| 1          | SD/MMC     | High level |
| 2          | N/A        |            |
| 3          | SDIO       | High level |
| 4          | eMMC       | High level |
| 5          | PID_FILTER | High level |
| 6          | Uart2 tx   | High level |
| 7          | Uart2 rx   | High level |
| 8          | Uart3 tx   | High level |
| 9          | Uart3 rx   | High level |
| 10         | Spi0 tx    | High level |
| 11         | Spi0 rx    | High level |
| 12         | Spi1 tx    | High level |
| 13         | Spi1 rx    | High level |

DMAC1supports the following features:

- Supports 14 perihpral request.
- Up to 64bits data size.
- 7 channel at the same time.
- Up to burst 16.
- 1 interrupts output and one abort output.
- Supports 64 MFIFO depth.

# 11.2 Block Diagram

Figure 11-1 shows the block diagram of DMAC1





Fig. 11-1 Block diagram of dmac1

# 11.3 Function Description

Please refer to chapter 10.3 for the similar description.

# 11.4 Register Description

### 11.4.1 Register summary

|                  | 1      | •    |                | Y                                     |
|------------------|--------|------|----------------|---------------------------------------|
| Name             | Offset | Size | Reset<br>Value | Description                           |
| DMAC1_DSR        | 0x0000 | W    | 0x0            | DMA Status Register.                  |
| DMAC1_DPC        | 0x0004 | W    | 0×0            | DMA Program Counter<br>Register.      |
| -                | -      |      | -              | reserved                              |
| DMAC1_INTEN      | 0x0020 | W    | 0x0            | Interrupt Enable Register             |
| DMAC1_EVENT_R IS | 0x0024 | W    | 0x0            | Event Status Register.                |
| DMAC1_INTMIS     | 0x0028 | W    | 0x0            | Interrupt Status Register             |
| DMAC1_INTCLR     | 0x002C | W    | 0x0            | Interrupt Clear Register              |
| DMAC1_FSRD       | 0x0030 | W    | 0x0            | Fault Status DMA Manager<br>Register. |
| DMAC1_FSRC       | 0x0034 | W    | 0x0            | Fault Status DMA Channel Register.    |
| DMAC1_FTRD       | 0x0038 | W    | 0x0            | Fault Type DMA Manager<br>Register.   |
| -                | _      | -    | -              | reserved                              |
| DMAC1_FTR0       | 0x0040 | W    | 0x0            | Fault type for DMA Channel 0          |
| DMAC1_FTR1       | 0x0044 | W    | 0x0            | Fault type for DMA Channel 1          |
| DMAC1_FTR2       | 0x0048 | W    | 0x0            | Fault type for DMA Channel 2          |
| DMAC1_FTR3       | 0x004C | W    | 0x0            | Fault type for DMA Channel 3          |
| DMAC1_FTR4       | 0x0050 | W    | 0x0            | Fault type for DMA Channel 4          |
| DMAC1_FTR5       | 0x0054 | W    | 0x0            | Fault type for DMA Channel 5          |
| DMAC1_FTR6       | 0x0058 | W    | 0x0            | Fault type for DMA Channel 6          |
| -                | _      | -    | -              | reserved                              |
| DMAC1_CSR0       | 0x0100 | W    | 0x0            | Channel Status for DMA<br>Channel 0   |



| D144 04 00D4 | 0.0400 |   |     | Channel Status for DMA               |
|--------------|--------|---|-----|--------------------------------------|
| DMAC1_CSR1   | 0x0108 | W | 0x0 | Channel 1                            |
| DMAC1_CSR2   | 0x0110 | W | 0x0 | Channel Status for DMA Channel 2     |
| DMAC1_CSR3   | 0x0118 | W | 0x0 | Channel Status for DMA<br>Channel 3  |
| DMAC1_CSR4   | 0x0120 | W | 0x0 | Channel Status for DMA<br>Channel 4  |
| DMAC1_CSR5   | 0x0128 | W | 0x0 | Channel Status for DMA<br>Channel 5  |
| DMAC1_CSR6   | 0x0130 | W | 0x0 | Channel Status for DMA<br>Channel 6  |
| DMAC1_CPC0   | 0x0104 | W | 0x0 | Channel PC for DMA Channel 0         |
| DMAC1_CPC1   | 0x010c | W | 0x0 | Channel PC for DMA Channel 1         |
| DMAC1_CPC2   | 0x0114 | W | 0x0 | Channel PC for DMA Channel 2         |
| DMAC1_CPC3   | 0x011c | W | 0x0 | Channel PC for DMA Channel 3         |
| DMAC1 CPC4   | 0x0124 | W | 0x0 | Channel PC for DMA Channel 4         |
| DMAC1 CPC5   | 0x012c | W | 0x0 | Channel PC for DMA Channel 5         |
| DMAC1 CPC6   | 0x0134 | W | 0x0 | Channel PC for DMA Channel 6         |
| DMAC1_SAR0   | 0x0400 | W | 0x0 | Source Address for DMA<br>Channel 0  |
| DMAC1_SAR1   | 0x0420 | W | 0x0 | Source Address for DMA<br>Channel 1  |
| DMAC1_SAR2   | 0x0440 | W | 0x0 | Source Address for DMA Channel 2     |
| DMAC1_SAR3   | 0x0460 | W | 0x0 | Source Address for DMA Channel 3     |
| DMAC1_SAR4   | 0x0480 | W | 0x0 | Source Address for DMA<br>Channel 4  |
| DMAC1_SAR5   | 0x04a0 | W | 0x0 | Source Address for DMA Channel 5     |
| DMAC1_SAR6   | 0x04c0 | W | 0x0 | Source Address for DMA Channel 6     |
| DMAC1_DAR0   | 0x0404 | W | 0x0 | Dest Address for DMAChannel 0        |
| DMAC1_DAR1   | 0x0424 | W | 0x0 | Dest Address for DMAChannel 1        |
| DMAC1_DAR2   | 0x0444 | W | 0x0 | Dest Address for DMAChannel 2        |
| DMAC1_DAR3   | 0x0464 | W | 0x0 | Dest Address for DMAChannel 3        |
| DMAC1_DAR4   | 0x0484 | W | 0x0 | Dest Address for DMAChannel 4        |
| DMAC1_DAR5   | 0x04a4 | W | 0x0 | Dest Address for DMAChannel 5        |
| DMAC1_DAR6   | 0x04c4 | W | 0x0 | Dest Address for DMAChannel 6        |
| DMAC1_CCR0   | 0x0408 | W | 0×0 | Channel Control for DMA<br>Channel 0 |
| DMAC1_CCR1   | 0x0428 | W | 0×0 | Channel Control for DMA<br>Channel 1 |
| DMAC1_CCR2   | 0x0448 | W | 0x0 | Channel Control for DMA<br>Channel 2 |



| DMAC1_CCR3                | 0x0468     | W | 0x0 | Channel Control for DMA Channel 3    |
|---------------------------|------------|---|-----|--------------------------------------|
| DMAC1_CCR4                | 0x0488     | W | 0x0 | Channel Control for DMA<br>Channel 4 |
| DMAC1_CCR5                | 0x04a8     | W | 0x0 | Channel Control for DMA<br>Channel 5 |
| DMAC1_CCR6                | 0x04c8     | W | 0x0 | Channel Control for DMA<br>Channel 6 |
| DMAC1_LC0_0               | 0x040C     | W | 0x0 | Loop Counter 0 for DMA<br>Channel 0  |
| DMAC1_LC0_1               | 0x042C     | W | 0x0 | Loop Counter 0 for DMA Channel 1     |
| DMAC1_LC0_2               | 0x044C     | W | 0x0 | Loop Counter 0 for DMA<br>Channel 2  |
| DMAC1_LC0_3               | 0x046C     | W | 0x0 | Loop Counter 0 for DMA<br>Channel 3  |
| DMAC1_LC0_4               | 0x048C     | W | 0×0 | Loop Counter 0 for DMA<br>Channel 4  |
| DMAC1_LC0_5               | 0x04aC     | W | 0x0 | Loop Counter 0 for DMA<br>Channel 5  |
| DMAC1_LC0_6               | 0x04cC     | W | 0x0 | Loop Counter 0 for DMA<br>Channel 6  |
| DMAC1_LC1_0               | 0x0410     | W | 0x0 | Loop Counter 1 for DMA<br>Channel 0  |
| DMAC1_LC1_1               | 0x0430     | W | 0x0 | Loop Counter 1 for DMA<br>Channel 1  |
| DMAC1_LC1_2               | 0x0450     | W | 0x0 | Loop Counter 1 for DMA<br>Channel 2  |
| DMAC1_LC1_3               | 0x0470     | W | 0×0 | Loop Counter 1 for DMA<br>Channel 3  |
| DMAC1_LC1_4               | 0x0490     | W | 0x0 | Loop Counter 1 for DMA<br>Channel 4  |
| DMAC1_LC1_5               | 0x04b0     | W | 0x0 | Loop Counter 1 for DMA<br>Channel 5  |
| DMAC1_LC1_6               | 0x04d0     | W | 0x0 | Loop Counter 1 for DMA<br>Channel 6  |
| -                         | , <b>-</b> | - | -   | reserved                             |
| DMAC1_DBGST<br>DMAC1_ATUS | 0x0D00     | W | 0x0 | Debug Status Register.               |
| DMAC1 DBGCMD              | 0x0D04     | W | 0x0 | Debug Command Register.              |
| DMAC1_DBGINS<br>T0        | 0x0D08     | W | 0x0 | Debug Instruction-0 Register.        |
| DMAC1_DBGINS<br>T1        | 0x0D0C     | W | 0x0 | Debug Instruction-1 Register.        |
| DMAC1_CR0                 | 0x0E00     | W |     | Configuration Register 0.            |
| DMAC1 CR1                 | 0x0E04     | W |     | Configuration Register 1.            |
| DMAC1 CR2                 | 0x0E08     | W |     | Configuration Register 2.            |
| DMAC1 CR3                 | 0x0E0C     | W |     | Configuration Register 3.            |
| DMAC1 CR4                 | 0x0E10     | W |     | Configuration Register 4.            |
| DMAC1_CRDn                | 0x0E14     | W |     | Configuration Register Dn.           |
| DMAC1_WD                  | 0X0E80     | W |     | Watchdog Register                    |
|                           |            |   | •   |                                      |

Notes:

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



## 11.4.2 Detail Register Description

# DMAC1\_DSR

Address:Operational Base+0x0 DMA Manager Status Register

|       |      | Status Register |                                                                                                                                                                                      |
|-------|------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit   | Attr | Reset Value     | Description                                                                                                                                                                          |
| 31:10 | -    | -               | Reserved                                                                                                                                                                             |
| 9     | R    | 0x0             | Provides the security status of the DMA manager thread:  0 = DMA manager operates in the Secure state  1 = DMA manager operates in the Non-secure state.                             |
| 8:4   | R    | 0x0             | When the DMA manager thread executes a DMAWFE instruction, it waits for the following event to occur:  b00000 = event[0]  b00001 = event[1]  b00010 = event[2]   b11111 = event[31]. |
| 3:0   | R    | 0x0             | The operating state of the DMA manager: b0000 = Stopped b0001 = Executing b0010 = Cache miss b0011 = Updating PC b0100 = Waiting for event b0101-b1110 = reserved b1111 = Faulting.  |

### DMAC1\_DPC

Address: Operational Base+0x4
DMA Program Counter Register

|      |   | Reset Value |                                            |
|------|---|-------------|--------------------------------------------|
| 31:0 | R | 0x0         | Program counter for the DMA manager thread |

## DMAC1\_INTEN

Address:Operational Base+0x20

Interrupt Enable Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                      |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0×0         | Program the appropriate bit to control how the DMAC responds when it executes DMASEV: Bit [N] = 0 If the DMAC executes DMASEV for the event-interrupt resource N then the DMAC signals event N to all of the threads. Set bit [N] to 0 if your system design does not use irq[N] to signal an interrupt request. |
|      |      |             | Bit [N] = 1 If the DMAC executes DMASEV for<br>the event-interrupt resource N then the DMAC<br>sets irq[N] HIGH. Set bit [N] to 1 if your system<br>designer requires irq[N] to signal an interrupt                                                                                                              |



## **DMAC1\_EVENT\_RIS**

Address: Operational Base+0x24 Event-Interrupt Raw Status Register

| Bit  | Attr | Reset Value | Description                                                                                                                                               |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | R    | 0x0         | Returns the status of the event-interrupt resources:  Bit [N] = 0 Event N is inactive or irq[N] is LOW.  Bit [N] = 1 Event N is active or irq[N] is HIGH. |

### **DMAC1\_INTMIS**

Address:Operational Base+0x28

Interrupt Status Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                          |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | R    | 0x0         | Provides the status of the interrupts that are active in the DMAC:  Bit [N] = 0 Interrupt N is inactive and therefore irq[N] is LOW.  Bit [N] = 1 Interrupt N is active and therefore irq[N] is HIGH |

## DMAC1\_INTCLR

Address: Operational Base+0x2c

Interrupt Clear Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                          |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | W    | 0x0         | Controls the clearing of the irq outputs:  Bit [N] = 0 The status of irq[N] does not change.  Bit [N] = 1 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. |

### DMAC1\_FSRD

Address: Operational Base+0x30

Fault Status DMA Manager Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                         |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | R    | 0x0         | Provides the fault status of the DMA manager. Read as: 0 = the DMA manager thread is not in the Faulting state 1 = the DMA manager thread is in the Faulting state. |

## DMAC1\_FSRC

Address:Operational Base+0x34

Fault Status DMA Channel Register

| Bit  | Attr | Reset Value | Description                                                                                                                   |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | R    | 0x0         | Each bit provides the fault status of the corresponding channel. Read as: Bit $[N] = 0$ No fault is present on DMA channel N. |



| Bit $[N] = 1$ DMA channel N is in the Faulting or |
|---------------------------------------------------|
| Faulting completing state.                        |

# DMAC1\_FTRD

Address:Operational Base+0x38 Fault Type DMA Manager Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                       |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    |      | -           | reserved                                                                                                                                                                                                                                                                                                                                                          |
| 30    | R    | 0x0         | If the DMA manager aborts, this bit indicates if the erroneous instruction was read from the system memory or from the debug interface:  0 = instruction that generated an abort was read from system memory  1 = instruction that generated an abort was read from the debug interface.                                                                          |
| 29:17 | -    | -           | reserved                                                                                                                                                                                                                                                                                                                                                          |
| 16    | R    | 0x0         | Indicates the AXI response that the DMAC receives on the RRESP bus, after the DMA manager performs an instruction fetch:  0 = OKAY response  1 = EXOKAY, SLVERR, or DECERR response                                                                                                                                                                               |
| 15:6  | -    | -           | reserved                                                                                                                                                                                                                                                                                                                                                          |
| 5     | R    | 0x0         | Indicates if the DMA manager was attempting to execute DMAWFE or DMASEV with inappropriate security permissions:  0 = DMA manager has appropriate security to execute DMAWFE or DMASEV  1 = a DMA manager thread in the Non-secure state attempted to execute either:  • DMAWFE to wait for a secure event  • DMASEV to create a secure event or secure interrupt |
| 4     | R    | 0×0         | ndicates if the DMA manager was attempting to execute DMAGO with inappropriate security permissions:  0 = DMA manager has appropriate security to execute DMAGO  1 = 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   |      | -           | reserved                                                                                                                                                                                                                                                                                                                                                          |
| 1     | R    | 0x0         | Indicates if the DMA manager was attempting to execute an instruction operand that was not valid for the configuration of the DMAC:  0 = valid operand  1 = invalid operand.                                                                                                                                                                                      |
| 0     | R    | 0x0         | Indicates if the DMA manager was attempting to execute an undefined instruction:  0 = defined instruction  1 = undefined instruction.                                                                                                                                                                                                                             |

# DMAC1\_FTR0~DMAC1\_FTR6

Address:Operational Base+0x40



Operational Base+0x44

Operational Base+0x48

Operational Base+0x4c Operational Base+0x50

Operational Base+0x54

Operational Base+0x58

Fault Type DMA Channel Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Dic   | Acci | Reset value | Indicates if the DMA channel has locked-up                                                                                                                                                                                                                                                                                                                                        |
|       |      |             | because of resource starvation:                                                                                                                                                                                                                                                                                                                                                   |
| 31    | R    | 0x0         | 0 = DMA channel has adequate resources                                                                                                                                                                                                                                                                                                                                            |
| 31    |      | OXO         | 1 = DMA channel has locked-up because of                                                                                                                                                                                                                                                                                                                                          |
|       |      |             | insufficient resources.                                                                                                                                                                                                                                                                                                                                                           |
|       |      |             | This fault is an imprecise abort                                                                                                                                                                                                                                                                                                                                                  |
| 30    | R    | 0x0         | If the DMA channel aborts, this bit indicates if the erroneous instruction was read from the system memory or from the debug interface:  0 = instruction that generated an abort was read from system memory  1 = instruction that generated an abort was read from the debug interface.  This fault is an imprecise abort but the bit is only valid when a precise abort occurs. |
| 29:19 | -    | -           | reserved                                                                                                                                                                                                                                                                                                                                                                          |
| 18    | R    | 0x0         | Indicates the AXI response that the DMAC receives on the RRESP bus, after the DMA channel thread performs a data read:  0 = OKAY response  1 = EXOKAY, SLVERR, or DECERR response.  This fault is an imprecise abort                                                                                                                                                              |
|       |      | . (         | Indicates the AXI response that the DMAC                                                                                                                                                                                                                                                                                                                                          |
| 17    | R    | 0x0         | receives on the BRESP bus, after the DMA channel thread performs a data write:  0 = OKAY response  1 = EXOKAY, SLVERR, or DECERR response.  This fault is an imprecise abort.                                                                                                                                                                                                     |
|       |      | 1           | Indicates the AXI response that the DMAC                                                                                                                                                                                                                                                                                                                                          |
| 16    | R    | 0×0         | receives on the RRESP bus, after the DMA channel thread performs an instruction fetch:  0 = OKAY response  1 = EXOKAY, SLVERR, or DECERR response.                                                                                                                                                                                                                                |
|       | ~    |             | This fault is a precise abort.                                                                                                                                                                                                                                                                                                                                                    |
| 15:14 | -    | -           | reserved                                                                                                                                                                                                                                                                                                                                                                          |
| 13    | R    | 0×0         | Indicates if the MFIFO did not contain the data to enable the DMAC to perform the DMAST:  0 = MFIFO contains all the data to enable the DMAST to complete  1 = previous DMALDs have not put enough data in the MFIFO to enable the DMAST to complete. This fault is a precise abort.                                                                                              |
| 12    | R    | 0×0         | Indicates if the MFIFO prevented the DMA channel thread from executing DMALD or DMAST. Depending on the instruction:  DMALD 0 = MFIFO contains sufficient space                                                                                                                                                                                                                   |



|      | 1            | T   |                                                         |
|------|--------------|-----|---------------------------------------------------------|
|      |              |     | 1 = MFIFO is too small to hold the data that            |
|      |              |     | DMALD requires.                                         |
|      |              |     | DMAST 0 = MFIFO contains sufficient data                |
|      |              |     | 1 = MFIFO is too small to store the data to             |
|      |              |     | enable DMAST to complete.                               |
|      |              |     | This fault is an imprecise abort                        |
| 11:8 | -            | -   | reserved                                                |
|      |              |     | Indicates if a DMA channel thread, in the               |
|      |              |     | Non-secure state, attempts to program the               |
|      |              |     | CCRn Register to perform a secure read or               |
|      |              |     | secure write:                                           |
|      |              |     | 0 = a DMA channel thread in the Non-secure              |
| 7    | R            | 0x0 | state is not violating the security permissions         |
|      |              |     |                                                         |
|      |              |     | 1 = a DMA channel thread in the Non-secure              |
|      |              |     | state attempted to perform a secure read or             |
|      |              |     | secure write.                                           |
|      |              |     | This fault is a precise abort                           |
|      |              |     | Indicates if a DMA channel thread, in the               |
|      |              |     | Non-secure state, attempts to execute DMAWFP,           |
|      |              |     | DMALDP, DMASTP, or DMAFLUSHP with                       |
|      |              |     | inappropriate security permissions:                     |
|      |              |     | 0 = a DMA channel thread in the Non-secure              |
|      |              |     | state is not violating the security permissions         |
| 6    | R            | 0x0 | 1 = a DMA channel thread in the Non-secure              |
|      |              |     | state attempted to execute either:                      |
|      |              |     | DMAWFP to wait for a secure peripheral                  |
|      |              |     | <ul> <li>DMALDP or DMASTP to notify a secure</li> </ul> |
|      |              |     | peripheral                                              |
|      |              |     | DMAFLUSHP to flush a secure peripheral.                 |
|      |              |     | This fault is a precise abort.                          |
|      |              |     | Indicates if the DMA channel thread attempts to         |
|      |              |     | execute DMAWFE or DMASEV with inappropriate             |
|      |              |     | security permissions:                                   |
|      |              | AAY | 0 = a DMA channel thread in the Non-secure              |
|      |              |     | state is not violating the security permissions         |
| 5    | R            | 0x0 | 1 = a DMA channel thread in the Non-secure              |
|      | \ \          | 1   | state attempted to execute either:                      |
|      |              | 7   | DMAWFE to wait for a secure event                       |
|      |              | 7   | DMASEV to create a secure event or secure               |
|      |              | 1   | interrupt.                                              |
|      |              |     | This fault is a precise abort.                          |
| 4:2  |              | _   | reserved                                                |
|      |              |     | Indicates if the DMA channel thread was                 |
|      |              |     | attempting to execute an instruction operand            |
|      |              |     | that was not valid for the configuration of the         |
| 1    | R            | 0x0 | DMAC:                                                   |
| _    | '`           | 0,0 | 0 = valid operand                                       |
|      |              |     | ·                                                       |
|      |              |     | 1 = invalid operand.                                    |
|      |              |     | This fault is a precise abort.                          |
|      |              |     | Indicates if the DMA channel thread was                 |
|      | <sub>D</sub> | 0.0 | attempting to execute an undefined instruction:         |
| 0    | R            | 0x0 | 0 = defined instruction                                 |
|      |              |     | 1 = undefined instruction.                              |
|      |              |     | This fault is a precise abort                           |



## DMAC1\_CSR0~DMAC1\_CSR6

Address:Operational Base+0x100

Operational Base+0x108

Operational Base+0x110

Operational Base+0x118

Operational Base+0x120

Operational Base+0x128

Operational Base+0x130

Channel Status Registers

| Bit   | Attr | s Registers<br>Reset Value | Doscrintion                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Attr | Reset value                | Description                                                                                                                                                                                                                                                                                                                                                           |
| 31:22 | -    | -                          | reserved The channel non-secure bit provides the security                                                                                                                                                                                                                                                                                                             |
| 21    | R    | 0x0                        | of the DMA channel:  0 = DMA channel operates in the Secure state  1 = DMA channel operates in the Non-secure state                                                                                                                                                                                                                                                   |
| 20:16 | -    | -                          | reserved                                                                                                                                                                                                                                                                                                                                                              |
| 15    | R    | 0x0                        | When the DMA channel thread executes DMAWFP this bit indicates if the periph operand was set:  0 = DMAWFP executed with the periph operand not set  1 = DMAWFP executed with the periph operand set                                                                                                                                                                   |
| 14    | R    | 0x0                        | When the DMA channel thread executes DMAWFP this bit indicates if the burst or single operand were set:  0 = DMAWFP executed with the single operand set  1 = DMAWFP executed with the burst operand set.                                                                                                                                                             |
| 13:9  | -    | -                          | reserved                                                                                                                                                                                                                                                                                                                                                              |
| 8:4   | R    | 0x0                        | If the DMA channel is in the Waiting for event state or the Waiting for peripheral state then these bits indicate the event or peripheral number that the channel is waiting for: b00000 = DMA channel is waiting for event, or peripheral, 0 b00001 = DMA channel is waiting for event, or peripheral, 1 b00010 = DMA channel is waiting for event, or peripheral, 2 |
| 3:0   | R    | 0x0                        | The channel status encoding is:<br>b0000 = Stopped<br>b0001 = Executing<br>b0010 = Cache miss<br>b0011 = Updating PC<br>b0100 = Waiting for event                                                                                                                                                                                                                     |



| b010 | 1 = At barrier             |
|------|----------------------------|
| b011 | 0 = reserved               |
| b011 | 1 = Waiting for peripheral |
| b100 | 0 = Killing                |
| b100 | 1 = Completing             |
|      | 0-b1101 = reserved         |
| b111 | 0 = Faulting completing    |
|      | 1 = Faulting               |

#### DMAC1\_CPC0~DMAC1\_CPC6

Address: Operational Base+0x104

Operational Base+0x10c Operational Base+0x114

Operational Base+0x11c

Operational Base+0x124

Operational Base+0x12c

Operational Base+0x134

Channel Program Counter Registers

| Bit  | Attr | Reset Value | Description                                  |
|------|------|-------------|----------------------------------------------|
| 31:0 | R    | 0x0         | Program counter for the DMA channel n thread |

#### DMAC1\_SAR0~DMAC1\_SAR6

Address: Operational Base+0x400

Operational Base+0x420

Operational Base+0x440

Operational Base+0x460

Operational Base+0x480

Operational Base+0x4a0

Operational Base+0x4c0

#### **Source Address Registers**

| Bit  | Attr | Reset Value | Description                                  |
|------|------|-------------|----------------------------------------------|
| 31:0 | R    | 0x0         | Address of the source data for DMA channel n |

#### DMAC1\_DAR0~DMAC1\_DAR5

Address: Operational Base+0x404

Operational Base+0x424

Operational Base+0x444

Operational Base+0x464

Operational Base+0x484

Operational Base+0x4a4

DestinationAddress Registers

| Bit  | Attr | Reset Value | Description                                      |
|------|------|-------------|--------------------------------------------------|
| 31:0 | R    | 0x0         | Address of the Destinationdata for DMA channel n |
| 31.0 | '`   | OXO         |                                                  |

#### DMAC1\_CCR0~DMAC1\_CCR6

Address: Operational Base+0x408

Operational Base+0x428

Operational Base+0x448

Operational Base+0x468

Operational Base+0x488

Operational Base+0x4a8

Operational Base+0x4c8

Channel Control Registers



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | -    | -           | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 27:25 | R    | 0×0         | Programs the state of AWCACHE[3,1:0]a when the DMAC writes the destination data.  Bit [27] 0 = AWCACHE[3] is LOW 1 = AWCACHE[3] is HIGH.  Bit [26] 0 = AWCACHE[1] is LOW 1 = AWCACHE[1] is HIGH.  Bit [25] 0 = AWCACHE[0] is LOW 1 = AWCACHE[0] is HIGH                                                                                                                                                                                                 |
| 24:22 | R    | 0x0         | Programs the state of AWPROT[2:0]a when the DMAC writes the destination data.  Bit [24] 0 = AWPROT[2] is LOW 1 = AWPROT[2] is HIGH.  Bit [23] 0 = AWPROT[1] is LOW 1 = AWPROT[1] is HIGH.  Bit [22] 0 = AWPROT[0] is LOW 1 = AWPROT[0] is HIGH                                                                                                                                                                                                          |
| 21:18 | R    | 0x0         | For each burst, these bits program the number of data transfers that the DMAC performs when it writes the destination data: b0000 = 1 data transfer b0001 = 2 data transfers b0010 = 3 data transfers                                                                                                                                                                                                                                                   |
| 17:15 | R    | 0x0         | For each beat within a burst, it programs the number of bytes that the DMAC writes to the destination:  b000 = writes 1 byte per beat  b001 = writes 2 bytes per beat  b010 = writes 4 bytes per beat  b011 = writes 8 bytes per beat  b100 = writes 16 bytes per beat  b101-b111 = reserved.  The total number of bytes that the DMAC writes out of the MFIFO when it executes a DMAST instruction is the product of dst_burst_len and dst_burst_size. |
| 14    | R    | 0x0         | Programs the burst type that the DMAC performs when it writes the destination data:  0 = Fixed-address burst. The DMAC signals AWBURST[0] LOW.  1 = Incrementing-address burst. The DMAC signals AWBURST[0] HIGH.                                                                                                                                                                                                                                       |
| 13:11 | R    | 0x0         | Set the bits to control the state of ARCACHE[2:0]a when the DMAC reads the source data.                                                                                                                                                                                                                                                                                                                                                                 |



|      | 1     |     | DIL [42] O ADCACHE[2]: LOW                                       |
|------|-------|-----|------------------------------------------------------------------|
|      |       |     | Bit [13] 0 = ARCACHE[2] is LOW                                   |
|      |       |     | 1 = ARCACHE[2] is HIGH.                                          |
|      |       |     | Bit [12] 0 = ARCACHE[1] is LOW                                   |
|      |       |     | 1 = ARCACHE[1] is HIGH.                                          |
|      |       |     | Bit [11] $0 = ARCACHE[0]$ is LOW                                 |
|      |       |     | 1 = ARCACHE[0] is HIGH.                                          |
|      |       |     | Programs the state of ARPROT[2:0]a when the                      |
|      |       |     | DMAC reads the source data.                                      |
|      |       |     | Bit $[10]$ 0 = ARPROT $[2]$ is LOW                               |
| 10:8 | R     | 0x0 | 1 = ARPROT[2] is HIGH.                                           |
| 10.6 | \ \ \ | UXU | Bit $[9]$ 0 = ARPROT $[1]$ is LOW                                |
|      |       |     | 1 = ARPROT[1] is HIGH.                                           |
|      |       |     | Bit [8] 0 = ARPROT[0] is LOW                                     |
|      |       |     | 1 = ARPROT[0] is HIGH.                                           |
|      |       |     | For each burst, these bits program the number                    |
|      |       |     | of data transfers that the DMAC performs when                    |
|      |       |     | it reads the source data:                                        |
|      |       |     | b0000 = 1 data transfer                                          |
|      |       |     | b0001 = 2 data transfers                                         |
|      |       |     | b0010 = 3 data transfers                                         |
|      |       |     |                                                                  |
| 7:4  | R     | 0x0 |                                                                  |
|      |       |     | • 0                                                              |
|      |       |     | b1111 = 16 data transfers.                                       |
|      |       |     | The total number of bytes that the DMAC reads                    |
|      |       |     | into the MFIFO when it executes a DMALD                          |
|      |       |     | instruction is the product of src_burst_len and                  |
|      |       |     | src_burst_size                                                   |
|      |       |     | For each beat within a burst, it programs the                    |
|      |       |     | number of bytes that the DMAC reads from the                     |
|      |       |     | source:                                                          |
|      |       | - 4 | b000 = reads 1 byte per beat                                     |
|      |       | • \ | b000 = reads 1 byte per beat<br>b001 = reads 2 bytes per beat    |
|      |       |     | b010 = reads 2 bytes per beat<br>b010 = reads 4 bytes per beat   |
| 3:1  | D     | 0×0 | b010 = reads 4 bytes per beat<br>  b011 = reads 8 bytes per beat |
| J.1  | K     | UXU | b110 = reads 8 bytes per beat                                    |
|      |       |     | b100 = reads 16 bytes per beat<br>  b101-b111 = reserved.        |
|      |       |     | The total number of bytes that the DMAC reads                    |
|      |       | 7   | ,                                                                |
|      |       | )   | into the MFIFO when it executes a DMALD                          |
|      |       |     | instruction is the product of src_burst_len and                  |
| 1    |       |     | src_burst_size                                                   |
|      |       |     | Programs the burst type that the DMAC                            |
|      |       |     | performs when it reads the source data:                          |
| 0    | R     | 0x0 | 0 = Fixed-address burst. The DMAC signals                        |
|      |       |     | ARBURST[0] LOW.                                                  |
|      |       |     | 1 = Incrementing-address burst. The DMAC                         |
|      |       |     | signals ARBURST[0] HIGH                                          |

### DMAC1\_LCO\_0~DMAC1\_LCO\_6

Address:Operational Base+0x40c

Operational Base+0x42c Operational Base+0x44c Operational Base+0x46c Operational Base+0x48c



Operational Base+0x4ac Operational Base+0x4cc

Loop Counter 0 Registers

| Bit  | Attr | Reset Value | Description               |
|------|------|-------------|---------------------------|
| 31:8 | -    | -           | reserved                  |
| 7:0  | R    | 0x0         | Loop counter 0 iterations |

## DMAC1\_LC1\_0~DMAC1\_LC1\_6

Address:Operational Base+0x410

Operational Base+0x430 Operational Base+0x450 Operational Base+0x470 Operational Base+0x490 Operational Base+0x4b0 Operational Base+0x4e0

Loop Counter 1 Registers

| Bit  | Attr | Reset Value | Description               |
|------|------|-------------|---------------------------|
| 31:8 | -    | -           | reserved                  |
| 7:0  | R    | 0x0         | Loop counter 1 iterations |

### DMAC1\_DBGSTATUS

Address:Operational Base+0xd00

Debug Status Register

| Bit  | Attr | Reset Value | Description                                                                                                                                            |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | -    | -           | reserved                                                                                                                                               |
| 1:0  | R    | 0x0         | The debug encoding is as follows: b00 = execute the instruction that the DBGINST [1:0] Registers contain b01 = reserved b10 = reserved b11 = reserved. |

## DMAC1\_DBGCMD

Address: Operational Base+0xd04

Debug Command Register

| Bit  | Attr | Reset Value | Description                                                                                                                                           |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | -(   | )-          | reserved                                                                                                                                              |
| 1:0  | >    | 0x0         | The debug encoding is as follows: b00 = execute the instruction that the DBGINST [1:0] Registers contain b01 = reserved b10 = reserved b11 = reserved |

### **DMAC1\_DBGINSTO**

Address: Operational Base+0xd08

Debug Instruction-0 Register

| Bit   | Attr | <b>Reset Value</b> | Description        |
|-------|------|--------------------|--------------------|
| 31:24 | W    | 0x0                | Instruction byte 1 |
| 23:16 | W    | 0x0                | Instruction byte 0 |
| 17:11 | -    | -                  | reserved           |



| 10:8 | W | 0x0 | DMA channel number:<br>b000 = DMA channel 0<br>b001 = DMA channel 1<br>b010 = DMA channel 2<br><br>b111 = DMA channel 7 |
|------|---|-----|-------------------------------------------------------------------------------------------------------------------------|
| 7:1  | - | -   | reserved                                                                                                                |
| 0    | W | 0x0 | The debug thread encoding is as follows:  0 = DMA manager thread  1 = DMA channel.                                      |

### DMAC1\_DBGINST1

Address:Operational Base+0xd0c

Debug Instruction-1 Register

| Bit   | Attr | Reset Value | Description        |
|-------|------|-------------|--------------------|
| 31:24 | W    | 0x0         | Instruction byte 5 |
| 23:16 | W    | 0x0         | Instruction byte 4 |
| 15:8  | W    | 0x0         | Instruction byte 3 |
| 7:0   | W    | 0x0         | Instruction byte 2 |

## DMAC1\_CR0

Address:Operational Base+0xe00

Configuration Register 0

| Bit   | Attr | Reset Value | Description                                                                                                                                                              |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | -    | -           | reserved                                                                                                                                                                 |
| 21:17 | R    | 0x2         | Number of interrupt outputs that the DMAC provides:  b00000 = 1 interrupt output, irq[0]  b00001 = 2 interrupt outputs, irq[1:0]  b00010 = 3 interrupt outputs, irq[2:0] |
|       |      |             | b11111 = 32 interrupt outputs, irq[31:0].                                                                                                                                |
|       | ~ (  | 4           | Number of peripheral request interfaces that the DMAC provides: b00000 = 1 peripheral request interface b00001 = 2 peripheral request interfaces                         |
| 16:12 | R    | 0x7         | b00010 = 3 peripheral request interfaces                                                                                                                                 |
| 3     |      |             |                                                                                                                                                                          |
|       |      |             | b11111 = 32 peripheral request interfaces.                                                                                                                               |
| 11:7  | -    | -           | reserved                                                                                                                                                                 |
| 6:4   | R    | 0x5         | Number of DMA channels that the DMAC supports: $b000 = 1 \text{ DMA channel}$ $b001 = 2 \text{ DMA channels}$ $b010 = 3 \text{ DMA channels}$ .                          |
|       |      |             | b111 = 8 DMA channels.                                                                                                                                                   |



| 3 | - | -   | reserved                                                                                                                                                                                                |
|---|---|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2 | R | 0×0 | Indicates the status of the boot_manager_ns signal when the DMAC exited from reset:  0 = boot_manager_ns was LOW  1 = boot_manager_ns was HIGH.                                                         |
| 1 | R | 0x0 | Indicates the status of the boot_from_pc signal when the DMAC exited from reset:  0 = boot_from_pc was LOW  1 = boot_from_pc was HIGH                                                                   |
| 0 | R | 0x1 | Supports peripheral requests:  0 = the DMAC does not provide a peripheral request interface  1 = the DMAC provides the number of peripheral request interfaces that the num_periph_req field specifies. |

### DMAC1\_CR1

Address:Operational Base+0xe04

Configuration Register 1

| Connig | aradion | Register 1  |                                                                                                                                                          |
|--------|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit    | Attr    | Reset Value | Description                                                                                                                                              |
| 31:8   | -       | -           | reserved                                                                                                                                                 |
| 7:4    | R       | 0x5         | [7:4] num_i-cache_lines Number of i-cache lines:  b0000 = 1 i-cache line  b0001 = 2 i-cache lines  b0010 = 3 i-cache lines  b1111 = 16 i-cache lines.    |
| 3      | -       | -           | reserved                                                                                                                                                 |
| 2:0    | R       | 0x7         | The length of an i-cache line:<br>b000-b001 = reserved<br>b010 = 4 bytes<br>b011 = 8 bytes<br>b100 = 16 bytes<br>b101 = 32 bytes<br>b110-b111 = reserved |

# DMAC1\_CR2

Address: Operational Base+0xe08

Configuration Register 2

| Bit    | Attr | Reset Value | Description                                    |
|--------|------|-------------|------------------------------------------------|
| 31:0   | D    | 0×0         | Provides the value of boot_addr[31:0] when the |
| 31:0 > | K    | 0x0         | DMAC exited from reset                         |

## DMAC1\_CR3

Address:Operational Base+0xe0c

Configuration Register 3

| resource:  Rit [N] = 0 Assigns event <n> or irg[N] to t</n> | Bit  | Attr | Reset Value | Description                                                                                                                                                                      |
|-------------------------------------------------------------|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Secure state.                                               | 31:0 | R    | 0x0         | Provides the security state of an event-interrupt resource:  Bit [N] = 0 Assigns event <n> or irq[N] to the Secure state.  Bit [N] = 1 Assigns event<n> or irq[N] to the</n></n> |



Address:Operational Base+0xe10

Configuration Register 4

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                            |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | R    | 0x6         | Provides the security state of the peripheral request interfaces:  Bit [N] = 0 Assigns peripheral request interface N to the Secure state.  Bit [N] = 1 Assigns peripheral request interface N to the Non-secure state |

## DMAC1\_CRDn

Address:Operational Base+0xe14

DMA Configuration Register

| Bit   | Attr | Reset Value | Description                                                                                                           |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------|
| 31:30 | -    | -           | reserved                                                                                                              |
| 29:20 | R    | 0x20        | The number of lines that the data buffer contains: b000000000 = 1 line b00000001 = 2 lines b111111111 = 1024 lines    |
| 19:16 | R    | 0x9         | The depth of the read queue: b0000 = 1 line b0001 = 2 lines b1111 = 16 lines.                                         |
| 15    | -    | -           | reserved                                                                                                              |
| 14:12 | R    | 0x4         | Read issuing capability that programs the number of outstanding read transactions: $b000 = 1$ $b001 = 2$ $b111 = 8$   |
| 11:8  | R    | 0x7         | The depth of the write queue:  b0000 = 1 line  b0001 = 2 lines  b1111 = 16 lines.                                     |
| 7     | -    | -           | reserved                                                                                                              |
| 6:4   | R    | 0x3         | Write issuing capability that programs the number of outstanding write transactions: $b000 = 1$ $b001 = 2$ $b111 = 8$ |
| 3     | -    | -           | reserved                                                                                                              |
| 2:0   |      | 0x3         | The data bus width of the AXI interface: b000 = reserved b001 = reserved b010 = 32-bit                                |



| b011 = 64-bit                           |  |
|-----------------------------------------|--|
| b100 = 128-bit $b101$ -b111 = reserved. |  |

#### DMAC1\_WD

Address: Operational Base+0xe80

DMA Watchdog Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                              |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | -    | -           | reserved                                                                                                                                                                                 |
| 0    | RW   | 0x0         | Controls how the DMAC responds when it detects a lock-up condition:  0 = the DMAC aborts all of the contributing DMA channels and sets irq_abort HIGH  1 = the DMAC sets irq_abort HIGH. |

# 11.5 Timing Diagram

Please refer to chapter 10.5 for the similar description.

# 11.6 Interface Description

DMAC1 has the following tie-off signals. It can be configured by GRF register.(Please refer to the chapter to find how to configure)

#### DMAC1

| interface       | Reset value | Control source |
|-----------------|-------------|----------------|
| IIICEITACE      | Neset value | Control source |
| boot_addr       | 0x0         | GRF            |
| boot_from_pc    | 0x0         | GRF            |
| boot_manager_ns | 0x0         | GRF            |
| boot_irq_ns     | 0xf         | GRF            |
| boot_periph_ns  | 0xfffff     | GRF            |

#### boot\_addr

Configures the address location that contains the first instruction the DMAC executes, when it exits from reset.

## boot\_from\_pc

Controls the location in which the DMAC executes its initial instruction, after it exits from reset:

- 0 = DMAC waits for an instruction from either APB interface
- 1 = DMA manager thread executes the instruction that is located at the address that

## boot\_manager\_ns

When the DMAC exits from reset, this signal controls the security state of the DMA manager thread:

- 0 = assigns DMA manager to the Secure state
- 1 = assigns DMA manager to the Non-secure state.

## boot\_irq\_ns

Controls the security state of an event-interrupt resource, when the DMAC exits from reset:

boot irg ns[x] is LOW



The DMAC assigns event<x> or irq[x] to the Secure state. boot\_irq\_ns[x] is HIGH

The DMAC assigns event<x> or irq[x] to the Non-secure state.

#### boot\_periph\_ns

Controls the security state of a peripheral request interface, when the DMAC exits from reset:

boot\_periph\_ns[x] is LOW

The DMAC assigns peripheral request interface x to the Secure state. boot\_periph\_ns[x] is HIGH

The DMAC assigns peripheral request interface x to the Non-secure state.

# 11.7 Application Notes

Please refer to chapter 10.3 for the similar description.

# **Chapter 12 GIC(General Interrupt Controller)**

#### 12.1 Overview

The interrupt controller(GIC) in This device has two interfaces, the distributor interface connects to the interrupt source, the cpu interface connects to Cortex-A8. The GIC supports Security Extensions.

It supports the following features:

- Supports 72 vectored IRQ interrupts
- Supports 64 interrupts priority levels
- Programmable interrupt priority level masking
- Generates IRQ and FIQ
- Generates Software interrupt
- Supports Security Extensions

# 12.2 Block Diagram

Fig.12-1 shows the block diagram of gic



Fig. 12-1Block diagram of GIC

The diagram shows that GIC has two axi interfaces independently and has two base address for these two interfaces.

These two interfaces connect to CPU L1 AXI interconnect, and the connected ports are secure after reset. So, after reset GIC can only be accessed by secure transaction. These two ports in CPU L1 AXI interconnect can be configured to non-secure , Please refer to chapter 9.3 for detailed information.

# 12.3 Function Description

This GIC architecture splits logically into a Distributor block and one CPU interface block, as Figure 12-1 shows.

#### **Distributor**

This performs interrupt prioritization and distribution to the CPU interface that connect to the processor in the system.



#### **CPU** interface

CPU interface performs priority masking and preemption handling for a connected processor in the system.

#### 12.3.1 The Distributor

The Distributor centralizes all interrupt sources, determines the priority of each interrupt, and for CPU interface dispatches the interrupt with the highest priority to the interface for priority masking and preemption handling.

The Distributor provides a programming interface for:

- Globally enabling the forwarding of interrupts to the CPU interface
- Enabling or disabling each interrupt
- Setting the priority level of each interrupt
- Setting the target processor list of each interrupt
- Setting each peripheral interrupt to be level-sensitive or edge-triggered
- If the GIC implements the Security Extensions, setting each interrupt as either
- Secure or Non-secure
- Sending an SGI to processor.
- Visibility of the state of each interrupt
- A mechanism for software to set or clear the pending state of a peripheral
- interrupt.

#### **Interrupt ID**

Interrupts from sources are identified using ID numbers. CPU interface can see up to 88 interrupts.

The GIC assigns interrupt these 88 ID numbers as follows:

- Interrupt numbers ID32-ID1 are used for SPIs(shared peripheral interrupts).
- ID0-ID15 are used for SGIs(software generated interrupts).
- ID16-ID31 are not used

The GIC architecture reserves interrupt ID numbers 1022-1023 for special purposes.

#### ID1022

The GIC returns this value to a processor in response to an interrupt acknowledge only whenall of the following apply:

- The interrupt acknowledge is a Secure read
- The highest priority pending interrupt is Non-secure
- The AckCtl bit in the Secure ICCICR is set to 0
- The priority of the interrupt is sufficient for it to be signalled to the processor.

Interrupt ID 1022 informs Secure software that there is a Non-secure interrupt of sufficient priority to be signalled to the processor, that must be handled by Non-secure software. In this situation the Secure software might alter its schedule to permit Non-secure software to handle the interrupt, to minimize the interrupt latency.

#### **ID1023**

This value is returned to a processor, in response to an interrupt acknowledge, if there is no pending interrupt with sufficient priority for it to be signalled to the processor.

On a processor that implements the Security Extensions, Secure software



treats values of 1022 and 1023 as spurious interrupts.

#### 12.3.2 CPU interface

CPU interface block provides the interface for a processor that operates with the GIC. CPU interface provides a programming interface for:

- Enabling the signalling of interrupt requests by the CPU interface
- Acknowledging an interrupt
- Indicating completion of the processing of an interrupt
- Setting an interrupt priority mask for the processor
- Defining the preemption policy for the processor
- Determining the highest priority pending interrupt for the processor.

When enabled, CPU interface takes the highest priority pending interrupt for its connected processor and determines whether the interrupt has sufficient priority for it to signal the interrupt request to the processor.

To determine whether to signal the interrupt request to the processor the CPU interface considers the interrupt priority mask and the preemption settings for the processor. At any time, the connected processor can read the priority of its highest priority active interrupt from a CPU interface register.

The processor acknowledges the interrupt request by reading the CPU interface Interrupt Acknowledge register. The CPU interface returns one of:

The ID number of the highest priority pending interrupt, if that interrupt is of sufficient priority to generate an interrupt exception on the processor. This is the normal response to an interrupt acknowledge.

Exceptionally, an ID number that indicates a spurious interrupt.

When the processor acknowledges the interrupt at the CPU interface, the Distributor changes the status of the interrupt from pending to either active, or active and pending. At this point the CPU interface can signal another interrupt to the processor, to preempt interrupts that are active on the processor. If there is no pending interrupt with sufficient priority for signalling to the processor, the interface deasserts the interrupt request signal to the processor.

When the interrupt handler on the processor has completed the processing of an interrupt, it writes to the CPU interface to indicate interrupt completion. When this happens, the distributor changes the status of the interrupt either:

- from active to inactive
- from active and pending to pending.

#### 12.3.3 Interrupt handling state machine

The distributor maintains a state machine for each supported interrupt on CPU interface. Following figure shows an instance of this state machine, and the possible state transitions.





Fig. 12-2 GIC Interrupt handling state machine

## Transition A1 or A2, add pending status

For an SGI:

- Occurs on a write to an ICDSGIR that specifies the processor as a target.
- If the GIC implements the Security Extensions and the write to the ICDSGIR is Secure, the transition occurs only if the security configuration of the specified SGI, for the CPU interface, corresponds to the ICDSGIR.SATT bit value.

For an SPI, occurs if either:

- a peripheral asserts an interrupt signal
- software writes to an ICDISPR.

## Transition B1 or B2, remove pending status

Not applicable to SGIs:

- a pending SGI must transition through the active state, or reset, to remove its pending status.
- an active and pending SGI must transition through the pending state, or reset, to remove its pending status.

For an SPI, occurs if either:

- the level-sensitive interrupt is pending only because of the assertion of an input signal, and that signal is deasserted
- the interrupt is pending only because of the assertion of an edge-triggered interrupt signal, or a write to an ICDISPR, and software writes to the corresponding ICDICPR.

#### **Transition C**

If the interrupt is enabled and of sufficient priority to be signalled to the processor, occurs when software reads from the ICCIAR.

#### **Transition D**

For an SGI, occurs if the associated SGI is enabled and the Distributor forwards it to the CPU interface at the same time that the processor reads the ICCIAR to acknowledge a previous instance of the SGI. Whether this transition occurs depends on the timing of the read of the ICCIAR relative to the reforwarding of the SGI.

For an SPI:



- Occurs if all the following apply:
- The interrupt is enabled.
- Software reads from the ICCIAR. This read adds the active state to the interrupt.
- For a level-sensitive interrupt, the interrupt signal remains asserted. This is usually the case, because the peripheral does not deassert the interrupt until the processor has serviced the interrupt.
- For an edge-triggered interrupt, whether this transition occurs depends on the timing of the read of the ICCIAR relative to the detection of the reassertion of the interrupt. Otherwise the read of the ICCIAR causes transition C, possibly followed by transition A2.

#### Transition E1 or E2, remove active status

Occurs when software writes to the ICCEOIR.

# 12.4 Register Description

12.4.1 GIC Distributor interface register summary

| Name         | Offset      | Size | Reset                                 | Description                    |
|--------------|-------------|------|---------------------------------------|--------------------------------|
|              | 0x000       | W    | 0x0                                   |                                |
| GICD_ICDDCR  | UXUUU       | VV   | UXU                                   | Distributor Control Register   |
| GICD ICDICTR | 0x004       | W    | ~ ^                                   | Interrupt Controller Type      |
| GIGD_IGDIGTK | 0,0001      | • •  |                                       | Register                       |
| CICD ICDIIDD | 0x008       | w    |                                       | Distributor Implementer        |
| GICD_ICDIIDR | UXUUO       | VV   | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | Identification Register        |
| GICD_ICDISR  | 0x080       | W    |                                       | Interrupt Security Registers   |
| -            | -           | - L  | )-                                    | reserved                       |
| GICD_ICDISER | 0x100-0x17C | W    |                                       | Interrupt Set-Enable Registers |
|              | 0 100 0 150 |      |                                       | Interrupt Clear-Enable         |
| GICD_ICDICER | 0x180-0x1FC | W    |                                       | Registers                      |
|              |             |      |                                       | Interrupt Set-Pending          |
| GICD_ICDISPR | 0x200-0x27C | W    | 0x0                                   |                                |
|              | · / /       |      |                                       | Registers Class Panding        |
| GICD_ICDICPR | 0x280-0x2FC | W    | 0x0                                   | Interrupt Clear-Pending        |
|              |             |      |                                       | Registers                      |
| GICD_ICDABR  | 0x300-0x37C | W    | 0x0                                   | Active Bit Registers           |
| - 1          | <u>-</u>    | -    | -                                     | reserved                       |
| GICD_ICDIPR  | 0x400-0x7F8 | В    | 0x0                                   | Interrupt Priority Registers   |
| -            | -           | -    | -                                     | reserved                       |
| GICD_ICDIPTR | 0x800-0x81C | В    |                                       | Interrupt Processor Targets    |
| - 1          | -           | -    | -                                     | reserved                       |
| CICD ICDICES | 0.000.0.050 | 147  |                                       | Interrupt Configuration        |
| GICD_ICDICFR | 0xC00-0xCFC | W    |                                       | Registers                      |
| -            | -           | -    | -                                     | reserved                       |
| 0100 10000   | 0 500       |      |                                       | Software Generated Interrupt   |
| GICD_ICDSGIR | 0xF00       | W    |                                       | Register                       |
| A/ - /       |             | L    | L                                     |                                |

Notes:

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

12.4.2 GIC Distributor interface detail register description

#### GICD\_ICDDCR

Address:Operational Base+0x0



Distributor Control Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                    |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | ı    | -           | reserved                                                                                                                                                                                                                                                                                                                                       |
| 0    | RW   | 0x0         | Global enable for monitoring peripheral interrupt signals and forwarding pending interrupts to the CPU interface.  O The GIC ignores all peripheral interrupt signals, and does not forward pending interrupts to the Cpu interface.  The GIC monitors the peripheral interrupt signals, and forwards pending interrupts to the Cpu interface. |

## GICD\_ICDICTR

Address:Operational Base+0x4 Interrupt Controller Type Register

|       |      | roller Type Regi |                                                                                                                                                                                                                                                                                                                                                  |
|-------|------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit   | Attr | Reset Value      | Description                                                                                                                                                                                                                                                                                                                                      |
| 31:11 | -    | -                | reserved                                                                                                                                                                                                                                                                                                                                         |
| 10    | R    | 0x1              | Indicates whether the GIC implements the Security Extensions.  0 Security Extensions not implemented.  1 Security Extensions implemented                                                                                                                                                                                                         |
| 9:8   | ı    | -                | reserved                                                                                                                                                                                                                                                                                                                                         |
| 7:5   | R    | 0x0              | Indicates the number of implemented Cpu interface. The number of implemented Cpu interface is one more than the value of this field, for example if this field is 0b011, there are four Cpu interface. In this product ,only one cpu interface is implemented.                                                                                   |
| 4:0   | R    | 0x2              | Indicates the maximum number of interrupts that the GIC supportsa. If the value of this field is N, the maximum number of interrupts is 32(N+1). The interrupt ID range is from 0 to one less than the number of IDs. For example:  0b00011 Up to 128 interrupt lines, interrupt IDs 0-127.  The maximum number of interrupts is 1020 (0b11111). |

# GICD\_ICDIIDR

Address:Operational Base+0x8

Distributor Implementer Identification Register

| Bit   | Attr | Reset Value | Description                                       |
|-------|------|-------------|---------------------------------------------------|
| 31:24 | R    | 0x0         | product identifier.                               |
| 23:20 | ı    | -           | reserved                                          |
|       |      |             | variant number. Typically, this field is used to  |
| 19:16 | R    | 0x0         | distinguish                                       |
|       |      |             | product variants, or major revisions of a product |
| 15:12 | D    | 0x0         | revision number. Typically, this field is used to |
| 13.12 | Γ.   | UXU         | distinguish minor revisions of a product          |
| 11:0  | R    | 0x0         | Contains the JEP106 code of the company that      |
| 11.0  | K    | UXU         | implemented the GIC Distributor:a                 |



| Bits [11:8] The JEP106 continuation code of |
|---------------------------------------------|
| the implementer.                            |
| Bits [7] Always 0.                          |
| Bits [6:0] The JEP106 identity code of the  |
| implementer.                                |

#### GICD\_ICDISR

Address:Operational Base+0x80 **Interrupt Security Registers** 

| Bit  | Attr | Reset Value | Description                                  |
|------|------|-------------|----------------------------------------------|
|      |      |             | For each bit:                                |
| 31:0 | RW   | 0x0         | 0 The corresponding interrupt is Secure.     |
|      |      |             | 1 The corresponding interrupt is Non-secure. |

For interrupt ID N, when DIV and MOD are the integer division and modulo operations:

- the corresponding ICDISR number, M, is given by M = N DIV 32
- the offset of the required ICDISR is (0x080 + (4\*M))
- the bit number of the required Security status bit in this register is N MOD 32.

## GICD\_ICDISER

Address:Operational Base+0x100 Interrupt Set-Enable Registers

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                          |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   |             | For SPIs, for each bit: Reads 0 The corresponding interrupt is disabled. 1 The corresponding interrupt is enabled. Writes 0 Has no effect. 1 Enables the corresponding interrupt. A subsequent read of this bit returns the value 1. |

For interrupt ID N, when DIV and MOD are the integer division and modulo

- the corresponding ICDISER number, M, is given by M = N DIV 32
- the offset of the required ICDISER is (0x100 + (4\*M))
- the bit number of the required Set-enable bit in this register is N MOD 32.

## GICD ICDICER

Address: Operational Base+0x180 Interrupt Clear-Enable Registers

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                          |
|------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x0                | For SPI, for each bit: Reads 0 The corresponding interrupt is disabled. 1 The corresponding interrupt is enabled. Writes 0 Has no effect. 1 Disables the corresponding interrupt. A subsequent read of this bit returns the value 0. |

For interrupt ID N, when DIV and MOD are the integer division and modulo operations:

- the corresponding ICDICER number, M, is given by M = N DIV 32
- the offset of the required ICDICER is (0x180 + (4\*M))
- the bit number of the required Clear-enable bit in this register is N MOD 32.



### GICD\_ICDISPR

Address:Operational Base+0x200 Interrupt Set-Pending Registers

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                             |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |             | For each bit: Reads  O The corresponding interrupt is not pending on any processor.  1  • For SGIs, the corresponding interrupt is pending on this processor.  • For SPIs, the corresponding interrupt is pending on at least one processor.  Writes For SPIs:  O Has no effect.  1 The effect depends on whether the interrupt is edge-triggered or level-sensitive:                                   |
| 31:0 | RW   | 0×0         | Edge-triggered Changes the status of the corresponding interrupt to: • pending if it was previously inactive • active and pending if it was previously active. Has no effect if the interrupt is already pending.  Level sensitive If the corresponding interrupt is not pendinga, changes the status of the corresponding interrupt                                                                    |
| 2    | Ĉ    |             | to:     pending if it was previously inactive     active and pending if it was previously active.     If the interrupt is already pending:     because of a write to the ICDISPR, the write has no effect     because the corresponding interrupt signal is asserted, the write has no effect on the status of the interrupt, but the interrupt remains pendinga if the interrupt signal is deasserted. |

For interrupt ID N, when DIV and MOD are the integer division and modulo operations:

- the corresponding ICDISPR number, M, is given by M = N DIV 32
- the offset of the required ICDISPR is (0x200 + (4\*M))
- the bit number of the required Set-pending bit in this register is N MOD 32.

## GICD\_ICDICPR

Address:Operational Base+0x280 Interrupt Clear-Pending Registers

| Bit  | Attr | Reset Value | Description            |  |  |
|------|------|-------------|------------------------|--|--|
| 31:0 | RW   | 0x0         | For each bit:<br>Reads |  |  |



| 0 The corresponding interrupt is not pending on any processor                                                                                                                                                                                                                                                                   |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>For SGIs, the corresponding interrupt is pendinga on this processor.</li> <li>For SPIs, the corresponding interrupt is pendinga on aleast one processor.</li> </ul>                                                                                                                                                    |
| Writes For SPIs: 0 Has no effect. 1 The effect depends on whether the interrupt is edge-triggeredor level-sensitive:                                                                                                                                                                                                            |
| Edge-triggered Changes the status of the corresponding interrupto: • inactive if it was previously pending • active if it was previously active and pending. Has no effect if the interrupt is not pending.                                                                                                                     |
| Level-sensitive If the corresponding interrupt is pendinga only because of a write to the ICDISPR, the write changes the status of the interrupt to: • inactive if it was previously pending • active if it was previously active and pending.Otherwise the interrupt remains pending if the interrupt signal remains asserted. |

For interrupt ID N, when DIV and MOD are the integer division and modulo operations:

- the corresponding ICDICPR number, M, is given by M = N DIV 32
- the offset of the required ICDICPR is (0x280 + (4\*M))
- the bit number of the required Set-pending bit in this register is N MOD 32.

#### GICD\_ICDABR

Address: Operational Base+0x300

Active Bit Registers

| Bit Attı | Reset Value | Description                              |
|----------|-------------|------------------------------------------|
|          |             | For each bit:                            |
| 31:0 R   |             | 0 Corresponding interrupt is not active. |
|          |             | 1 Corresponding interrupt is active.     |

For interrupt ID N, when DIV and MOD are the integer division and modulo operations:

- the corresponding ICDABR number, M, is given by M = N DIV 32
- the offset of the required ICDABR is (0x300 + (4\*M))
- the bit number of the required Active bit in this register is N MOD 32.

#### **GICD ICDIPR**

Address: Operational Base+0x400 **Interrupt Priority Registers** 



| Bit | Attr | Reset Value | Description                                                                   |
|-----|------|-------------|-------------------------------------------------------------------------------|
| 7:0 | RW   | 0x0         | The lower the value, the greater the priority of the corresponding interrupt. |

For interrupt ID N:

- the corresponding ICDIPR number, M, is given by M = N
- the offset of the required ICDIPR is (0x400 + M)

## GICD\_ICDIPTR

Address: Operational Base+0x800 Interrupt Processor Targets Registers

| Bit | Attr | <b>Reset Value</b> | Description                                                                |          |
|-----|------|--------------------|----------------------------------------------------------------------------|----------|
| 7:0 | RW   | 0x1                | This register is not used. As in our product ,there is only one processor. | <b>\</b> |

#### GICD ICDICFR

Address: Operational Base+0xc00 **Interrupt Configuration Registers** 

| Bit  | Attr | Reset Value | Description                                                                                                            |  |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------|--|
| 2F+1 | RW   | 0x0         | F=0,1,2,315 The encoding is: 0 Corresponding interrupt is level-sensitive. 1 Corresponding interupt is edge-triggered. |  |

For interrupt ID N, when DIV and MOD are the integer division and modulo operations:

- the corresponding ICDICFR number, M, is given by M = N DIV 16
- the offset of the required ICDIPTR is (0xC00 + (4\*M))
- the required Priority field in this register, F, is given by F = N MOD 16, where field 0 refers to register bits [1:0], field 1 refers to bits [3:2], and so on, up to field 15 refers to bits [31:30]

## GICD\_ICDSGIR

Address: Operational Base+0xf00 Software Generated Interrupt Register

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                         |
|-------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:26 | -    | <del>-</del> ( ) ' | reserved                                                                                                                                                                                                                                                                                                            |
| 25:24 | 8    | 0x0                | 0b00 Send the interrupt to the Cpu interface specified in the CPUTargetList fielda. 0b01 Send the interrupt to all Cpu interface except the CPU interface that requested the interrupt. 0b10 Send the interrupt only to the CPU interface that requested the interrupt. 0b11 Reserved                               |
| 23:16 | W    | 0x0                | When TargetList Filter = 0b00, defines the Cpu interface the Distributor must send the interrupt to.  Each bit of CPUTargetList[7:0] refers to the corresponding CPU interface, for example CPUTargetList[0] corresponds to CPU interface 0. Setting a bit to 1 sends the interrupt to the corresponding interface. |
| 15    | W    | 0x0                | If the GIC implements the Security Extensions, this field is writable only using a Secure access.                                                                                                                                                                                                                   |



|      |   |     | Any Non-secure write to the ICDSGIR issues an SGI only if the specified SGI is programmed as Non-secure, regardless of the value of bit [15] of the write.  Specifies the required security value of the SGI:  O Send the SGI specified in the SGIINTID field to a specified CPU interface only if the SGI is configured as Secure on that interface.  Send the SGI specified in the SGIINTID field to a specified Cpu interface only if the SGI is configured as Non-secure on that interface |
|------|---|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14:4 | - | -   | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3:0  | W | 0x0 | The Interrupt ID of the SGI to send to the specified Cpu interface. The value of this field is the Interrupt ID, in the range 0-15, for example a value of 0b0011 specifies Interrupt ID 3                                                                                                                                                                                                                                                                                                     |

## 12.4.3 GIC CPU interface register summary

| Name         | Offset | Size | Reset<br>Value | Description                           |
|--------------|--------|------|----------------|---------------------------------------|
| GICC_ICCICR  | 0x00   | W    | 0x0            | CPU Interface Control<br>Register     |
| GICC_ICCPMR  | 0x04   | W    | 0x0            | Interrupt Priority Mask<br>Register   |
| GICC_ICCBPR  | 0x08   | W    | 0x0            | Binary Point Register                 |
| GICC_ICCIAR  | 0x0C   | W    | 0x3ff          | Interrupt Acknowledge<br>Register     |
| GICC_ICCEOIR | 0x10   | W    | -              | End of Interrupt Register             |
| GICC_ICCRPR  | 0x14   | V    | 0xff           | Running Priority Register             |
| GICC_ICCHPIR | 0x18   | 8    | 0x3ff          | Highest Pending Interrupt<br>Register |
| GICC_ICCABPR | 0x1C   | W    | 0x0            | Aliased Binary Point<br>Register      |
| <b>\1</b>    |        |      |                |                                       |
| GICC_ICCIIDR | 0xFC   | W    | 0x0            | CPU Interface Identification Register |

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

## 12.4.4 GIC CPU interface detail register description

## GICC\_ICCICR

Address:Operational Base+0x0 CPU Interface Control Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | -    | -           | reserved                                                                                                                                                                                   |
| 4    | RW   | 0x0         | Controls whether the CPU interface uses the Secure or Non-secure Binary Point Register for preemption.  O To determine any preemption, use:  • the Secure Binary Point Register for Secure |

| Rockchip<br><sub>端芯微电子</sub> | DI | <b>V</b> 3 | n | vv |
|------------------------------|----|------------|---|----|
| 瑞芯微电子                        | ĸı | 15         | U | XX |

|   |    |     | interrupts • the Non-secure Binary Point Register for Non-secure interrupts.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---|----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |    |     | 1 To determine any preemption use the Secure Binary Point Register for both Secure and Non-secure interrupts.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|   |    |     | Controls whether the GIC signals Secure interrupts to a target processor using the FIQ or the IRQ signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 3 | RW | 0x0 | Signal Secure interrupts using the IRQ signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|   |    |     | Signal Secure interrupts using the FIQ signal. The GIC always signals Non-secure interrupts using the IRQ signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 2 | RW | 0x0 | Controls whether a Secure read of the ICCIAR, when the highest priority pending interrupt is Non-secure, causes the CPU interface to acknowledge the interrupt.  O  If the highest priority pending interrupt is Non-secure, a Secure read of the ICCIAR returns an Interrupt ID of 1022. The read does not acknowledge the interrupt, and the pending status of the interrupt is unchanged.  I  If the highest priority pending interrupt is Non-secure, a Secure read of the ICCIAR returns the Interrupt ID of the Non-secure interrupt. The read acknowledges the interrupt, and the status of the interrupt becomes active, or active and pending. |
| 1 | RW | 0×0 | An alias of the Enable bit in the Non-secure ICCICR. This alias bit means Secure software can enable the signalling of Non-secure interrupts.  O Disable signalling of Non-secure interrupts.  Enable signalling of Non-secure interrupts.                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0 | RW | 0x0 | Global enable for the signalling of Secure interrupts by the Cpu interface to the connected processors.  O Disable signalling of Secure interrupts.  Enable signalling of Secure interrupts                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

## GICC\_ICCPMR

Address:Operational Base+0x4 Interrupt Priority Mask Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                  |  |  |  |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 31:8 | -    | -           | reserved                                                                                                                                                     |  |  |  |
| 7:0  | RW   | 0x0         | The priority mask level for the CPU interface. If<br>the priority of an interrupt is higher than the<br>value indicated by this field, the interface signals |  |  |  |



| the interrupt to the processor.  If the GIC supports fewer than 256 priority levels then some bits are RAZ/WI, as follows: |
|----------------------------------------------------------------------------------------------------------------------------|
| 128 supported levels Bit [0] = 0.                                                                                          |
| 64 supported levels Bit [1:0] = 0b00.                                                                                      |
| 32 supported levels Bit [2:0] = 0b000.                                                                                     |
| 16 supported levels Bit [3:0] = 0b0000                                                                                     |

### GICC\_ICCBPR

Address:Operational Base+0x8

Binary Point Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                    |  |  |  |  |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 31:3 | -    | -           | reserved                                                                                                                                                                       |  |  |  |  |
| 2:0  | RW   | 0x0         | The value of this field controls how the 8-bit interrupt priority field is split into a group priority field, used to determine interrupt preemption, and a subpriority field. |  |  |  |  |

### GICC\_ICCIAR

Address:Operational Base+0xc Interrupt Acknowledge Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                  |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13 | -    | -           | reserved                                                                                                                                                                                                                                                                                                                                     |
| 12:10 | RO   | 0x0         | For SGIs in a multiprocessor implementation, this field identifies the processor that requested the interrupt. It returns the number of the CPU interface that made the request, for example a value of 3 (0b011) means the request was generated by a write to the IDCSFGIR on CPU interface 3. For all other interrupts this field is RAZ. |
| 9:0   | RO   | 0x0         | The interrupt ID.                                                                                                                                                                                                                                                                                                                            |

## GICC\_ICCEOIR \

Address:Operational Base+0x10

End of Interrupt Register

| Bit   | Attr | Reset Value | Description                                                                                                                                              |  |  |  |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 31:13 | - 0  | -           | reserved                                                                                                                                                 |  |  |  |
| 12:10 | wo   | 0x0         | On a multiprocessor implementation, on completion of the processing of an SGI, this field contains the CPUID value from the corresponding ICCIAR access. |  |  |  |
| 9:0   | WO   | 0x0         | The ACKINTID value from the corresponding ICCIAR access.                                                                                                 |  |  |  |

## GICC\_ICCRPR

Address:Operational Base+0x14

Running Priority Register

|      | rtaning Priority Register |             |                                                                                           |  |  |  |  |  |
|------|---------------------------|-------------|-------------------------------------------------------------------------------------------|--|--|--|--|--|
| Bit  | Attr                      | Reset Value | Description                                                                               |  |  |  |  |  |
| 31:8 | -                         | -           | reserved                                                                                  |  |  |  |  |  |
| 7:0  | RO                        | 0x0         | The priority value of the highest priority interrupt that is active on the CPU interface. |  |  |  |  |  |



#### GICC ICCABPR

Address:Operational Base+0x18

Aliased Binary Point Register

| Bit  | Attr | <b>Reset Value</b> | Description                                 |  |  |  |  |
|------|------|--------------------|---------------------------------------------|--|--|--|--|
| 31:3 | -    | -                  | reserved                                    |  |  |  |  |
| 2:0  | RW   | 0x0                | Provides an alias of the Non-secure ICCBPR. |  |  |  |  |

#### GICC\_ICCHPIR

Address: Operational Base+0x1c Highest Pending Interrupt Register

| Bit   | Attr | Reset Value | Description                                                 |  |  |
|-------|------|-------------|-------------------------------------------------------------|--|--|
| 31:10 | -    | -           | reserved                                                    |  |  |
| 9:0   | R    | 0x0         | The interrupt ID of the highest priority pending interrupt. |  |  |

#### GICC\_ICCIIDR

Address: Operational Base+0xfc

CPU Interface Identification Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                             |  |  |  |  |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 31:20 |      | 0x0         | An IMPLEMENTATION DEFINED product identifier.                                                                                                                                                                           |  |  |  |  |
| 19:16 | R    | 0x0         | For an implementation that complies with this specification, the value is 0x1                                                                                                                                           |  |  |  |  |
| 15:12 | R    | 0x0         | An IMPLEMENTATION DEFINED revision number for the CPU interface.                                                                                                                                                        |  |  |  |  |
| 11:0  | R    | 0×0         | Contains the JEP106 code of the company that implemented the GIC CPU interface:b Bits [11:8] The JEP106 continuation code of the implementer. Bit [7] Always 0. Bits [6:0] The JEP106 identity code of the implementer. |  |  |  |  |

# 12.5 Interface Description

Both distributor interface and cpu interface are secure accessed only after reset, Register inside the CPU L1 AXI interconnect needs to be configured to change to non-secure access.

When the tie\_off signal cfgsisable is HIGH, it enhances the security of the GIC by preventing write accesses to security-critical configuration registers. This signal is low after reset, it can be configured through TZPC registers.

# 12.6 Application Notes

12.6.1 General handling of interrupts

The GIC operates on interrupts as follows:

1. The GIC determines whether each interrupt is enabled. An interrupt that is not enabled has no further effect on the GIC. (Enables an interrupt by writing to the appropriate ICDISER bit, disables an interrupt by writing to the appropriate ICDICER bit)



- 2. For each enabled interrupt that is pending, the Distributor determines the targeted processor.
- 3. For processor, the Distributor determines the highest priority pending interrupt, based on the priority information it holds for each interrupt, and forwards the interrupt to the CPU interface.
- 4. The CPU interface compares the interrupt priority with the current interrupt priority for the processor, determined by a combination of the Priority Mask Register, the current preemption settings, and the highest priority active interrupt for the processor. If the interrupt has sufficient priority, the GIC signals an interrupt exception request to the processor.
- 5. When the processor takes the interrupt exception, it reads the ICCIAR in its CPU interface to acknowledge the interrupt. This readreturns an Interrupt ID that the processor uses to select the correct interrupt handler. When it recognizes this read, the GIC changes the state of the interrupt:
- if the pending state of the interrupt persists when the interrupt becomes active, or if the interrupt is generated again, from pending to active and pending.
- otherwise, from pending to active
- 6. When the processor has completed handling the interrupt, it signals this completion by writing to the ICCEOIR in the GIC

#### Generating an SGI

A processor generates an SGI by writing to an ICDSGIR.

## 12.6.2 Interrupt prioritization

Software configures interrupt prioritization in the GIC by assigning a priority value to each interrupt source. Priority values are 8-bit unsigned binary. In this product, GIC implements 64 priority levels. So only the highest 6 bits are valid, the lower 2 bits read as zero.

In the GIC prioritization scheme, lower numbers have higher priority, that is, the lower the assigned priority value the higher the priority of the interrupt. The highest interrupt priority always has priority field value 0.

The ICDIPRs hold the priority value for each supported interrupt. To determine the number of priority bits implemented write 0xFF to an ICDIPR priority field and read back the value stored.

#### **Preemption**

A CPU interface supports forwarding of higher priority pending interrupts to a target processor before an active interrupt completes. A pending interrupt is only forwarded if it has a higher priority than all of:

- the priority of the highest priority active interrupt on the target processor, the running priority for the processor, see Running Priority Register (ICCRPR) .
- the priority mask, see Priority masking.
- the priority group, see Priority grouping.

Preemption occurs at the time when the processor acknowledges the new interrupt, and starts to service it in preference to the previously active interrupt or the currently running process. When this occurs, the initial active interrupt is said to have been preempted. Starting to service an interrupt while another



interrupt is still active is sometimes described as interrupt nesting.

#### **Priority masking**

The ICCPMR for a CPU interface defines a priority threshold for the target processor, see Interrupt Priority Mask Registe. The GIC only signals pending interrupts with a higher priority than this threshold value to the target processor. A value of zero, the register reset value, masks all interrupts to the associated processor.

The GIC always masks an interrupt that has the largest supported priority field value. This provides an additional means of preventing an interrupt being signalled to any processor.

#### **Priority grouping**

Priority grouping splits each priority value into two fields, the group priority and the subpriority fields. The GIC uses the group priority field to determine whether a pending interrupt has sufficient priority to preempt a currently active interrupt.

The binary point field in the ICCBPR controls the split of the priority bits into the two parts. This 3-bit field specifies how many of the least significant bits of the 8-bit interrupt priority field are excluded from the group priority field, as following table shows.

| Binary point value | Group priority | Subpriority field | Field with binary |
|--------------------|----------------|-------------------|-------------------|
|                    | field          |                   | point             |
| 0                  | [7:1]          | [0]               | ggggggg.s         |
| 1                  | [7:2]          | [1:0]             | gggggg.ss         |
| 2                  | [7:3]          | [2:0]             | ggggg.sss         |
| 3                  | [7:4]          | [3:0]             | gggg.ssss         |
| 4                  | [7:5]          | [4:0]             | ggg.sssss         |
| 5                  | [7:6]          | [5:0]             | gg.ssssss         |
| 6                  | [7]            | [6:0]             | g.ssssss          |
| 7                  | No preemption  | [7:0]             | .SSSSSSS          |

Where multiple pending interrupts share the same group priority, the GIC uses the subpriority field to resolve the priority within a group.

12.6.3 The effect of the Security Extensions on interrupt handling

If a GIC CPU interface implements the Security Extensions, it provides two interrupt output signals, IRQ and FIQ:

- The CPU interface always uses the IRQ exception request for Non-secure interrupts
- Software can configure the CPU interface to use either IRQ or FIQ exception requests for Secure interrupts.

#### **Security Extensions support**

Software can detect support for the Security Extensions by reading the ICDICTR.SecurityExtn bit, see Interrupt Controller Type Register (ICDICTR). Secure software makes Secure writes to the ICDISRs to configure each interrupt as Secure or Non-secure, see Interrupt Security Registers (ICDISRn).

#### In addition:

• The banking of registers provides independent control of Secure and



Non-secure interrupts.

- The Secure copy of the ICCICR has additional fields to control the processing of Secure and Non-secure interrupts, see CPU Interface Control Register (ICCICR) These fields are:
- the SBPR bit, that affects the preemption of Non-secure interrupts.
- the FIQEn bit, that controls whether the interface signals Secure interrupts to the processor using the IRQ or FIQ interrupt exception requests.
- the AckCtl bit, that affects the acknowledgment of Non-secure interrupts.
- the EnableNS bit, that controls whether Non-secure interrupts are signaled to the processor, and is an alias of the Enable bit in the Non-secure ICCICR.
- The Non-secure copy of the ICCBPR is aliased as the ICCABPR, see Aliased Binary Point Register (ICCABPR). This is a Secure register, meaning it is only accessible by Secure accesses.

#### Effect of the Security Extensions on interrupt acknowledgement

When a processor takes an interrupt, it acknowledges the interrupt by reading the ICCIAR. A read of the ICCIAR always acknowledges the highest priority pending interrupt for the processor performing the read.

If the highest priority pending interrupt is a Secure interrupt, the processor must make a Secure read of the ICCIAR to acknowledge it.

By default, the processor must make a Non-secure read of the ICCIAR to acknowledge a Non-secure interrupt. If he AckCtl bit in the Secure ICCICR is set to 1 the processor can make a Secure read of the ICCIAR to acknowledge a Non-secure interrupt.

If the read of the ICCIAR does not match the security of the interrupt, taking account of the AckCtl bit value for a Non-secure interrupt, the ICCIAR read does not acknowledge any interrupt and returns the value:

- 1022 for a Secure read when the highest priority interrupt is Non-secure
- 1023 for a Non-secure read when the highest priority interrupt is Secure.

#### 12.6.4 The effect of Security Extensions on interrupt priority

If the GIC supports the Security Extensions:

- Secure software must program the ICDISRs to configure each supported interrupt as either Secure or Non-secure, see Interrupt Security Registers (ICDISRn).
- the GIC provides Secure and Non-secure views of the interrupt priority settings

#### Software views of interrupt priority

When a processor reads the priority value of an interrupt, the GIC returns either the Secure or the Non-secure view of that value, depending on whether the access is Secure or Non-secure. This section describes the two views of interrupt priority, and the relationship between them.

In this product, 64 priority levels are implemented.



Fig. 12-3Secure view of the priority field for a Secure interrupt Fig 12-3 shows the Secure view of a priority value field for a Secure interrupt.



A-F is the priority value. The low-order bits of the priority fields are RAZ/WI

| Е | D | С | В | A | 0 | 0 | 0 |
|---|---|---|---|---|---|---|---|
|---|---|---|---|---|---|---|---|

Fig. 12-4 Non-secure view of the priority field for a Non-secure interrupt

Fig 12-4 shows the Non-secure view of a priority value field for a Non-secure interrupt. A-E is the priority value. The low-order bits of the priority fields are RAZ/WI

The Non-secure view of a priority value does not show how the value is stored in the Distributor. Taking the value from a Non-secure write to a priority field, before storing the value the Distributor:

- right-shifts the value by one bit
- sets bit [7] of the value to 1.

This translation means the priority value for the Non-secure interrupt is in the top half of the possible value range, meaning the interrupt priority is in the bottom half of the priority range.

A Secure read of the priority value for a Non-secure interrupt returns the value stored in the distributor. Fig12-5 shows this Secure view of the priority value field for a Non-secure interrupt that has had its priority value field set by a Non-secure access, or has had a priority value with bit [7] == 1 set by a Secure access:



Fig. 12-5 Secure read of the priority field for a Non-secure interrupt

# **Chapter 13 DMC (Dynamic Memory Interface)**

#### 13.1 Overview

The DMC includes two section: dynamic ram protocol controller(PCTL) and phy controller (PHYCTL).

The PCTL SoC application bus interface supports a lowest-latency native application interface (NIF). To maximize data transfer efficiency, NIF commands transfer data without flow control. To simplify command processing, the NIF accepts addresses in rank, bank, row, column format.

The PHYCTL provides control features to ease the customer implementation of digitally controlled features of the PHY such as initialization, DQS gate training, and programmable configuration controls. The PHYCTL has built-in self test features to provide support for production testing of the compatible PHY. It also provides a DFI 2.1 interface to the PHY.

#### The DMC supports the following features:

- Complete, integrated, single-vendor DDR2, DDR3, mDDR, LPDDR2 solution .
- DFI 2.1 interface compatibility
- Up to 1066 Mbps in 1:1 frequency ratio, using a 533MHz controller clock and 533MHz memory clock.
- Support for x8, x16, and x32 memories, for a total memory data path width of up to 72 bits
- Up to 2 memory ranks; devices within a rank tie to a common chip select
- Up to 8 open memory banks, maximum of eight per rank
- Per-NIF transaction controllable bank management policies: open-page, close-page
- Low area, low power architecture with minimal buffering on the data, avoiding duplication of storage resources within the system
- PCTL NIF slave interface facilitates easy integration with an external scheduler or standard on-chip buses
- Efficient DDR protocol implementation with in-order column (Read and Write) commands and out- of-order Activate and Precharge commands
- Three clock cycles best case command latency (best case is when a command is to an open page and the shift array in the PCTL is empty).
- 1T or 2T memory command timing
- Automatic clock stop, power-down and self-refresh entry and exit.
   Clock stop is mDDR/LPDDR2 only
- Software and hardware driven self-refresh entry and exit
- Programmable memory initialization
- Partial population of memories, where not all DDR byte lanes are populated with memory chips
- Programmable per rank memory ODT (On-Die Termination) support for reads and writes
- APB interface for controller software-accessible registers
- Programmable data training interface:

Assists in training of the data eye of the memory channel Provides a method for testing large sections of memory

- Support for industry standard UDIMMs (Unbuffered DIMMs) and RDIMMs (Registered DIMMs)
- Automatic DQS gate training and drift compensation
- At-speed built-in-self-test (BIST) loopback testing on both the address and data channels for DDR PHYs
- PHY control and configuration registers
- Optional, additional JTAG interface to configure registers
- DFI 2.1 interface

# 13.2 Block Diagram



Fig. 13-1Protocol controller architecture



Fig. 13-2PHY controller architecture



# 13.3 Function description

PCTL operations are defined in terms of the current state of the Operational State Machine. Software can move PCTL in any of the operational states by issuing commands via the SCTL register. Transitions from one operational state to the other occur pass through a "transitional" state. Transitional states are exited automatically by the PCTL after all the necessary actions required to change operational state have been completed. The current operational state of PCTL is reported by the STAT register and is also available from the p\_ctl\_stat output.

PCTL supports the following operational states:

- Init\_mem This state is the default state entered after reset. All writable registers can be programmed. While in this state software can program PCTL and initialize the PHY and the memories. The memories are not refreshed and data that has previously been written to the memories may be lost as a result. The Init\_mem state is also used when it is desirable to stop any automatic PCTL function that directly affects the memories, like Power Down and Refresh, or when a software reset of the memory subsystem has to be executed.
- Config This state is used to suspend temporarily the normal NIF traffic and allow software to reprogram PCTL and memories if necessary, while still keeping active the periodic generation of Refresh cycles to the memories. Power Down entry and exit sequences are possible while in Config state.
- Access This is the operational state where NIF transactions are accepted by the PCTL and converted into memory read and writes. None of the registers can be programmed except SCFG, SCTL, ECCCLR and DTU\* registers.
- Low\_power Memories are in self refresh mode. The PCTL does not generate refresh cycles while in this state.

Access and Low\_power states can also be entered and exited by the hardware low power signals (c\_\*). In case of conflicting software and hardware low-power commands, the resulting operational state taken by the controller can be either one of the two conflicting requests.

Figure 13-3 illustrates the operational and transitional states.



Fig. 13-3Protocol controller architecture



The PHYCTL provides control features to ease the customer implementation of digitally controlled PHY features such as read DQS training, data eye training, output impedance calibration, and so on. The PHTCTL has built-in self test features to provide support for production testing of PHY. It also provides a DFI 2.1 interface to the PHY. The PHYCTL performs, in sequence, various tasks required by the PHY before it can commence normal DDR operations. SDRAM memory read/write access through the DDR PHY is primarily through a DFI 2.1 interface on the PHYCTL. Therefore, the memory controller used with the PHY must be DFI 2.1 compatible.

Access to the PHYCTL internal control features and registers is through a dedicated configuration port, which can be either APB or CFG (generic configuration interface). An optional JTAG interface can also be compiled in as an additional second configuration port to co-exist with either the APB or CFG main configuration ports. The PHYCTL is driven off two clocks, the controller clock (ctl\_clk) and the configuration clock pclk for an APB interface.

The controller clock is the same clock driving the memory controller and will be the same frequency as the SDRAM clock (ck). The configuration clock can run at a frequency equal to or less than the controller clock. The configuration clock all non-DDR timing logic, such as configuration registers, PHYinitialization, output impedance, and so on.

## **13.4 DDR PHY**

#### 13.4.1 DDR PHY Overview

In order to facilitate robust system timing and ease of use, DMC interface and control architecture utilizes a mixture of soft-IP and hard-IP design elements. The main control logic (Memory Controller) is supplied as soft-IP. The PHY is comprised of hard-IP components that include double-data rate InterfaceTiming Modules(ITM), input and output path DLLs, and application-specific SSTL I/Os.



Fig. 13-4 DDR PHY architecture

In order to maximize system timing margins on the command/write path, inputs to the SDRAM are provided with the clock or data strobe centered in the associated data eve. The ITM components perform timing translation for the various signal groups of the interface. The hardened ITM approach ensures minimal pin to pin skew while allowing optimal circuit design for drive and capture circuitry. A DLL is utilized to facilitate the clock centering. In the Command Lane, a master DLL (MDLL) is utilized. In the Byte Lane, the master portion of a master/slave DLL macrocell (MSDLL) is utilized.



On the read path, read data from the SDRAM is arriving from the SDRAM edge aligned with the data strobes. In order to maintain maximum system timing margins on the input path, the data strobes are translated to the center of the data eye. The MSDLL macrocell associated with each Byte Lane contains a master DLL and 2 slave DLLs (mirror delay lines). The slave DLL portion of the MSDLL is utilized to facilitate the clock centering. DOS and DOS b strobe inputs each utilize one of these slave DLL functions. The captured double data rate inputs are then converted to single data rate and passed onto the DDR Controller RTL logic. The ITM facilitates both data capture and DDR to SDR

The physical interface between the DDR controller and DDR SDRAMs uses DDR-specific SSTL I/O buffers with programmable on-die termination (ODT). These I/Os operate at either 1.8V for LPDDR/DDRII interfacing (SSTL\_18).

DMC interface and control architecture follows a common signal grouping philosophy. A Byte Lane is a complete eight-bit data unit consisting of the associated DQ, DM, and DQS/DQS\_b signals. A 32-bit system would consist of four Byte Lanes. A Command Lane is a complete command and address unit including also clock signals. There would normally be only one Command Lane in a particular DDR SDRAM interface. All clock and data signals relative to a Lane, either Byte or Command, are isolated to within that Lane only. Timing critical clock and data signals do not traverse between Lanes. Implementation of a memory interface involves placing the Command Lane components, placing the Byte Lane components, and standard synthesis/place and route to complete the design.

Each SSTL cell communicating with the SDRAM has an associated ITM component. The ITM library consists of individual components designed specifically for signal groups of address and command, data & data mask, and data strobes. In order to ensure low pin to pin skews and facilitate ease of implementation, the ITM components are tileable. DLL output clock distribution is embedded within the ITM components.

#### 13.4.2 Lane-Based Architecture

#### **Byte Lane PHY**

The data bus interface to the external memory is organized into self-contained units referred to herein as Byte Lanes. The external memory components are designed to support Byte Lanes for optimal system timing. The partitioning of the data word into discrete Byte Lanes allows pin to pin skew to be managed across a much smaller group of signals than would typically be required.

All components of the Byte Lane PHY are designed to permit connectivity by abutment. The ITM connects by abutment to the SSTL I/O, and the DLL connects by abutment to the ITM.

The SDRAM contains data strobes associated with each 8 bits of data and there is a timing skew allowance between the main clock signal to the SDRAM and its data strobe inputs during a Write command (tDQSS). 8bit memory components provide a single DQS.

A Byte Lane consists of the following I/O slots:

- ♦ 8 data bits (DQ)
- ♦ 1 data mask bit (DM)
- ♦ I/O power and ground cells
- ♦ Core power and ground cells

Each functional I/O slot has an associated ITM module, including DQ, DM, and DQS/DQS b. The ITMs provide a mechanism for monitoring read timing drift, which can be used to adjust timing to maintain optimum system margins. Drift



analysis and compensation is performed by the controller on a per Byte Lane basis. The ITM components contain the functions to monitor DQS drift and permit timing adjustment, the controller provides the analysis and control for these functions. These functions operate dynamically for each data bit of every user-issued Read command. There are no overhead penalties in channel bandwidth or utilization incurred by the use of these functions.

The memory interface (PHY) architecture is based on the concept of independent, but related, signal groups to provide the highest level of system timing performance. In order to maintain robust system timing, all clock and data signals relevant to a Byte Lane remain within that Byte Lane. These signals are not shared between other Byte Lanes or between a Byte Lane and a Command Lane. Alternate approaches require clock distribution networks that span the full length of the interface including all address, command, and data signals. These large clock distribution networks are difficult for the user to design and implement, and add an additional component of pin to pin skew to the critical timing budget.

A DLL macrocell (MSDLL) consisting of a master DLL and 2 slave DLLs (mirror delay lines) is utilized at each Byte Lane to facilitate optimal PHY timing for drive and capture of DDR data streams, and allows the Lanes to be independent. The master DLL section provides outputs for DDR data stream creation to the SDRAMs and acts as a reference for the slave delay line sections. The slave delay line sections translate the incoming DQS/DQS b into the center of the read data eye to maximize read system timing margins.

The user is permitted to fine tune the relationship of the DQS and DQ signals to maximize read system timing margin. The DLL includes adjustability of the slave delay lines for the DQS and DQS b signals, which provide byte-wide timing adjustments. The ITMs include adjustability of the read DQS/DQS b strobe timing, which provides byte-wide timing adjustments. The ITMs include adjustability of the read DQ signal timing, which provides per-bit timing adjustability. To permit Lane-independent timing adjustments, DLL adjustment bits are provided by the controller per Byte Lane and ITM adjustment bits are provided per bit.

DMC interface and control solution allows memory systems with a word width narrower than the design. Our system is designed with a 32 bit data width and it can then be utilized with either 16 bit or 32 bit memory systems. The controller contains register settings to allow the desired operational mode to be set in the final device.

The DDR-specific SSTL I/Os include programmable ODT and output impedence selection. The ODT and output impedances can be be dynamically calibrated to compensate for variations in voltage and temperature. The ODT feature can be disabled by the controller. When ODT is enabled by the controller, the SSTL I/O automatically enables its internal ODT circuitry when in input mode and disable this circuitry when in output mode, as determined by the output enable signal. The initial programming and subsequent calibration of the of the ODT and output impedance is achieved through the use of an impedance control loop that can be triggered to calibrate the ODT and output impedance values at the I/Os based on the desired impedance value when compared to an precision external resistor. All the necessary pieces of the impedance control loop are included in the SSTL I/O library.

There are four Byte Lanes in our chip of 32 bit memory system.

#### **Command Lane PHY**

The control and address interface to the external memory is organized into a self-contained unit referred to herein as a Command Lane. DMC interface



contains a single Command Lane and four Byte Lanes.

All components of the Command Lane PHY are designed to permit connectivity by abutment. The ITM connects by abutment to the SSTL I/O, and the DLL connects by abutment to the ITM.

A typical Command Lane consists of the following I/O slots:

- ♦ Memory clocks (CK/CK\_b)
- ♦ Command signals (RAS\_b, CAS\_b, WE\_b)
- ♦ 1 or more clock enable (CKE)
- ♦ 1 or more on-die termination (ODT)
- ♦ 2 chip select (CS\_b)
- ♦ 3 bank address (BA)
- ♦ 16 row/column address (A)
- ♦ I/O power and ground cells
- ♦ Core power and ground cells

The system clock input is used to provide the source clock for the memory interface. Memory controller supports 2 SDRAM ranks. There is one CKE, ODT, and CS\_b signal provided for each rank.

Each functional I/O slot has an associated ITM module, with exception of the system clock input. A master DLL (MDLL) is utilized with the Command Lane to facilitate optimal PHY timing for drive of DDR data streams, and allows the Lane to be independent. The DLL macrocells provide two 0 degree phase outputs, one which can be used to drive the controller logic. The Command Lane MDLL is used for this purpose.

To permit Lane-independent timing adjustments, DLL and ITM adjustment bits are provided by the controller separately for Command and Byte Lanes.

## 13.4.3 Master DLL(MDLL)

Master DLL for DDRII, and LPDDR applications is a Delay Locked Loop that takes an input reference clock (clk\_in) and generates four clock outputs, each delayed in quarter clock cycle (90°) increments. These four clock phases (clk\_0, clk\_90, clk\_180, clk\_270) can be generated with very high accuracy and low jitter across a wide range of frequencies.



Fig. 13-5 DDR PHY master DLL architecture diagram A number of test modes and configuration settings are included:



- ♦ A bypass mode shuts down all analog circuitry, and directly buffers the input clock and strobes with appropriate delays and inversions to the output clocks and strobes. This mode can be used for low speed functional or IDDQ testing.
- ♦ A digital test output (test\_out\_d) provides direct observability of several internal reference clock and timing nodes.
- ♦ An analog test output (test\_out\_a) provides direct observability of several internal reference voltages.

#### **Master DLL Control for Trim and Test**

The performance and testing of the MDLL can be accessed through the dll\_ctrl bus.

Table 13-1DDR PHYtrim and test MDLL control

| Static In |         | Field            | Description                                                                              |
|-----------|---------|------------------|------------------------------------------------------------------------------------------|
|           | [1:0]   |                  | Reserved                                                                                 |
|           | [4:2]   | ipump_trm[2:0]   | Charge pump current trim                                                                 |
|           | [5]     | test_ctrl_en     | Test control enable for analog and digital test outputs                                  |
|           | [8:6]   | test_ctrl_d[2:0] | Digital test control. Selects the digital signal to be viewed at the digital test output |
|           | [10:9]  | test_ctrl_a[1:0] | Analog test control. Selects the analog signal to be viewed at the analog test output    |
| 411 -41   | [11]    |                  | Reserved                                                                                 |
| dll_ctrl  | [14:12] | bias_trm[2:0]    | Bias generator frequency trim                                                            |
|           | [19,15] | fdtrm[1:0]       | Bypass mode fixed delay trim                                                             |
|           | [22:20] | bias_trm[6:4]    | Bias generator control voltage trim                                                      |
|           | [23]    | bps200           | Bypass frequency select                                                                  |
|           | [28:24] |                  | Reserved                                                                                 |
|           | [29]    |                  | Reserved                                                                                 |
|           | [37:30] |                  | Reserved                                                                                 |
|           | [43:38] | fb_trm[5:0]      | Feedback delay adjust                                                                    |
|           | [49:44] |                  | Reserved                                                                                 |
|           | [50]    | test_hizb_a      | Analog test output tri-stated control                                                    |
|           | [51]    | 7                | Reserved                                                                                 |

## Charge Pump Current Trim:

Table 13-2 charge pump current trim in dll\_ctrl

| Field          | Setting | Function        | Suggested Default |
|----------------|---------|-----------------|-------------------|
| inumn tum[2,0] | 000     | Maximum current | 000               |
| ipump_trm[2:0] | 111     | Minimum current | 000               |

#### Digital Test Control:

Table 13-3DLL digital test control in dll\_ctrl

| test_ctrl_en | test_ctrl_d[2:0] | Function                                  | Suggested Default |
|--------------|------------------|-------------------------------------------|-------------------|
| 0            | xxx              | digital test outputs disabled (drive '0') |                   |
| 1            | 000              | 0° output clock (clk_0)                   | 0.000             |
| 1            | 001              | 90° output clock (clk_90)                 | 0,000             |
| 1            | 010              | 180° output clock (clk_180)               |                   |
| 1            | 011              | 270° output clock (clk_270)               |                   |



| 1 | 100 | 360° internal clock<br>(clk_360_int) |  |
|---|-----|--------------------------------------|--|
| 1 | 101 | Speed-up pulse (spdup)               |  |
| 1 | 110 | Slow-down pulse (slwdn)              |  |
| 1 | 111 | Asic output clock (cclk 0)           |  |

#### Analog Test Control:

Table 13-4DLL analog test control in dll\_ctrl

| test_hizb_a | test_ctrl_en | test_ctrl_a<br>[1:0] | Function                           | Suggested<br>Default |
|-------------|--------------|----------------------|------------------------------------|----------------------|
| 0           | X            | XX                   | Tri-state                          |                      |
| 1           | 0            | XX                   | MVSS                               |                      |
| 1           | 1            | 00                   | Filter output (Vc)                 |                      |
| 1           | 1            | 01                   | Replica bias output for NMOS (Vbn) | 0,0,00               |
| 1           | 1            | 10                   | Replica bias output for PMOS (Vbp) |                      |
| 1           | 1            | 11                   | MVDD                               |                      |

#### Bias Generator Trim:

The bias generator trim capability can be used to adjust the behavior of the bias voltages being supplied to the delay line. Characteristics of the DLL that may warrant an adjustment of this trim value include the inability to lock due to a slow clock (suggest decreasing Vc adjust), inability to lock due to fast clock (suggest increasing Vc adjust) and increase noise margin on bias voltages (suggest decreasing Fmax adjust). The bit fields described in the following table can be set to any value between 000(binary) and 111(binary).

Table 13-5 bias generator trim in dll ctrl

| Field         | Setting | Function                      | Suggested Default |
|---------------|---------|-------------------------------|-------------------|
| hiac trm[2:0] | 000     | Fmax trim: minimum adjust     | 111               |
| bias_trm[2:0] | 111     | Fmax trim: maximum adjust     | 111               |
| hiac trm[6,4] | 000     | Vc level trim: minimum adjust | 011               |
| bias_trm[6:4] | 111     | Vc level trim: maximum adjust | 011               |

#### Feedback Trim:

The feedback trim capability can be used in the event that an adjustment is desired in the phase detector feedback of the DLL. Characteristics of the DLL that may warrant an adjustment of this trim value include non-optimal phase alignment. The lower 3 bits (2:0) are used for feed-back delay trimming and the upper 3 bits (5:3) are used for feed-forward delay trimming. The feed-back trimming is used to decrease total delay, decreasing the amount of delay between phase outputs. The feed-forward trimming is used to increase total delay, increasing the amount of delay between phase outputs. For each 3-bit field, the inputs can be set to any value between 000(binary) and 111(binary).

Table 13-6MDLL feedback trim in dll\_ctrl

| Field               | Setting | Function                 | Suggested Default |
|---------------------|---------|--------------------------|-------------------|
| fb_trm[5:3] 000     |         | Minimum additional delay | 000               |
| (feed-forward path) | 111     | Maximum additional delay | 000               |
| fb_trm[2:0]         | 000     | Minimum additional delay | 000               |
| (feed-back path)    | 111     | Maximum additional delay | 000               |

#### **Bypass Mode**



The DLL has a bypass mode which allows phased clocks to be generated with analog locking circuitry disabled. This mode may be used for low-speed functional testing and for IDDg testing. Bypass mode can also be used when operating with LPDDR SDRAMs. When bypass mode is enabled, all analog circuitry is disabled, and all static current paths are shut down.

Bypass mode has two settings for the clk 90 delay to optimize it for two different frequency ranges.

| Table 13-7 MDLL   | bypass mode frequency    | v range in dll ctrl    |
|-------------------|--------------------------|------------------------|
| Tuble 15 / Mibble | by pass inoue in equence | y i diigo iii dii_ctii |

|        |         | <u> </u>    | <del> </del>      |
|--------|---------|-------------|-------------------|
| Field  | Setting | Function    | Suggested Default |
| bps200 | 0       | 0 to 100MHz | 0                 |
|        | 1       | 0 to 200MHz | ]                 |

It is also possible to trim the 90-degree delay using the fdtrm control bits. Table 13-8fdtrm control bits in dll\_ctrl

| Field      | Setting | Function            | Suggested Default |
|------------|---------|---------------------|-------------------|
| fdtrm[1:0] | 00      | nominal delay       |                   |
|            | 01      | nominal delay - 10% | 00                |
|            | 10      | nominal delay + 10% | 00                |
|            | 11      | nominal delay + 20% |                   |

## 13.4.4 Master-Slave DLL(MSDLL)

Master-Slave DLL for DDRII, and LPDDR applications is an integrated Delay Locked Loop and a pair of slave delays. The Delay Locked Loop (DLL) takes an input reference clock (clk\_in), and generates four clock outputs, each delayed in quarter clock cycle (90°) increments. These four clock phases (clk 0, clk 90, clk\_180, clk\_270) can be generated with very high accuracy and low jitter across a wide range of frequencies.



Fig. 13-6 DDR PHY master-slave DLL architecture diagram



The slave delay pair uses timing reference from the delay line to provide a highly accurate 90° delay to dgs and dgsb inputs (generating dgs\_90 and dasb 90 respectively).

A number of test modes and configuration settings are included:

- ♦ A bypass mode shuts down all analog circuitry, and directly buffers the input clock and strobes with appropriate delays and inversions to the output clocks and strobes. This mode can be used for low speed functional or IDDQ testing.
- ♦ A digital test output (test\_out\_d) provides direct observability of several internal reference clock and timing nodes.
- An analog test output (test out a) provides direct observability of several internal reference voltages.

The primary application for MSDLL is a DDRII Byte Lane PHY with Interface Timing Modules (ITMs)..

#### **MSDLL Control for Trim and Test**

The performance and testing of the MSDLL can be accessed through the dll ctrl bus. Many of these controls are the same as the MDLL, therefore, this section only describes the settings that are different.

Table 13-9 DDR PHYMSDLL control for trim and test

| Static In |         | Field                       | Description                                                                              |  |
|-----------|---------|-----------------------------|------------------------------------------------------------------------------------------|--|
|           | [1:0]   |                             | Reserved                                                                                 |  |
|           | [4:2]   | ipump_trm[2:0]              | Charge pump current trim                                                                 |  |
|           | [5]     | test_ctrl_en                | Test control enable for analog and digital test outputs                                  |  |
|           | [8:6]   | test_ctrl_d[2:0]            | Digital test control. Selects the digital signal to be viewed at the digital test output |  |
|           | [10:9]  | test_ctrl_a[1:0]            | Analog test control. Selects the analog signal to be viewed at the analog test output    |  |
|           | [11]    | test_ctrl_switch            | Test control switch. Selects the analog and digital test signals of master or slave      |  |
|           | [14:12] | bias_trm[2:0]               | Master bias generator frequency trim                                                     |  |
|           | [19,15] | fdtrm[1:0]                  | Master bypass fixed delay trim                                                           |  |
|           | [18:16] | bias_trm[6:4]               | Master bias generator control voltage trim                                               |  |
| dll_ctrl  | [22:20] | sl_bias_trm[2:0             | Slavebias generator control voltage trim                                                 |  |
|           | [23]    | bps200                      | Bypass frequency select                                                                  |  |
|           | [26:24] | sl_bias_trm[6:4             | Slave bias generator control voltage trim                                                |  |
|           | [28:27] | fdtrm_sl[1:0]               | Slave bypass fixed delay trim                                                            |  |
|           | [29]    | lock_det_en                 | Lock detector enable                                                                     |  |
|           | [31:30] |                             | Reserved                                                                                 |  |
|           | [37:32] | sl_fb_trm[5:0]              | Slave feedback delay adjust                                                              |  |
|           | [43:38] | fb_trm[5:0]                 | Master feedback delay adjust                                                             |  |
|           | [45:44] | sl_bypass_start<br>_up[1:0] | Slave auto-startup bypass                                                                |  |
|           | [49:46] | sl_phase_trm[3: 0]          | Slave phase lock trim                                                                    |  |
|           | [50]    | test_hizb_a                 | Analog test output tri-stated control                                                    |  |
|           | [51]    |                             | Reserved                                                                                 |  |



## MSDLL Digital Test Control:

Table 13-10MSDLL digital test control in dll\_ctrl

| test_ctrl<br>_en | test_ctrl<br>switch | test_ctrl_d<br>[2:0] | Function                                  | Suggested<br>Default |
|------------------|---------------------|----------------------|-------------------------------------------|----------------------|
| 0                | X                   | XX                   | digital test outputs disabled (drive '0') | Boldaic              |
| 1                |                     | 000                  | 0°output clock (clk_0)                    |                      |
| 1                |                     | 001                  | 90°output clock (clk_90)                  |                      |
| 1                |                     | 010                  | 180° output clock (clk_180)               |                      |
| 1                | 0                   | 011                  | 270° output clock (clk_270)               |                      |
| 1                | U                   | 100                  | 360° internal clock (clk_360_int)         |                      |
| 1                |                     | 101                  | Master speed-up pulse (spdup)             |                      |
| 1                |                     | 110                  | Master slow-down pulse (slwdn)            |                      |
| 1                |                     | 111                  | Output clock (cclk_0)                     | 0,0,000              |
| 1                |                     | 000                  | Input signal dqs                          | 0,0,000              |
| 1                |                     | 001                  | Slave input clock reference (clk_90_in)   |                      |
| 1                |                     | 010                  | Slave internal feedback clock             |                      |
| <b>-</b>         |                     |                      | (clk_0_out)                               |                      |
| 1                | 1                   | 011                  | Output signal dqsb_90                     |                      |
| 1                |                     | 100                  | Output signal dqs_90                      |                      |
| 1                |                     | 101                  | Slave speed-up pulse (spdup)              |                      |
| 1                |                     | 110                  | Slave slow-down pulse (slwdn)             |                      |
| 1                |                     | 111                  | Auto-lock enable signal                   |                      |

## MSDLL Analog Test Control:

Table 13-11MSDLL analog test control in dll\_ctrl

| Table 13 11M3DLL analog test control in un_ett1 |                 |                     |                      |                                           |                      |
|-------------------------------------------------|-----------------|---------------------|----------------------|-------------------------------------------|----------------------|
| test_hizb<br>a                                  | test_ctrl<br>en | test_ctrl<br>switch | test_ctrl_a<br>[1:0] | Function                                  | Suggested<br>Default |
| 0                                               | _               |                     |                      | Tri-state                                 | Derdare              |
| U                                               | X               | X                   | XX                   |                                           |                      |
| 1                                               | 0               | X                   | XX                   | MVSS                                      |                      |
| 1                                               | 1               | • 1                 | 00                   | Master Filter output (Vc)                 |                      |
| 1                                               | 1               |                     | 01                   | Master Replica bias output for NMOS (Vbn) |                      |
| 1                                               | 1               | 0                   | 10                   | Master Replica bias output for PMOS (Vbp) | 0,0,0,00             |
| 1                                               | 1               |                     | 11                   | MVDD                                      | 0,0,0,00             |
| 1                                               | 1               |                     | 00                   | Slave Filter output (Vc)                  |                      |
| 1                                               | 1               | 01                  |                      | Slave Replica bias output for NMOS (Vbn)  |                      |
| 1                                               | 1               |                     | 10                   | Slave Replica bias output for PMOS (Vbp)  |                      |
| 1                                               | 1               |                     | 11                   | MVDD                                      |                      |

#### MSDLL Lock Detector Enable:

This setting enables start of the slave DLL section after the master DLL section has reached lock. Characteristics of the DLL that may warrant an adjustment of this trim value include the slave DLL delay remaining in it's reset state (minimum delay, much less than 90 degrees) after the DLL lock time.

Table 13-12MSDLL lock detector enable in dll ctrl

| Field Setting |   | Function              | Suggested Default |  |  |  |  |  |
|---------------|---|-----------------------|-------------------|--|--|--|--|--|
| lock dat on   | 0 | Disable lock detector | 0                 |  |  |  |  |  |
| lock_det_en   | 1 | Enable lock detector  | U                 |  |  |  |  |  |



## Slave Auto-Startup Bypass:

By default, the slave DLL automatically starts to lock during the time the master is locking, after the master has begun to approach lock. This setting permits the user to manually start-up the slave DLL. To bypass the automatic startup, this setting should be set to '10'. Once the specified number of clocks has passed for the master DLL to achieve lock, the user sets this field to '11' to permit the slave DLL to startup. The user then waits for the specified number of clocks for the slave DLL to lock before proceeding. Characteristics of the slave DLL that might warrant a manual startup of the slave DLL include the inability for the slave DLL to produce a consistent and/or correct phase difference between the input signal and the output signal.

Table 13-13 slave auto\_startup bypass in dll\_ctrl

| sl_bypass_start<br>_up[1:0] | Function                                                                  | Suggested<br>Default |
|-----------------------------|---------------------------------------------------------------------------|----------------------|
| 0X                          | Slave DLL automatically starts up                                         |                      |
| 10                          | Slave DLL's automatic startup is disabled; the phase detector is disabled | 00                   |
| 11                          | Slave DLL's automatic startup is disabled; the phase detector is enabled  |                      |

#### Slave DLL Phase Trim:

Selects the phase difference between the input signal and the corresponding output signal of the slave DLL. This setting applies to the dqs to dqs\_90 and dgsb to dgsb 90 paths. The nominal phase difference is 90 degrees. Users may select to modify this value to account for factors external to the DLL, which require the DLL to produce a delay of greater than or less than the nominal 90 degrees. When modifying the value of these bits, the user does not need to issue a reset to the DLL but should wait the equivalent of the DLL lock time before the slave DLL circuitry is used (such as, receiving Read data from an SDRAM) to ensure the DLL has adequate time to stabilize with the new settings.

Table 13-14 slave DLL phase trim in dll ctrl

| Table 13-14 slave BLL phase thin in un_ctri |                            |                   |  |  |  |  |
|---------------------------------------------|----------------------------|-------------------|--|--|--|--|
| sl_phase_trm[3:0]                           | Phase Difference (degrees) | Suggested Default |  |  |  |  |
| 0000                                        | 90                         |                   |  |  |  |  |
| 0001                                        | 72                         |                   |  |  |  |  |
| 0010                                        | 54                         |                   |  |  |  |  |
| 0011                                        | 36                         |                   |  |  |  |  |
| 0100                                        | 108                        |                   |  |  |  |  |
| 0101                                        | 90                         |                   |  |  |  |  |
| 0110                                        | 72                         |                   |  |  |  |  |
| 0111                                        | 54                         | 0000              |  |  |  |  |
| 1000                                        | 126                        | 0000              |  |  |  |  |
| 1001                                        | 108                        |                   |  |  |  |  |
| 1010                                        | 90                         |                   |  |  |  |  |
| 1011                                        | 72                         |                   |  |  |  |  |
| 1100                                        | 144                        |                   |  |  |  |  |
| 1101                                        | 126                        |                   |  |  |  |  |
| 1110                                        | 108                        |                   |  |  |  |  |
| 1111                                        | 90                         |                   |  |  |  |  |

### **MSDLL Bypass Mode**

The DLL bypass mode, when enabled, shuts down all analog delay paths and phase detection circuitry and generates output clocks as directly buffered and



inverted versions of clk in. Bypass mode can be used for low-speed functional testing or for IDDQ testing. Bypass mode can also be used when operating with LPDDR SDRAMs. When bypass mode is enabled, all analog circuitry is disabled, and all static current paths are shut down. Phased outputs are generated during bypass with inverters and standard delays:

= buffered clk in clk 0 = delayed version of clk\_0 clk 90 clk 180 = inverted clk 0 clk 270 = inverted clk 90 cclk 0 = buffered clk in dqs\_90 = delayed version of dqs dqsb\_90 = delayed version of dqsb

Bypass mode has two settings for the clk\_90 delay to optimize it for two different frequency ranges same as MDLL.

It is also possible to trim the MDLL 90 degree delay using the fdtrm control bits same as MDLL. And it is also possible to trim the MSDLL 90 degree delay using the fdtrm\_sl control bits same as fdtrm.

#### 13.4.5 DQS Gating

DDRII systems use a bidirectional data strobe which is driven by the host during memory writes, and by the SDRAM during memory reads. During active read commands, the ITMS basically acts as a buffer for the incoming DOS/DOS b. A turn-around time exists between operations when neither device is driving the bus, and the strobe traces are held by termination circuitry at a mid-rail voltage.

While the DQS lines are held at mid-rail during inactive periods, an unknown value X is being received by the SSTL inputs. To prevent X from causing false transitions and other negative effects within the read path, the input read dgs strobe path is disabled when there is no active read data. The ITMS provides the functions to enable/disable this path, while the control of these functions is provided by the memory controller logic. A basic view of the enable/disable requirements is shown in following figure.



Fig. 13-7Strobe Gating Requirements During Read Operations

After a read is issued, the SDRAM drives DQS and DQS b for a number of clock cycles equal to the read burst length. Differing SDRAM CAS latencies, clock cycle times, board trace lengths, and other analog factors between controller and SDRAM result in a variable latency between when the read was issued, and when the returning DQS/DQS\_b strobes reach the ITMS. The goal of DQS gating is to control a window, which enables and disables the input read dqs path only when the DQS lines are active, not when they are at mid-rail. There is a pre-amble and post-amble surrounding the active DQS edges that is used as the point to perform the enabling and disabling of this window.



There are two windowing schemes supported by the ITMS - passive windowing and active windowing - which are selected by input dgs config.

## **Passive Windowing**

In the passive windowing mode (dgs config = 1), the controller asserts dgs\_en at the start of the window and de-asserts dgs\_en at the end of the window. This provides the course (clock-cycle) position of the enable and disable edges. Fine tuning (1/4 clock cycle) of the window placement is selected by phase sel[1:0].



Fig. 13-8DQS gating – passive windowing mode

The phase sel[1:0] settings are provided. Table 13-15 phase selection for dos gating

| rabit to to prince series for ade garing |                               |                 |  |  |  |  |
|------------------------------------------|-------------------------------|-----------------|--|--|--|--|
| phase_sel[1:0] Phase Selection           |                               |                 |  |  |  |  |
| Setting                                  | Setting Selected Phase Offset |                 |  |  |  |  |
| 00                                       | clk_90 (90 deg)               | 1/4 clock cycle |  |  |  |  |
| 01 clk_180 (180 deg) 1/2 clock cycle     |                               |                 |  |  |  |  |
| 10                                       | clk_270 (270 deg)             | 3/4 clock cycle |  |  |  |  |
| 11                                       | clk_0 (360 deg)               | 1 clock cycle   |  |  |  |  |

#### **Active Windowing**

The active windowing mode addresses the fact that the postamble is shorter than the preamble. The optimal window position for the preamble and postamble are not necessarily the same. In the active windowing mode (dgs config = 0), the controller asserts dgs en for one clock cycle at the start of the window and asserts dgs\_dis for one clock cycle at the end of the window. Internal to ITMS, the assertion of dgs dis is shifted by a further 180 degrees to account for the fact that DQS\_b occurs 180 degrees later than DQS. This provides the course (clock-cycle) position of the enable and disable edges.

Fine tuning (1/4 clock cycle) of the window placement is selected by phase\_sel[1:0]. The effective window is opened in the same manner as in the passive windowing mode, such as dqs\_en assertion plus the phase\_sel offset. To close the window, the controller asserts dgs\_dis to inform the ITMS to expect the last DQS\_b rising edge of the burst. The phase\_sel setting is applied to this to set the effective time at which to expect the last DQS\_b rising edge. The last DOS b rising edge of the burst is also the last data of the burst. This last DOS b rising edge is used to close the window. Thus, the window is self-closing.



Fig. 13-9DQS gating – active windowing mode

#### 13.4.6 Dynamic Strobe Drift Detection

DDRII systems can have a long round-trip path from the controller clock output (CK), to the SDRAM, and back to the controller data strobe input (DQS). The sum of potential variations in this path can exceed 25% of a clock cycle at high frequencies (>300MHz), so some compensation should be made if the path delay increases or decreases slowly, but significantly, during normal operation.

The ITMS component has a two-bit strobe drift indicator (dgs\_drift), which changes value in grey code if the returning strobe drifts across internal 90° timing reference boundaries. The absolute value of this indicator is not important, but the change in value over time is.

| dqs_drift[1:0] |           | DQS Drift | Required Changes                         |
|----------------|-----------|-----------|------------------------------------------|
| Old Value      | New Value | Direction | 1 3                                      |
| 00 01 10       |           | forward   | increase read data latency by 90 degrees |
|                |           | backward  | decrease read data latency by 90 degrees |
| 01 11 00       |           | forward   | increase read data latency by 90 degrees |
|                |           | backward  | decrease read data latency by 90 degrees |
| 10 00          |           | forward   | increase read data latency by 90 degrees |
| 10 11          |           | backward  | decrease read data latency by 90 degrees |
| 11             | 10        | forward   | increase read data latency by 90 degrees |
| 1 11           | 01        | backward  | decrease read data latency by 90 degrees |

Table 13-16 dynamic strobe drift indicators

# 13.5 Register description

## 13.5.1 Registers Summary

| Name          | Offset | Size | Reset<br>Value | Description                           |
|---------------|--------|------|----------------|---------------------------------------|
| DDR_PCTL_SCFG | 0×0000 | W    | 0×0000030<br>0 | State<br>Configuration<br>Register    |
| DDR_PCTL_SCTL | 0x0004 | W    | 0x0000000<br>0 | Operational State<br>Control Register |



Configuration 1

Register

0x0090

W

0

DDR\_PCTL\_MCFG1



| Name                | Offset | Size | Reset<br>Value | Description                                    |
|---------------------|--------|------|----------------|------------------------------------------------|
| DDR_PCTL_DTUPDES    | 0x0094 | W    | 0x0000000<br>0 | DTU Status<br>Register                         |
| DDR_PCTL_DTUNA      | 0x0098 | W    | 0x0000000<br>0 | DTU Number of<br>Addresses Created<br>Register |
| DDR_PCTL_DTUNE      | 0x009c | W    | 0x0000000<br>0 | DTU Number of<br>Errors Register               |
| DDR_PCTL_DTUPRD0    | 0x00a0 | W    | 0x0000000<br>0 | DTU Parallel Read<br>0 Register                |
| DDR_PCTL_DTUPRD1    | 0x00a4 | W    | 0x0000000<br>0 | DTU Parallel Read<br>1 Register                |
| DDR_PCTL_DTUPRD2    | 0x00a8 | W    | 0x0000000<br>0 | DTU Parallel Read<br>2 Register                |
| DDR_PCTL_DTUPRD3    | 0x00ac | W    | 0x0000000<br>0 | DTU Parallel Read<br>3 Register                |
| DDR_PCTL_DTUAWDT    | 0x00b0 | W    | 0x0000029<br>0 | DTU Address<br>Width Register                  |
| DDR_PCTL_TOGCNT1U   | 0x00c0 | W    | 0x0000006<br>4 | Toggle Counter<br>1us Register                 |
| DDR_PCTL_TINIT      | 0x00c4 | W    | 0x000000c<br>8 | t_init Timing<br>Register                      |
| DDR_PCTL_TRSTH      | 0x00c8 | W    | 0x0000000<br>0 | t_rsth Timing<br>Register                      |
| DDR_PCTL_TOGCNT100N | 0х00сс | W    | 0x0000000<br>1 | Toggle Counter<br>100ns                        |
| DDR_PCTL_TREFI      | 0x00d0 | W    | 0x0000000<br>1 | t_refi Timing<br>Register                      |
| DDR_PCTL_TMRD       | 0x00d4 | W    | 0x0000000<br>1 | t_mrd Timing<br>Register                       |
| DDR_PCTL_TRFC       | 0x00d8 | W    | 0x0000000<br>1 |                                                |
| DDR_PCTL_TRP        | 0x00dc | W    | 0x0001000<br>6 | t_trp Timing<br>Register                       |
| DDR_PCTL_TRTW       | 0x00e0 | W    | 0x0000000<br>2 | t_rtw Timing<br>Register                       |
| DDR_PCTL_TAL        | 0x00e4 | W    | 0x0000000<br>0 | AL Register                                    |
| DDR_PCTL_TCL        | 0x00e8 | W    | 0x0000000<br>4 | CL Timing Register                             |
| DDR_PCTL_TCWL       | 0x00ec | W    | 0x0000000<br>3 | CWL Timing<br>Register                         |



| Name            | Offset | Size | Reset<br>Value | Description                  |
|-----------------|--------|------|----------------|------------------------------|
| DDR_PCTL_TRAS   | 0x00f0 | W    | 0x0000001<br>0 | t_ras Timing<br>Register     |
| DDR_PCTL_TRC    | 0x00f4 | W    | 0x0000001<br>6 | t_rc Timing<br>Register      |
| DDR_PCTL_TRCD   | 0x00f8 | W    | 0x0000000<br>6 | t_rcd Timing<br>Register     |
| DDR_PCTL_TRRD   | 0x00fc | W    | 0x0000000<br>4 | t_rrd Timing<br>Register     |
| DDR_PCTL_TRTP   | 0×0100 | W    | 0x0000000      | t_rtp Timing<br>Register     |
| DDR_PCTL_TWR    | 0x0104 | W    | 0x0000000<br>6 | t_wr Register                |
| DDR_PCTL_TWTR   | 0×0108 | W    | 0x0000000<br>4 | t_wtr Timing<br>Register     |
| DDR_PCTL_TEXSR  | 0x010c | W    | 0x0000000<br>1 | t_exsr Timing<br>Register    |
| DDR_PCTL_TXP    | 0×0110 | w    | 0x0000000<br>1 | t_xp Timing<br>Register      |
| DDR_PCTL_TXPDLL | 0x0114 | W    | 0x0000000<br>0 | t_xpdll Timing<br>Register   |
| DDR_PCTL_TZQCS  | 0x0118 | W    | 0x0000000<br>0 | t_zqcs Timing<br>Register    |
| DDR_PCTL_TZQCSI | 0x011c | W    | 0x0000000<br>0 | t_zqcsi Timing<br>Register   |
| DDR_PCTL_TDQS   | 0x0120 | W    | 0x0000000<br>1 | t_dqs Timing<br>Register     |
| DDR_PCTL_TCKSRE | 0x0124 | W    | 0x0000000<br>0 | t_cksre Timing<br>Register   |
| DDR_PCTL_TCKSRX | 0x0128 | W    | 0x0000000<br>0 | t_cksrx Timing<br>Register   |
| DDR_PCTL_TCKE   | 0x012c | W    | 0x0000000<br>3 | t_cke Timing<br>Register     |
| DDR_PCTL_TMOD   | 0x0130 | W    | 0x0000000<br>0 | t_mod Timing<br>Register     |
| DDR_PCTL_TRSTL  | 0x0134 | W    | 0x0000000<br>0 | Reset Low Timing<br>Register |
| DDR_PCTL_TZQCL  | 0x0138 | W    | 0x0000000<br>0 | t_zqcl Timing<br>Register    |
| DDR_PCTL_TMRR   | 0x013c | W    | 0x0000000<br>2 | t_mrr Timing<br>Register     |



| Name               | Offset | Size | Reset<br>Value | Description       |
|--------------------|--------|------|----------------|-------------------|
| DDR_PCTL_TCKESR    | 0x0140 | W    | 0x0000000      | t_ckesr Timing    |
| DDK_FCIL_ICKLSK    | 000140 | VV   | 4              | Register          |
| DDR_PCTL_TDPD      | 0x0144 | W    | 0x0000000      | t_dpd Timing      |
| DDK_FCFE_FDFD      | 0,0144 | •    | 0              | Register          |
| DDR_PCTL_DTUWACTL  | 0x0200 | W    | 0×0000000      | DTU Write Address |
| DBK_FETE_BTOWNETE  | 000200 |      | 0              | Control           |
| DDR_PCTL_DTURACTL  | 0x0204 | w    |                | DTU Read Address  |
|                    | -      |      | 0              | Control Register  |
| DDR_PCTL_DTUCFG    | 0x0208 | w    |                | DTU Configuration |
|                    |        |      | 0              | Control Register  |
| DDR_PCTL_DTUECTL   | 0x020c | w    |                | DTU Execute       |
|                    |        |      | 0              | Control Register  |
| DDR_PCTL_DTUWD0    | 0x0210 | w    | A              | DTU Write Data #0 |
|                    |        |      | 0              | Register          |
| DDR_PCTL_DTUWD1    | 0x0214 | w    |                | DTU Write Data #1 |
|                    |        |      | 0              | Register          |
| DDR_PCTL_DTUWD2    | 0x0218 | w C  | . 7            | DTU Write Data #2 |
|                    |        |      | 0              | Register          |
| DDR_PCTL_DTUWD3    | 0x021c | W    |                | DTU Write Data #3 |
|                    |        | ) >  | 0              | Register          |
| DDR_PCTL_DTUWDM    | 0x0220 | w    | 0x0000000      |                   |
|                    |        |      | 0              | Mask Register     |
| DDR_PCTL_DTURD0    | 0x0224 | W    |                | DTU Read Data #0  |
|                    | 2      |      | 0              | Register          |
| DDR_PCTL_DTURD1    | 0x0228 | W    |                | DTU Read Data #1  |
|                    |        |      | 0              | Register          |
| DDR_PCTL_DTURD2    | 0x022c | W    |                | DTU Read Data #2  |
|                    |        |      | 0              | Register          |
| DDR_PCTL_DTURD3    | 0x0230 | W    |                | DTU Read Data #3  |
|                    |        |      | 0              | Register          |
|                    |        |      |                | DTU LFSR Seed for |
| DDR_PCTL_DTULFSRWD | 0x0234 | W    | 0x0000000      |                   |
|                    |        |      | 0              | Generation        |
|                    |        |      |                | Register          |
|                    |        |      | 00000000       | DTU LFSR Seed for |
| DDR_PCTL_DTULFSRRD | 0x0238 | W    | 0x0000000      |                   |
|                    |        |      | 0              | Generation        |
|                    |        |      | 00000000       | Register          |
| DDR_PCTL_DTUEAF    | 0x023c | W    |                | DTU Error Address |
|                    |        |      | 0              | FIFO Register     |





| Name                          | Offset | Size | Reset<br>Value | Description                                   |
|-------------------------------|--------|------|----------------|-----------------------------------------------|
| DDR_PCTL_DFITCTRLUPDI         | 0x0298 | w    | 0x0000000<br>0 | DFI<br>tctrlupd_interval<br>Register          |
| DDR_PCTL_DFITRCFG0            | 0x02ac | w    | 0×0000000<br>0 | DFI Training<br>Configuration 0<br>Register   |
| DDR_PCTL_DFITRSTAT0           | 0x02b0 | w    | 0x0000000<br>0 | DFI Training<br>Status 0 Register             |
| DDR_PCTL_DFITRWRLVLEN         | 0x02b4 | W    | 0×0000000<br>0 | DFI Training<br>dfi_wrlvl_en<br>Register      |
| DDR_PCTL_DFITRRDLVLEN         | 0x02b8 | W    | 0×0000000<br>0 | DFI Training<br>dfi_rdlvl_en<br>Register      |
| DDR_PCTL_DFITRRDLVLGATE<br>EN | 0x02bc | W    | 0x0000000<br>0 | DFI Training<br>dfi_rdlvl_gate_en<br>Register |
| DDR_PCTL_DFISTSTAT0           | 0x02c0 | W    | 0x0000000<br>0 | DFI Status Status<br>0 Register               |
| DDR_PCTL_DFISTCFG0            | 0x02c4 | W    | 0×0000000<br>0 | DFI Status<br>Configuration 0<br>Register     |
| DDR_PCTL_DFISTCFG1            | 0x02c8 | W    | 0×0000000<br>0 | DFI Status<br>Configuration 1<br>Register     |
| DDR_PCTL_DFITDRAMCLKEN        | 0x02d0 | w    | 0x0000000<br>2 | DFI<br>tdram_clk_enable<br>Register           |
| DDR_PCTL_DFITDRAMCLKDIS       | 0x02d4 | w    | 0x0000000<br>2 | DFI<br>tdram_clk_disable<br>Register          |
| DDR_PCTL_DFISTCFG2            | 0x02d8 | w    | 0x0000000<br>0 | DFI Status<br>Configuration 2<br>Register     |
| DDR_PCTL_DFISTPARCLR          | 0x02dc | W    | 0x0000000<br>0 | DFI Status Parity<br>Clear Register           |
| DDR_PCTL_DFISTPARLOG          | 0x02e0 | W    | 0x0000000<br>0 | DFI Status Parity<br>Log Register             |
| DDR_PCTL_DFILPCFG0            | 0x02f0 | W    | 0x0007000<br>0 | DFI Low Power<br>Configuration 0<br>Register  |



| Name                          | Offset | Size | Reset<br>Value | Description                                           |
|-------------------------------|--------|------|----------------|-------------------------------------------------------|
| DDR_PCTL_DFITRWRLVLRESP       | 0x0300 | w    | 0x0000000<br>0 | DFI Training<br>dfi_wrlvl_resp<br>Status 0 Register   |
| DDR_PCTL_DFITRWRLVLRESP       | 0x0304 | W    | 0x0000000<br>0 | DFI Training<br>dfi_wrlvl_resp<br>Status 1 Register   |
| DDR_PCTL_DFITRWRLVLRESP       | 0x0308 | W    | 0×0000000<br>0 | DFI Training<br>dfi_wrlvl_resp<br>Status 2 Register   |
| DDR_PCTL_DFITRRDLVLRESP<br>0  | 0x030c | W    | 0x0000000<br>0 | DFI Training<br>dfi_rdlvl_resp<br>Status 0 Register   |
| DDR_PCTL_DFITRRDLVLRESP       | 0x0310 | W    | 0×0000000      | DFI Training<br>dfi_rdlvl_resp<br>Status 1 Register   |
| DDR_PCTL_DFITRRDLVLRESP 2     | 0x0314 | w    | 0x0000000<br>0 | DFI Training<br>dfi_rdlvl_resp<br>Status 2 Register   |
| DDR_PCTL_DFITRWRLVLDELA<br>Y0 | 0x0318 | w    | 0x0000000<br>0 | DFI Training dfi_wrlvl_delay Configuration 0 Register |
| DDR_PCTL_DFITRWRLVLDELA<br>Y1 | 0x031c | W    | 0×0000000<br>0 | DFI Training dfi_wrlvl_delay Configuration 1 Register |
| DDR_PCTL_DFITRWRLVLDELA<br>Y2 | 0x0320 | W    | 0×0000000<br>0 | DFI Training dfi_wrlvl_delay Configuration 2 Register |
| DDR_PCTL_DFITRRDLVLDELA<br>Y0 | 0x0324 | W    | 0x0000000<br>0 | DFI Training dfi_rdlvl_delay Configuration 0 Register |
| DDR_PCTL_DFITRRDLVLDELA<br>Y1 | 0x0328 | W    | 0x0000000<br>0 | DFI Training dfi_rdlvl_delay Configuration 1 Register |
| DDR_PCTL_DFITRRDLVLDELA<br>Y2 | 0x032c | w    | 0×0000000<br>0 | DFI Training dfi_rdlvl_delay Configuration 2 Register |



| Name                    | Offset | Size | Reset<br>Value | Description                        |
|-------------------------|--------|------|----------------|------------------------------------|
| DDR_PCTL_DFITRRDLVLGATE | 0x0330 | W    | 0×0000000      | DFI Training<br>dfi_rdlvl_gate_del |
| DELAY0                  | UNUSSU | ' '  | 0              | ay Configuration 0                 |
| DDR_PCTL_DFITRRDLVLGATE |        |      | 0x0000000      | DFI Training                       |
| DELAY1                  | 0x0334 | W    | 0              | dfi_rdlvl_gate_del                 |
| DLLATI                  |        |      | O              | ay Configuration 1                 |
| DDR_PCTL_DFITRRDLVLGATE | 0x0338 | W    | 0x0000000      | DFI Training                       |
| DELAY2                  |        |      | 0.00000000     | dfi_rdlvl_gate_del                 |
| DELATZ                  |        |      | U              | ay Configuration 2                 |
|                         |        | W    | 0x0000000      | DFI Training                       |
| DDR_PCTL_DFITRCMD       | 0x033c |      | 0              | Command                            |
|                         |        |      | U              | Register                           |
| DDB BCTL IBVB           | 0v02f0 | ١٨/  | 0x0000000      | IP Version                         |
| DDR_PCTL_IPVR           | 0x03f8 | W    | 0              | Register                           |
| DDR_PCTL_IPTR           | 0x03fc | W    | 0x4457430<br>0 | IP Type Register                   |

| Name               | Offset | Size | Reset<br>Value | Description                                  |
|--------------------|--------|------|----------------|----------------------------------------------|
| DDR_PHYCTL_RIDR    | 0x0000 | w    | 0x00100140     | Revision Identification<br>Register          |
| DDR_PHYCTL_PIR     | 0x0004 | W    | 0×00000000     | PHY Initialization<br>Register               |
| DDR_PHYCTL_PGCR    | 0x0008 | W    | 0x01bc2e04     | PHY General<br>Configuration Register        |
| DDR_PHYCTL_PGSR    | 0x000c | W    | 0x00000000     | PHY General Status<br>Register               |
| DDR_PHYCTL_DLLGCR  | 0x0010 | W    | 0x03737000     | DLL General Control<br>Register              |
| DDR_PHYCTL_ACDLLCR | 0x0014 | W    | 0x40000000     | AC DLL Control Register                      |
| DDR_PHYCTL_PTR0    | 0x0018 | W    | 0x0022af9b     | PHY Timing Register 0                        |
| DDR_PHYCTL_PTR1    | 0x001c | W    | 0x0604111d     | PHY Timing Register 1                        |
| DDR_PHYCTL_PTR2    | 0x0020 | W    | 0x042da072     | PHY Timing Register 2                        |
| DDR_PHYCTL_ACIOCR  | 0x0024 | W    | 0x33c03812     | AC I/O Configuration<br>Register             |
| DDR_PHYCTL_DXCCR   | 0x0028 | W    | 0x00000800     | DATX8 Common<br>Configuration Register       |
| DDR_PHYCTL_DSGCR   | 0x002c | W    | 0xfa00001f     | DDR System General<br>Configuration Register |
| DDR_PHYCTL_DCR     | 0x0030 | W    | 0x0000000b     | DRAM Configuration<br>Register               |



|                      |                    |      | Reset      |                                    |
|----------------------|--------------------|------|------------|------------------------------------|
| Name                 | Offset             | Size | Value      | Description                        |
| DDR_PHYCTL_DTPR0     | 0x0034             | ۱۸/  | 0x3092666e | DRAM Timing                        |
| DDK_ITHCIL_DITKO     | 0,00054            | VV   | 0230320000 | Parameters Register 0              |
| DDR_PHYCTL_DTPR1     | 0x0038             | ۱۸/  | 0x09830090 | DRAM Timing                        |
| DDK_ITHCIL_DITKI     | 0,0000             | VV   | 000000000  | Parameters Register 1              |
| DDR_PHYCTL_DTPR2     | 0x003c             | w    | 0x1001a0c8 | DRAM Timing                        |
| 551                  | OXOUSE             | ••   |            | Parameters Register 2              |
| DDR_PHYCTL_MR0       | 0x0040             |      |            | Mode Register 0                    |
| DDR_PHYCTL_MR1       | 0x0044             |      |            | Mode Register 1                    |
| DDR_PHYCTL_MR2       | 0x0048             |      |            | Mode Register 2                    |
| DDR_PHYCTL_MR3       | 0x004c             | W    | 0x00000000 | Mode Register 3                    |
| DDR_PHYCTL_ODTCR     | 0x0050             | W    | 0x00210000 | ODT Configuration<br>Register      |
| DDR_PHYCTL_DTAR      | 0x0054             | W    | 0x00000000 | Data Training Address              |
|                      |                    |      |            | Register                           |
| DDR_PHYCTL_DTDR0     | 0x0058             | W    | 0xdd22ee11 | Data Training Data                 |
|                      |                    |      |            | Register 0                         |
| DDR_PHYCTL_DTDR1     | 0x005c             | W    | 0x7788bb44 | Data Training Data                 |
| DDD DUVCTI DCUAD     | 0.00.0             | 147  | 0.0000000  | Register 1                         |
| DDR_PHYCTL_DCUAR     | 0x00c0             |      |            | DCU Address Register               |
| DDR_PHYCTL_DCUDR     | 0x00c4             |      | -          | DCU Data Register                  |
| DDR_PHYCTL_DCURR     | 0x00c8             |      |            | DCU Run Register                   |
| DDR_PHYCTL_DCULR     | 0x00cc             | VV   | 0x00000000 | DCU Loop Register                  |
| DDR_PHYCTL_DCUGCR    | 0x00d0             | W    | 0x00000000 | DCU General                        |
| ^                    |                    |      |            | Configuration Register             |
| DDR_PHYCTL_DCUTPR    | 0x00d4             | W    | 0x00000000 | DCU Timing Parameters<br>Registers |
| DDR_PHYCTL_DCUSR0    | 0x00d8             | ۱۸/  | 0×00000000 | DCU Status Register 0              |
| DDR_PHYCTL_DCUSR1    | 0x00d8             |      |            | DCU Status Register 1              |
| DDR PHYCTL BISTRR    | 0x0100             |      |            | BIST Run Register                  |
| DDR_PHYCTL_BISTMSKR0 |                    |      |            | BIST Mask Register 0               |
| DDR_PHYCTL_BISTMSKR1 |                    | 1    |            | BIST Mask Register 1               |
| DDK_FITCTL_BISTMSKKI | 00100              | VV   | 0x00000000 | BIST Word Count                    |
| DDR_PHYCTL_BISTWCR   | 0x010c             | W    | 0×00000020 | Register                           |
| DDR_PHYCTL_BISTLSR   | 0x0110             | W    | 0x1234abcd | BIST LFSR Seed Register            |
| DDR_PHYCTL_BISTAR0   | 0x0114             | W    | 0x0000000  | BIST Address Register 0            |
| DDR_PHYCTL_BISTAR1   | 0x0118             | W    | 0x000000c  | BIST Address Register 1            |
| DDR_PHYCTL_BISTAR2   | 0x011c             | W    | 0x7fffffff | BIST Address Register 2            |
| DDR_PHYCTL_BISTUDPR  | 0x0120             | \٨/  | 0xffff0000 | BIST User Data Pattern             |
| DDK_ITTCTE_DISTORK   | OXO120 W OXIIIIOOC |      | Register   |                                    |
| DDR_PHYCTL_BISTGSR   | 0x0124             | w    | 0×00000000 | BIST General Status                |
|                      | 37012-1            |      |            | Register                           |



| Name                | Offset | Size | Reset<br>Value | Description                          |
|---------------------|--------|------|----------------|--------------------------------------|
| DDR_PHYCTL_BISTWER  | 0x0128 | W    | 0x00000000     | BIST Word Error<br>Register          |
| DDR_PHYCTL_BISTBER0 | 0x012c | W    | 0x0000000      | BIST Bit Error Register 0            |
| DDR_PHYCTL_BISTBER1 | 0x0130 | W    | 0x00000000     | BIST Bit Error Register 1            |
| DDR_PHYCTL_BISTBER2 | 0x0134 | W    | 0x00000000     | BIST Bit Error Register 2            |
| DDR_PHYCTL_BISTWCSR | 0x0138 | W    | 0x00000000     | BIST Word Count Status<br>Register   |
| DDR_PHYCTL_BISTFWR0 | 0x013c | W    | 0x00000000     | BIST Fail Word Register 0            |
| DDR_PHYCTL_BISTFWR1 | 0x0140 | W    | 0×00000000     | BIST Fail Word Register<br>1         |
| DDR_PHYCTL_ZQ0CR0   | 0x0180 | W    | 0x0000014a     | ZQ 0 Impedance Control<br>Register 0 |
| DDR_PHYCTL_ZQ0CR1   | 0x0184 | W    | 0x0000007b     | ZQ 0 Impedance Control<br>Register 1 |
| DDR_PHYCTL_ZQ0SR0   | 0x0188 | W    | 0x00000000     | ZQ 0 Impedance Status<br>Register 0  |
| DDR_PHYCTL_ZQ0SR1   | 0x018c | W    | 0x00000000     | ZQ 0 Impedance Status<br>Register 1  |
| DDR_PHYCTL_ZQ1CR0   | 0x0190 | w    | 0x0000014a     | ZQ 1 Impedance Control<br>Register 0 |
| DDR_PHYCTL_ZQ1CR1   | 0x0194 | W    | 0x0000007b     | ZQ 1 Impedance Control<br>Register 1 |
| DDR_PHYCTL_ZQ1SR0   | 0x0198 | W    | 0x00000000     | ZQ 1 Impedance Status<br>Register 0  |
| DDR_PHYCTL_ZQ1SR1   | 0x019c | W    | 0x00000000     | ZQ 1 Impedance Status<br>Register 1  |
| DDR_PHYCTL_ZQ2CR0   | 0x01a0 | W    | 0x0000014a     | ZQ 2 Impedance Control<br>Register 0 |
| DDR_PHYCTL_ZQ2CR1   | 0x01a4 | W    | 0x0000007b     | ZQ 2 Impedance Control<br>Register 1 |
| DDR_PHYCTL_ZQ2SR0   | 0x01a8 | W    | 0x00000000     | ZQ 2 Impedance Status<br>Register 0  |
| DDR_PHYCTL_ZQ2SR1   | 0x01ac | W    | 0x00000000     | ZQ 2 Impedance Status<br>Register 1  |
| DDR_PHYCTL_ZQ3CR0   | 0x01b0 | W    | 0x0000014a     | ZQ 3 Impedance Control<br>Register 0 |
| DDR_PHYCTL_ZQ3CR1   | 0x01b4 | W    | 0x0000007b     | ZQ 3 Impedance Control<br>Register 1 |
| DDR_PHYCTL_ZQ3SR0   | 0x01b8 | W    | 0x00000000     | ZQ 3 Impedance Status<br>Register 0  |



| Name                | Offset | Size | Reset<br>Value | Description                               |
|---------------------|--------|------|----------------|-------------------------------------------|
| DDR_PHYCTL_ZQ3SR1   | 0x01bc | W    | 0×00000000     | ZQ 3 Impedance Status<br>Register 1       |
| DDR_PHYCTL_DX0GCR   | 0x01c0 | W    | 0x00000681     | DATX8 0 General<br>Configuration Register |
| DDR_PHYCTL_DX0GSR0  | 0x01c4 | W    | 0×00000000     | DATX8 0 General Status<br>Register 0      |
| DDR_PHYCTL_DX0GSR1  | 0x01c8 | W    | 0x00000000     | DATX8 0 General Status<br>Register 1      |
| DDR_PHYCTL_DX0DLLCR | 0x01cc | W    | 0x40000000     | DATX8 0 DLL Control<br>Register           |
| DDR_PHYCTL_DX0DQTR  | 0x01d0 | W    | 0xffffffff     | DATX8 0 DQ Timing<br>Register             |
| DDR_PHYCTL_DX0DQSTR | 0x01d4 | W    | 0x3db55000     | DATX8 0 DQS Timing<br>Register            |
| DDR_PHYCTL_DX1GCR   | 0x0200 | W    | 0x00000681     | DATX8 1 General<br>Configuration Register |
| DDR_PHYCTL_DX1GSR0  | 0x0204 | W    | 0x00000000     | DATX8 1 General Status<br>Register 0      |
| DDR_PHYCTL_DX1GSR1  | 0x0208 | W    | 0×00000000     | DATX8 1 General Status<br>Register 1      |
| DDR_PHYCTL_DX1DLLCR | 0x020c | W)   | 0×40000000     | DATX8 1 DLL Control<br>Register           |
| DDR_PHYCTL_DX1DQTR  | 0x0210 | W    | 0xffffffff     | DATX8 1 DQ Timing<br>Register             |
| DDR_PHYCTL_DX1DQSTR | 0x0214 | W    | 0x3db55000     | DATX8 1 DQS Timing<br>Register            |
| DDR_PHYCTL_DX2GCR   | 0x0240 | W    | 0x00000681     | DATX8 2 General<br>Configuration Register |
| DDR_PHYCTL_DX2GSR0  | 0x0244 | W    | 0x00000000     | DATX8 2 General Status<br>Register 0      |
| DDR_PHYCTL_DX2GSR1  | 0x0248 | W    | 0×00000000     | DATX8 2 General Status<br>Register 1      |
| DDR_PHYCTL_DX2DLLCR | 0x024c | W    | 0x40000000     | DATX8 2 DLL Control<br>Register           |
| DDR_PHYCTL_DX2DQTR  | 0x0250 | W    | 0xfffffff      | DATX8 2 DQ Timing<br>Register             |
| DDR_PHYCTL_DX2DQSTR | 0x0254 | W    | 0x3db55000     | DATX8 2 DQS Timing<br>Register            |
| DDR_PHYCTL_DX3GCR   | 0x0280 | W    | 0x00000681     | DATX8 3 General<br>Configuration Register |



| Name                | Offset  | Size | Reset<br>Value | Description            |
|---------------------|---------|------|----------------|------------------------|
| DDR PHYCTL DX3GSR0  | 0x0284  | ۱۸/  | 0×00000000     | DATX8 3 General Status |
| DDK_FITTCTE_DX3G3R0 | 0.00204 | VV   | 0x00000000     | Register 0             |
| DDR_PHYCTL_DX3GSR1  | 0x0288  | W    | 0x00000000     | DATX8 3 General Status |
| DDK_FITTCTL_DX3G3K1 |         |      |                | Register 1             |
| DDR PHYCTL DX3DLLCR | 0x028c  | W    | 0x40000000     | DATX8 3 DLL Control    |
| DDR_PHTCTL_DX3DLLCR |         |      |                | Register               |
| DDB DHYCTI DY3DOTB  | 0x0290  | ١٨/  | 0xfffffff      | DATX8 3 DQ Timing      |
| DDR_PHYCTL_DX3DQTR  | UXU290  | VV   | UXIIIIIIII     | Register               |
| DDD DUVCTI DV2DACTD | 0×0204  | ١٨/  | 0v3dbEE000     | DATX8 3 DQS Timing     |
| DDR_PHYCTL_DX3DQSTR | 0x0294  | W    | 0x3db55000     | Register               |

# 13.5.2 Detail Registers Description

## DDR\_PCTL\_SCFG

Address: Operational Base + offset (0x0000)

State Configuration Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 11:8  | RW   | 0×3         | The n_bbflags is a NIF output vector which provides combined information about the status of each memory bank. The de-assertion is based on whenprecharge, activates, reads/writesare scheduled by the TCU block. It may be possible to de-assert n_bbflags earlier than calculated by the TCU block. Programming bbflags_timing is used to achieve this. The maximum recommended value is:  PCTL_TCU_SED_P - TRP.t_rp. The programmed value is the maximum number of "early" cycles that n_bbflags maybe de-asserted. The actual achieved de-assertion depends on the traffic profile.  In 1:2 mode the maximum allowed programmable value is 4'b0111 In 1:1 mode the value can be 4'b1111 |
| 7:1   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |



| Attr | Reset Value      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Attr | Reset Value  0x0 | hw_low_power_en Enables the hardware low-power interface. Allows the system to request via hardware (c_sysreq input) to enter the memories into Self-Refresh. The handshaking between the request and acknowledge hardware low power signals (c_sysreq and c_sysack, respectively) is always performed, but the PCTL response depends on the value set on this register field and by the value driven on the c_active_in input pin. 1'b0 = Disabled. Requests are always denied and PCTL is unaffected by c_sysreq |
|      |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|      |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

# DDR\_PCTL\_SCTL

Address: Operational Base + offset (0x0004)

Operational State Control Register

| Bit  | Attr | Reset Value | Description                                    |
|------|------|-------------|------------------------------------------------|
| 31:3 | RO   | 0x0         | reserved                                       |
|      |      |             | state_cmd                                      |
|      |      | . ()        | Issues an operational state transition request |
|      |      | 1           | to the PCTL.                                   |
|      |      |             | 3'b000 = INIT (move to Init_mem from           |
|      |      |             | Config)                                        |
|      | 11   |             | 3'b001 = CFG (move to Config from Init_mem     |
| 2:0  | RW   | 0×0         | or Access)                                     |
|      |      |             | 3'b010 = GO (move to Access from Config)       |
|      |      |             | 3'b011 = SLEEP (move to Low_power from         |
|      | -    |             | Access)                                        |
|      |      |             | 3'b100 = WAKEUP (move to Access from           |
|      |      |             | Low_power)                                     |
|      |      |             | Others = Reserved                              |

# DDR\_PCTL\_STAT

Address: Operational Base + offset (0x0008)

Operational State Status Register

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



## DDR\_PCTL\_INTRSTAT

Address: Operational Base + offset (0x000c)

Interrupt Status Register

| Bit      | Attr | Reset Value                                   | Description                                |
|----------|------|-----------------------------------------------|--------------------------------------------|
| 31:2     | RO   | 0x0                                           | reserved                                   |
|          | ~    |                                               | parity_intr                                |
| <b>Y</b> |      |                                               | Indicates that a DFI parity error has been |
| 1        | RO   | 0x0                                           | detected                                   |
|          |      |                                               | 1'b0 = No error                            |
|          |      |                                               | 1'b1 = Parity error                        |
|          |      |                                               | ecc_intr                                   |
| 0 RO     | 0x0  | Indicates that an ECC error has been detected |                                            |
|          |      | 1'b0 = No error                               |                                            |
|          |      |                                               | 1'b1 = Parity error                        |

3'b111 = Low\_power\_exit\_req

Others = Reserved



Address: Operational Base + offset (0x0040) Memory Command Register

| Bit   | Attr  | Reset Value | Description                                     |
|-------|-------|-------------|-------------------------------------------------|
|       |       |             | start_cmd                                       |
|       |       |             | Start command. When this bit is set to 1, the   |
|       |       |             | command operation defined in the                |
|       |       |             | cmd_opcode field is started. This bit is        |
| 31    | R/WSC | 0x0         | automatically cleared by the PCTL after the     |
|       |       |             | command is finished. The application can poll   |
|       |       |             | this bit to determine when PCTL is ready to     |
|       |       |             | accept another command. This bit cannot be      |
|       |       |             | cleared to 1'b0 by software.                    |
| 30:28 | RO    | 0x0         | reserved                                        |
|       |       |             | cmd_add_del                                     |
|       |       |             | Set the additional delay associated with each   |
| 27:24 | RW    | 0x0         | command to 2^n internal timers clock            |
|       |       |             | cycles, where n is the bit field value. If n=0, |
|       |       |             | the delay is 0. Max value is n=10.              |
|       |       |             | rank_sel                                        |
|       |       |             | Rank select for the command to be executed.     |
|       |       |             | 4'b0001 = Rank 0                                |
|       |       |             | 4'b0010 = Rank 1                                |
|       |       |             | 4'b0100 = Rank 2                                |
|       |       |             | 4'b1000 = Rank 3                                |
|       |       |             | 4'b0000 = Reserved                              |
| 23:20 | RW    | 0x1         | Multiple 1'b1s in rank_sel mean multiple ranks  |
|       |       | AAY         | are selected, which is useful broadcasting      |
|       |       |             | commands in parallel to multiple ranks during   |
|       | A (   | ()          | initialization and configuration of the         |
|       |       | 7           | memories.                                       |
|       |       |             | If MCMD.cmd_opcode=RSTL, all ranks should       |
|       |       |             | be selected as it cannot be performed to        |
|       |       |             | individual ranks                                |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                         |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19:17 | RW   | 0×0         | bank_addr  Mode Register address driven on the memory bank address bits, BA1, BA0, during a Mode Register Set operation, defined by cmd_opcode=MRS. For other values of cmd_opcode, this field is ignored. 3'b000 = MR0 (MR in DDR2) 3'b001 = MR1 (EMR in DDR2) 3'b010 = MR2 (EMR(2) in DDR2) 3'b011 = MR3 (EMR(3) in DDR2) Others = Reserved                                       |
| 16:4  | RW   | 0×0000      | cmd_addr Mode Register value driven on the memory address bits, A12 to A0, during a Mode Register Set operation defined by cmd_opcode=MRS. For other values of cmd_opcode this field is ignored. Refer to the memory specification for the correct settings of the various bits of this field during a MRS operation. If LPDDR2, this fields is merged into bank_addr - lpddr2_addr |



|        |     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0 RW | 0×0 | cmd_opcode Command to be issued to the memory.  4'b000 = Deselect. This is only used for timing purposes, no actual direct Deselect command is passed to the memories.  4'b0001 = Precharge All (PREA)  4'b0010 = Refresh (REF)  4'b0011 = Mode Register Set (MRS) - is MRW in LPDDR2, MRS otherwise  4'b0100 = ZQ Calibration Short (ZQCS, only applies to LPDDR2/DDR3)  4'b0101 = ZQ Calibration Long (ZQCL, only applies to LPDDR2/DDR3)  4'b0101 = Software Driven Reset (RSTL, only applies to DDR3)  4'b0111 = Reserved  4'b1000 - Mode Register Read (MRR) - is MRR in LPDDR2, is SRR in mDRR and is MPR in DDR3  4'b1001 - Deep Power Down Entry (DPDE, only applies to mDDR/LPDDR2)  Others - Reserved |

# DDR\_PCTL\_POWCTL

Address: Operational Base + offset (0x0044)

Power Up Control Register

| Bit  | Attr  | Reset Value | Description                                    |
|------|-------|-------------|------------------------------------------------|
| 31:1 | RO    | 0x0         | reserved                                       |
|      | 11    |             | power_up_start                                 |
|      |       | ,           | Start the memory power up sequence.            |
|      |       |             | When this bit is set to 1'b1, PCTL starts the  |
| 0    | R/WSC | 0x0         | CKE and RESET# power up sequence to the        |
|      |       |             | memories. This bit is automatically cleared by |
|      |       |             | PCTL after the sequence is completed. This bit |
|      |       |             | cannot be cleared to 1'b0 by software.         |

## DDR\_PCTL\_POWSTAT

Address: Operational Base + offset (0x0048)

Power Up Status Register

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:1 | RO   | 0x0         | reserved    |



## DDR\_PCTL\_CMDTSTAT

Address: Operational Base + offset (0x004c)

Command Timers Status Register

| Bit  | Attr | Reset Value | Description                                           |
|------|------|-------------|-------------------------------------------------------|
| 31:1 | RO   | 0x0         | reserved                                              |
|      |      |             | cmd_tstat                                             |
|      |      |             | Returns the status of the timers for memory commands. |
| 0    | RO   | 0x0         | This ANDs all the command timers together.            |
|      |      |             | 1'b0 = One or more command timers has not expired.    |
|      |      |             | 1'b1 = All command timers have expired.               |

## DDR\_PCTL\_CMDTSTATEN

Address: Operational Base + offset (0x0050) Command Timers Status Enable Register

| Bit  | Attr   | Reset Value | Description                                  |
|------|--------|-------------|----------------------------------------------|
| 31:1 | RO     | 0x0         | reserved                                     |
|      |        |             | cmd_tstat_en                                 |
|      |        | 0x0         | Enables the generation of the status of the  |
|      | DW     |             | timers for memory commands.                  |
| U    | RW     |             | Is enabled before CMDTSTAT register is read. |
|      |        |             | 1'b0 - Disabled                              |
|      | $\cup$ |             | 1'b1 - Enabled                               |

## DDR\_PCTL\_MRRCFG0

Address: Operational Base + offset (0x0060)

Mode Register Read Configuration 0

| Bit  | Attr | Reset Value | Description                             |
|------|------|-------------|-----------------------------------------|
| 31:4 | RO   | 0x0         | reserved                                |
|      | RW   | 0×0         | mrr_byte_sel                            |
| 3:0  |      |             | Selects which byte's data to store when |
| 3:0  |      |             | performing an MRR command via MCMD.     |
|      |      |             | LegalValues: 0 8                        |



Address: Operational Base + offset (0x0064) Mode Register Read Status 0 Register

| Bit   | Attr | Reset Value | Description              | 1        |
|-------|------|-------------|--------------------------|----------|
| 31:24 | RO   | 0×00        | mrrstat_beat3            |          |
| 31.24 | KU   | UXUU        | MRR/MPR read data beat 3 |          |
| 22.16 | RO   | 0×00        | mrrstat_beat2            |          |
| 23:16 | RU   | UXUU        | MRR/MPR read data beat 2 |          |
| 1 5.0 | D.C. | 0×00        | mrrstat_beat1            | <u> </u> |
| 15:8  | RO   | UXUU        | MRR/MPR read data beat 1 |          |
| 7.0   | DO   | 0.400       | mrrstat_beat0            |          |
| 7:0   | RO   | 0x00        | MRR/MPR read data beat 0 |          |

## DDR\_PCTL\_MRRSTAT1

Address: Operational Base + offset (0x0068)

Mode Register Read Status 0 Register

| Bit     | Attr | Reset Value | Description              |
|---------|------|-------------|--------------------------|
| 31:24   | RO   | 0x00        | mrrstat_beat7            |
| 31.24   | KO   |             | MRR/MPR read data beat 7 |
| 22.16   | RO   | 0x00        | mrrstat_beat6            |
| 23:16   |      |             | MRR/MPR read data beat 6 |
| 1 . 0   | DO.  | 0 10x00     | mrrstat_beat5            |
| 15:8 RO | RO   |             | MRR/MPR read data beat 5 |
| 7:0     | RO   | 0x00        | mrrstat_beat4            |
|         |      |             | MRR/MPR read data beat 4 |

# DDR\_PCTL\_MCFG

Address: Operational Base + offset (0x0080)

Memory Configuration Register

| Bit   | Attr    | Reset Value | Description                                        |
|-------|---------|-------------|----------------------------------------------------|
|       |         |             | mddr_lpddr2_clock_stop_idle                        |
|       | .:24 RW | W 0x00      | Clock stop idle period in n_clk cycles. Memories   |
|       |         |             | are placed into clock stop mode if the NIF is idle |
| 21.24 |         |             | for mddr_lpddr2_clkstop_idle n_clk cycles. The     |
| 31.24 |         |             | automatic clock stop function is disabled when     |
|       |         |             | mddr_lpddr2_clkstop_idle=0.                        |
|       |         |             | Clock stop mode is only applicable in              |
|       |         |             | mDDR/LPDDR2.                                       |



| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23:22 | RW   | 0×0                | mddr_lpddr2_en mDDR/LPDDR2 Enable. Enables support for mDDR or LPDDR2. 2'b00 = mDDR/LPDDR2 Disabled 2'b10 = mDDR Enabled 2'b11 = LPDDR2 Enabled Others= Reserved.                                                                                                                                                                                                                                                                                                                                                                                 |
| 21:20 | RW   | 0×0                | mddr_lpddr2_bl mDDR/LPDDR2 Burst Length. The BL setting must be consistent with the value programmed into the BL field of MR.  2'b00 = BL2, Burst length of 2 (MR.BL=3'b001, mDDR only)  2'b01 = BL4, Burst length of 4 (MR.BL=3'b010, for mDDR and LPDDR2)  2'b10 = BL8, Burst length of 8 (MR.BL=3'b011, for mDDR and LPDDR2)  2'b11 = BL16, Burst length of 16 (MR.BL=3'b100, for mDDR and LPDDR2)  This value is effective only if MCFG.mddr_lpddr2_en[1]=1'b1. Otherwise, MCFG.mem_bl is used to define PCTL's Burst Length (for DDR2/DDR3). |
| 19:18 | RW   | 0×1                | tfaw_cfg Sets tFAW to be 4, 5 or 6 times tRRD. 2'b00 = set tFAW=4*tRRD 2'b01 = set tFAW=5*tRRD 2'b10 = set tFAW=6*tRRD                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 17    | RW   | 0×0                | pd_exit_mode Selects the mode for Power Down Exit. For DDR2/DDR3, the power down exit mode setting in PCTL must be consistent with the value programmed into the power down exit mode bit of MR0. For mDDR/LPDDR2, only fast exit mode is valid. 1'b0 = slow exit 1'b1 = fast exit                                                                                                                                                                                                                                                                |
| 16    | RW   | 0×0                | pd_type Sets the Power down type. 1'b0 = Precharge Power Down 1'b1 = Active Power Down                                                                                                                                                                                                                                                                                                                                                                                                                                                            |



| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                               |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8 | RW   | 0×00        | pd_idle Power-down idle period in n_clk cycles. Memories are placed into power-down mode if the NIF is idle for pd_idle n_clk cycles. The automatic power down function is disabled when pd_idle=0.                                                                                                                                       |
| 7    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                  |
| 6    | RW   | 0×0         | <pre>lpddr2_s4 Enables LPDDR2-S4 support. 1'b0 = LPDDR2-S4 disabled (LPDDR2-S2 enabled) 1'b1 = LPDDR2-S4 enabled</pre>                                                                                                                                                                                                                    |
| 5    | RW   | 0x1         | ddr3_en Select DDR2 or DDR3 protocol. Ignored, if mDDR or LPDDR2 support is enabled. 1'b0 = DDR2 Protocol Rules 1'b1 = DDR3 Protocol Rules                                                                                                                                                                                                |
| 4    | RW   | 0×0         | stagger_cs For multi-rank commands from the DCU, stagger the assertion of CS_N to odd and even ranks by one n_clk cycle. This is useful when using RDIMMs, when multi-rank commands may be interpreted as writes to control words in the register chip.  1'b0 = Do not stagger CS_N  1'b1 = Stagger CS_N                                  |
| 3    | RW   | 0×0         | two_t_en Enables 2T timing for memory commands. 1'b0= Disabled 1'b1 = Enabled                                                                                                                                                                                                                                                             |
| 2    | RW   | 0×0         | bl8int_en Setting this bit enables the BL8 interrupt function of DDR2. This is the capability to early terminate a BL8 after only 4 DDR beats by issuing the next command two cycles earlier. This functionality is only available for DDR2 memories and this setting is ignored for mDDR/LPDDR2 and DDR3. 1'b0 = Disabled 1'b1 = Enabled |



| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                 |
|-----|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | RW   | 0x0                | cke_or_en This bit is intended to be set for 4-rank RDIMMs, which have a 2-bit CKE input. If set, dfi_cke[0] is asserted to enable either of the even ranks (0 and 2), while dfi_cke[1] is asserted to enable either of the odd ranks (1 and 3). dfi_cke[3:2] are inactive (0) 1'b0: Disabled 1'b1: Enabled |
| 0   | RW   | 0×0                | mem_bl DDR Burst Length. The BL setting in DDR2 / DDR3 must be consistent with the value programmed into the BL field of MR0. 1'b0 = BL4, Burst length of 4 (MR0.BL=3'b010, DDR2 only) 1'b1 = BL8, Burst length of 8 (MR0.BL=3'b011 for DDR2, MR0.BL=2'b00 for DDR3)                                        |

### DDR\_PCTL\_PPCFG

Address: Operational Base + offset (0x0084)
Partially Populated Memories Configuration Register

| raitiany | ropuie | iteu Memories  | Configuration Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------|--------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit      | Attr   | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 31:9     | RO     | 0x0            | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 8:1      | RW     | 0×00           | rpmem_dis Reduced Population Disable bits. Setting these bits disables the corresponding NIF/DDR data lanes from writing or reading data. Lane 0 is always present, hence only 8 bits are required for the remaining lanes including the ECC lane. In 1:2 mode bit 0 of rpmem_dis covers n_wdata/n_rdata/m_ctl_d/m_phy_q[63:32], bit 1 [95:64] etc. In 1:1 mode bit 0 of rpmem_dis covers n_wdata/n_rdata/m_ctl_d/m_phy_q[31:16], bit 2 [47:32] etc. There are no restrictions on which byte lanes can be disabled, other than byte lane 0 is required. Gaps between enabled byte lanes are allowed For each bit: 1'b0 = lane exists 1'b1 = lane is disabled |



| Bit | Attr | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                         |
|-----|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | RW   | 0x0            | ppmem_en Partially Population Enable bit. Setting this bit enables the partial population of external memories where the entire application bus is routed to a reduced size memory system. The lower half of the SDRAM data bus, bit 0 up to bit PCTL_M_DW/2-1, is the active portion when Partially Populated memories are enabled. 1'b0 = Disabled 1'b1 = Enabled |

# DDR\_PCTL\_MSTAT

Address: Operational Base + offset (0x0088)

Memory Status Register

| Bit  | Attr | Reset Value | Description                                   |
|------|------|-------------|-----------------------------------------------|
| 31:3 | RO   | 0x0         | reserved                                      |
|      |      |             | self_refresh                                  |
|      |      |             | Indicates if PCTL, through auto self refresh, |
| 2    | RO   | 0x0         | has placed the memories in Self Refresh.      |
|      |      |             | 1'b0 = Memory is not in Self Refresh          |
|      |      |             | 1'b1 = Memory is in Self Refresh              |
|      |      |             | clock_stop                                    |
|      |      |             | Indicates if PCTL has placed the memories in  |
| 1    | RO   | 0x0         | Clock Stop.                                   |
|      |      |             | 1'b0 = Memory is not in Clock Stop            |
|      |      |             | 1'b1 = Memory is in Clock Stop                |
|      |      |             | power_down                                    |
|      | 1    |             | Indicates if PCTL has placed the memories in  |
| 0    | RO   | 0x0         | Power Down.                                   |
|      |      |             | 1'b0 = Memory is not in Power Down            |
|      |      |             | 1'b1 = Memory is in Power-Down                |

### DDR\_PCTL\_LPDDR2ZQCFG

Address: Operational Base + offset (0x008c)

LPDDR2 ZQ Configuration Register

| Bit Att | r Reset Value | Description |
|---------|---------------|-------------|
|---------|---------------|-------------|



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | RW   | 0xab        | zqcl_op Value to drive on memory address bits [19:12] for an automatic hardware generated ZQCL command (LPDDR2). Corresponds to OP7 OP0 of Mode Register Write (MRW) command which is used to send ZQCL command to memory. |
| 23:16 | RW   | 0x0a        | zqcl_ma Value to drive on memory address bits [11:4] for an automatic hardware generated ZQCL command (LPDDR2). Corresponds to MA7 MA0 of Mode Register Write (MRW) command which is used to send ZQCL command to memory.  |
| 15:8  | RW   | 0x56        | zqcs_op Value to drive on memory address bits [19:12] for an automatic hardware generated ZQCS command (LPDDR2). Corresponds to OP7 OP0 of Mode Register Write (MRW) command which is used to send ZQCS command to memory. |
| 7:0   | RW   | 0x0a        | zqcs_ma Value to drive on memory address bits [11:4] for an automatic hardware generated ZQCS command (LPDDR2). Corresponds to MA7 MA0 of Mode Register Write (MRW) command which is used to send ZQCS command to memory.  |

# DDR\_PCTL\_MCFG1

Address: Operational Base + offset (0x0090)

Memory Configuration 1 Register

| Bit      | Attr | Reset Value | Description                                  |
|----------|------|-------------|----------------------------------------------|
| <b>*</b> |      |             | hw_exit_idle_en                              |
|          |      |             | When this bit is programmed to 1'b1 the      |
| 31       | RW   | 0x0         | c_active_in pin can be used to exit from the |
|          |      |             | automatic clock stop , power down or         |
|          |      |             | self-refresh modes.                          |
| 30:24    | RO   | 0x0         | reserved                                     |



| Bit   | Attr | Reset Value         | Description                                        |
|-------|------|---------------------|----------------------------------------------------|
|       |      |                     | hw_idle                                            |
|       |      |                     | Hardware idle period. The c_active output is       |
| 23:16 | RW   | 0×00<br>0×0<br>0×00 | driven high if the NIF is idle in Access state for |
|       |      |                     | hw_idle * 32 * n_clk cycles. The hardware idle     |
|       |      |                     | function is disabled when hw_idle=0.               |
| 15:8  | RO   | 0x0                 | reserved                                           |
|       |      |                     | sr_idle                                            |
|       |      | RW 0×00             | Self Refresh idle period. Memories are placed      |
| 7:0   | RW 0 |                     | into Self-Refresh mode if the NIF is idle in       |
| 7.0   |      |                     | Access state for sr_idle * 32 * n_clk cycles.      |
|       |      |                     | The automatic self refresh function is disabled    |
|       |      |                     | when sr_idle=0.                                    |

### DDR\_PCTL\_DTUPDES

Address: Operational Base + offset (0x0094)

DTU Status Register

|    |                | D. C. Marillani                                                                                                                                                      |
|----|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    | Reset Value    | Description                                                                                                                                                          |
| RO | 0x0            | reserved                                                                                                                                                             |
|    |                | dtu_rd_missing                                                                                                                                                       |
| RO | 0x0            | Indicates if one or more read beats of data did                                                                                                                      |
|    |                | not return from memory.                                                                                                                                              |
|    |                | dtu_eaffl                                                                                                                                                            |
| PO | 0×0            | Indicates the number of entries in the FIFO                                                                                                                          |
| KO | OXO .          | that is holding the log of error                                                                                                                                     |
|    | • 1            | addresses for data comparison                                                                                                                                        |
|    |                | dtu_random_error                                                                                                                                                     |
| PΩ | 0×0            | Indicates that the random data generated had                                                                                                                         |
| KU | OXO            | some failures when written                                                                                                                                           |
| 1  |                | and read to the memories                                                                                                                                             |
|    | 7              | dtu_err_b7                                                                                                                                                           |
| RO | 0x0            | Detected at least 1 bit error for bit 7 in the                                                                                                                       |
|    |                | programmable data buffers                                                                                                                                            |
| 1  |                | dtu_err_b6                                                                                                                                                           |
| RO | 0x0            | Detected at least 1 bit error for bit 6 in the                                                                                                                       |
|    |                | programmable data buffers                                                                                                                                            |
|    |                | dtu_err_b5                                                                                                                                                           |
| RO | 0x0            | Detected at least 1 bit error for bit 5 in the                                                                                                                       |
|    |                | programmable data buffers                                                                                                                                            |
|    |                | dtu_err_b4                                                                                                                                                           |
| RO | 0x0            | Detected at least 1 bit error for bit 4 in the                                                                                                                       |
|    |                | programmable data buffers                                                                                                                                            |
|    | RO RO RO RO RO | RO         0x0           RO         0x0           RO         0x0           RO         0x0           RO         0x0           RO         0x0           RO         0x0 |



| Bit | Attr | Reset Value | Description                                    |
|-----|------|-------------|------------------------------------------------|
|     |      |             | dtu_err_b3                                     |
| 3   | RO   | 0x0         | Detected at least 1 bit error for bit 3 in the |
|     |      |             | programmable data buffers                      |
|     |      |             | dtu_err_b2                                     |
| 2   | RO   | 0x0         | Detected at least 1 bit error for bit 2 in the |
|     |      |             | programmable data buffers                      |
|     |      |             | dtu_err_b1                                     |
| 1   | RO   | 0x0         | Detected at least 1 bit error for bit 1 in the |
|     |      |             | programmable data buffers                      |
|     |      |             | dtu_err_b0                                     |
| 0   | RO   | 0x0         | Detected at least 1 bit error for bit 0 in the |
|     |      |             | programmable data buffers                      |

### DDR\_PCTL\_DTUNA

Address: Operational Base + offset (0x0098)DTU Number of Addresses Created Register

| Bit  | Attr | Reset Value | Description                                                                                                             |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0×0000000   | dtu_num_address Indicates the number of addresses that were created on the NIF interface during random data generation. |

### DDR\_PCTL\_DTUNE

Address: Operational Base + offset (0x009c)

DTU Number of Errors Register

| Bit  | Attr       | Reset Value          | Description                              |
|------|------------|----------------------|------------------------------------------|
|      |            |                      | dtu_num_errors                           |
| 31:0 | 0×00000000 | 0,000,000            | Indicates the number of errors that were |
| 31.0 | KU         | 0x $0$ 00000000 $-1$ | detected on the readback of the NIF data |
|      |            | Y                    | during random data generation.           |

### DDR PCTL DTUPRDO

Address: Operational Base + offset (0x00a0)

DTU Parallel Read 0 Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                   |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   |             | dtu_allbits_1 Allows all the bit ones from each of the 16 received read bytes to be read in parallel. Used as part of read data eye training where a transition is required to be monitored to train the eye. |



| Bit  | Attr | Reset Value | Description                                                                                                                                                                                           |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0 | RO   | 0x0000      | dtu_allbits_0 Allows all the bit zeros from each of the 16 received read bytes to be read in parallel. Used as part of read data eye training where a transition is required to be monitored to train |
|      |      |             | the eye.                                                                                                                                                                                              |

# DDR\_PCTL\_DTUPRD1

Address: Operational Base + offset (0x00a4)

DTU Parallel Read 1 Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                     |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0×0000      | dtu_allbits_3 Allows all the bit threes from each of the 16 received read bytes to be read in parallel. Used as part of read data eye training where a transition is required to be monitored to train the eye. |
| 15:0  | RO   | 0×0000      | dtu_allbits_2 Allows all the bit twos from each of the 16 received read bytes to be read in parallel. Used as part of read data eye training where a transition is required to be monitored to train the eye.   |

# DDR\_PCTL\_DTUPRD2

Address: Operational Base + offset (0x00a8)

DTU Parallel Read 2 Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                    |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0×0000      | dtu_allbits_5 Allows all the bit fives from each of the 16 received read bytes to be read in parallel. Used as part of read data eye training where a transition is required to be monitored to train the eye. |
| 15:0  | RO   | 0x0000      | dtu_allbits_4 Allows all the bit fours from each of the 16 received read bytes to be read in parallel. Used as part of read data eye training where a transition is required to be monitored to train the eye. |

## DDR\_PCTL\_DTUPRD3



Address: Operational Base + offset (0x00ac)

DTU Parallel Read 3 Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                     |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0000      | dtu_allbits_7 Allows all the bit sevens from each of the 16 received read bytes to be read in parallel. Used as part of read data eye training where a transition is required to be monitored to train the eye. |
| 15:0  | RO   | 0×0000      | dtu_allbits_6 Allows all the bit sixes from each of the 16 received read bytes to be read in parallel. Used as part of read data eye training where a transition is required to be monitored to train the eye.  |

# DDR\_PCTL\_DTUAWDT

Address: Operational Base + offset (0x00b0)

DTU Address Width Register

|       | 233 111 | ath Register |                                                                                                                                          |
|-------|---------|--------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit   | Attr    | Reset Value  | Description                                                                                                                              |
| 31:11 | RO      | 0x0          | reserved                                                                                                                                 |
| 10:9  | RW      | 0x1          | number_ranks Number of supported memory ranks. 2'b00 = 1 rank 2'b01 = 2 ranks 2'b10 = 3 ranks                                            |
| 8     | RO      | 0x0          | 2'b11 = 4 ranks<br>reserved                                                                                                              |
|       | RW      | 0x2          | row_addr_width Width of the memory row address bits. 2'b00 = 13 bits wide 2'b01 = 14 bits wide 2'b10 = 15 bits wide 2'b11 = 16 bits wide |
| 5     | RO      | 0x0          | reserved                                                                                                                                 |
| 4:3   | RW      | 0x2          | bank_addr_width Width of the memory bank address bits. 2'b00 = 2 bits wide (4 banks) 2'b01 = 3 bits wide (8 banks) Others = Reserved     |
| 2     | RO      | 0x0          | reserved                                                                                                                                 |



| Bit | Attr | Reset Value | Description                              |
|-----|------|-------------|------------------------------------------|
|     | RW   | 0x0         | column_addr_width                        |
|     |      |             | Width of the memory column address bits. |
| 1.0 |      |             | 2'b00 = 7 bits wide                      |
| 1:0 |      |             | 2'b01 = 8 bits wide                      |
|     |      |             | 2'b10 = 9 bits wide                      |
|     |      |             | 2'b11 = 10 bits wide                     |

## DDR\_PCTL\_TOGCNT1U

Address: Operational Base + offset (0x00c0)

Toggle Counter 1us Register

| Bit   | Attr | Reset Value | Description                                |
|-------|------|-------------|--------------------------------------------|
| 31:10 | RO   | 0x0         | reserved                                   |
| 9:0   | RW   | 0x064       | toggle_counter_1u                          |
| 9.0   | KVV  | 0004        | The number of internal timers clock cycles |

### DDR\_PCTL\_TINIT

Address: Operational Base + offset (0x00c4)

t init Timing Register

| Bit  | Attr | Reset Value | Description                                     |
|------|------|-------------|-------------------------------------------------|
| 31:9 | RO   | 0x0         | reserved                                        |
|      |      |             | t_init                                          |
|      |      |             | Defines the time period (in us) to hold dfi_cke |
|      |      |             | and dfi_reset_n stable during the memory        |
| 8:0  | RW   | 0x0c8       | power up sequence. The value programmed         |
|      |      | • 0         | must correspond to at least 200us. The actual   |
|      |      |             | time period defined is TINIT * TOGCNT1U *       |
|      |      |             | internal timers clock .period                   |

#### DDR\_PCTL\_TRSTH

Address: Operational Base + offset (0x00c8)

t rsth Timina Register

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:10 | RO   | 0x0         | reserved    |

| Bit | Attr | Reset Value | Description                                                                                                                                                                         |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:0 | RW   | 0x000       | t_rsth Defines the time period (in us) to hold the dfi_reset_n signal high after it is de-asserted during the DDR3 Power Up/Reset sequence. The value programmed for DDR3 must      |
|     |      |             | correspond to minimum 500us of delay. For mDDR and DDR2, this register should be programmed to 0.The actual time period defined is TRSTH * TOGCNT1U * internal timers clock period. |

## DDR\_PCTL\_TOGCNT100N

Address: Operational Base + offset (0x00cc)

Toggle Counter 100ns

| Bit  | Attr | Reset Value | Description                                 |
|------|------|-------------|---------------------------------------------|
| 31:7 | RO   | 0x0         | reserved                                    |
| C.O  | RW   | 0×01        | toggle_counter_100n                         |
| 6:0  | KVV  | UXUI        | The number of internal timers clock cycles. |

### DDR\_PCTL\_TREFI

Address: Operational Base + offset (0x00d0)

t\_refi Timing Register

| Bit  | Attr | Reset Value | Description                                     |
|------|------|-------------|-------------------------------------------------|
| 31:8 | RO   | 0x0         | reserved                                        |
|      |      | • 0         | t_refi                                          |
|      |      |             | Defines the time period (in 100ns units) of the |
| 7:0  | RW   | 0x01        | Refresh interval.                               |
|      |      |             | The actual time period defined is TREFI *       |
|      |      |             | TOGCNT100N * internal timers clock period.      |

# DDR\_PCTL\_TMRD

Address: Operational Base + offset (0x00d4)

t\_mrd Timing Register

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:3 | RO   | 0x0         | reserved    |



| Bit | Attr | Reset Value | Description                               |
|-----|------|-------------|-------------------------------------------|
|     |      |             | t_mrd                                     |
|     |      |             | Mode Register Set command cycle time in   |
|     |      |             | memory clock cycles.                      |
|     |      | 0x1         | mDDR: Time from MRS to any valid command. |
|     | RW   |             | LPDDR2: Time from MRS (MRW) to any valid  |
| 2:0 |      |             | command.                                  |
| 2.0 |      |             | DDR2: Time from MRS to any valid command. |
|     |      |             | DDR3: Time from MRS to MRS command.       |
|     |      |             | mDDR Legal Values: 2                      |
|     |      |             | LPDDR2 Legal Values: 5                    |
|     |      |             | DDR2 Legal Values: 23                     |
|     |      |             | DDR3 Legal Values: 24                     |

# DDR\_PCTL\_TRFC

Address: Operational Base + offset (0x00d8)

| Bit  | Attr | Reset Value | Description                               |
|------|------|-------------|-------------------------------------------|
| 31:9 | RO   | 0x0         | reserved                                  |
|      |      |             | t_rfc                                     |
|      |      |             | Refresh to Active/Refresh command time in |
|      |      |             | memory clock cycles.                      |
| 8:0  | RW   | 0x001       | mDDR Legal Values: 728                    |
|      |      |             | LPDDR2 Legal Values: 15112                |
|      |      |             | DDR2 Legal Values: 15131                  |
|      |      | . ()        | DDR3 Legal Values: 36 374                 |

## DDR\_PCTL\_TRP

Address: Operational Base + offset (0x00dc)

t\_trp Timing Register

| Bit   | Attr   | Reset Value | Description                                    |
|-------|--------|-------------|------------------------------------------------|
| 31:18 | RO     | 0x0         | reserved                                       |
| 0     | $\cup$ |             | prea_extra                                     |
|       | Y      |             | Additional cycles required for a Precharge All |
| 7     |        |             | (PREA) command - in addition to t_rp. In       |
|       | RW     | 0×1         | terms of memory clock cycles                   |
| 17:16 |        |             | mDDR Value: 0                                  |
| 17.10 |        |             | LPDDR2 Value: Value that corresponds (tRPab    |
|       |        |             | -tRPpb). Rounded up in terms of memory         |
|       |        |             | clock cycles. Values can be 0, 1, 2.           |
|       |        |             | DDR2 Value: 1 if 8 Banks, 0 otherwise          |
|       |        |             | DDR3 Value: 0                                  |
| 15:4  | RO     | 0x0         | reserved                                       |



| Bit | Attr | Reset Value | Description                                                                                                                                                                        |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0 | RW   | 0x6         | t_rp Precharge period in memory clock cycles. For LPDDR2, this should be set to TRPpb. mDDR Legal Values: 23 LPDDR2 Legal Values: 313 DDR2 Legal Values: 37 DDR3 Legal Values: 514 |

### DDR\_PCTL\_TRTW

Address: Operational Base + offset (0x00e0)

t\_rtw Timing Register

| Bit  | Attr | Reset Value | Description                             |
|------|------|-------------|-----------------------------------------|
| 31:4 | RO   | 0x0         | reserved                                |
|      |      |             | t_rtw                                   |
|      |      |             | Read to Write turnaround time in memory |
|      |      |             | clock cycles.                           |
| 3:0  | RW   | 0x2         | mDDR Legal Values: 311                  |
|      |      |             | LPDDR2 Legal Values: 111                |
|      |      |             | DDR2 Legal Values: 210                  |
|      |      |             | DDR3 Legal Values: 210                  |

## DDR\_PCTL\_TAL

Address: Operational Base + offset (0x00e4)

AL Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3:0  | RW   | 0×0         | t_al Additive Latency in memory clock cycles. For DDR2 this must match the value programmed into the AL field of MR1. For DDR3 this must be 0, CL-1, CL-2 depending weather the AL value in MR1 is 0,1, or 2 respectively. CL is the CAS latency programmed into MR0. For mDDR and LPDDR2, there is no AL field in the mode registers, and this setting should be set to 0 mDDR Legal Values: 0 LPDDR2 Legal Values: 0 DDR2 Legal Values: AL DDR3 Legal Values: 0, CL-1, CL-2 (depending on AL=0,1,2 in MR1) |



Address: Operational Base + offset (0x00e8)

CL Timing Register

| Bit  | Attr   | Reset Value | Description                                  |
|------|--------|-------------|----------------------------------------------|
| 31:4 | RO     | 0x0         | reserved                                     |
|      |        |             | t_cl                                         |
|      |        |             | CAS Latency in memory clock cycles.          |
|      |        | 0x4         | If mDDR/DDR2/DDR3, the PCTL setting must     |
|      | RW     |             | match the value programmed into the CL field |
| 3:0  |        |             | of MR0.                                      |
|      | IX V V |             | If LPDDR2, the PCTL setting must match RL    |
|      |        |             | (ReadLatency), where RL is the value         |
|      |        |             | programmed into the "RL & W" field of MR2    |
|      |        |             | mDDR/DDR2/3 Legal Value: CL                  |
|      |        |             | LPDDR2 Legal Value: RL                       |

## DDR\_PCTL\_TCWL

Address: Operational Base + offset (0x00ec)

CWL Timing Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 3:0  | RW   | 0x3         | t_cwl CAS Write Latency in memory clock cycles. For mDDR, the setting must be 1. For LPDDR2 the setting must match WL (Write Latency), where WL is the value programmed into the "RL & WL" field of MR2. For DDR2 the setting must match CL-1, where CL is the value programmed into the CL field of MR0. For DDR3, the setting must match the value programmed in the memory CWL field of MR2. mDDR Legal Value: 1 LPDDR2 Legal Values: WL DDR2 Legal Value: CL-1 DDR3 Legal Value: CWL |

### DDR\_PCTL\_TRAS

Address: Operational Base + offset (0x00f0)

t\_ras Timing Register

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:6 | RO   | 0x0         | reserved    |



| Bit | Attr | Reset Value | Description                                 |
|-----|------|-------------|---------------------------------------------|
|     |      |             | t_ras Activate to Precharge command time in |
|     |      |             | memory clock cycles.                        |
| 5:0 | RW   | 0x10        | mDDR Legal Values: 48                       |
|     |      |             | LPDDR2 Legal Values: 723                    |
|     |      |             | DDR2 Legal Values: 824                      |
|     |      |             | DDR3 Legal Values: 1538                     |

### DDR\_PCTL\_TRC

Address: Operational Base + offset (0x00f4)

t\_rc Timing Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                 |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | RO   | 0x0         | reserved                                                                                                                                                                                                                    |
| 5:0  | RW   | 0×16        | t_rc Row Cycle time in memory clock cycles. Specifies the minimum Activate to Activate distance for accesses to same bank. mDDR Legal Values: 511 LPDDR2 Legal Values: 1036 DDR2 Legal Values: 1131 DDR3 Legal Values: 2052 |

# DDR\_PCTL\_TRCD

Address: Operational Base + offset (0x00f8)

t rcd Timing Register

| Bit   | Attr | Reset Value | Description                                 |
|-------|------|-------------|---------------------------------------------|
| 31:4  | RO   | 0x0         | reserved                                    |
|       |      |             | t_rcd                                       |
|       | RW   | 0×6         | Row to Column delay in memory clock cycles. |
| 3:0 F |      |             | Specifies the minimum Activate to Column    |
|       |      |             | distance.                                   |
|       | KVV  |             | mDDR Legal Values: 23                       |
|       | ~    |             | LPDDR2 Legal Values: 313                    |
|       |      |             | DDR2 Legal Values: 37                       |
|       |      |             | DDR3 Legal Values: 514                      |

### DDR\_PCTL\_TRRD

Address: Operational Base + offset (0x00fc)

t\_rrd Timing Register

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:4 | RO   | 0x0         | reserved    |



| Bit | Attr | Reset Value | Description                                    |
|-----|------|-------------|------------------------------------------------|
|     |      |             | t_rrd                                          |
|     |      |             | Row-to-Row delay in memory clock cycles.       |
|     |      |             | Specifies the minimum Activate-to-Activate     |
|     |      |             | distance for consecutive accesses to different |
| 3:0 | RW   | 0x4         | banks in the same rank.                        |
|     |      |             | mDDR Legal Values: 12                          |
|     |      |             | LPDDR2 Legal Values: 26                        |
|     |      |             | DDR2 Legal Values: 26                          |
|     |      |             | DDR3 Legal Values: 48                          |

### DDR\_PCTL\_TRTP

Address: Operational Base + offset (0x0100)

t rtp Timina Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                    |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | RO   | 0x0         | reserved                                                                                                                                                                                                                       |
| 3:0  | RW   | 0x3         | t_rtp Read to Precharge time in memory clock cycles. Specifies the minimum distance Read to Precharge for consecutive accesses to same bank. mDDR Value: 0 LPDDR2 Legal Values: 24 DDR2 Legal Values: 24 DDR3 Legal Values: 38 |

### DDR\_PCTL\_TWR

Address: Operational Base + offset (0x0104)

t\_wr Register

| Bit  | Attr   | Reset Value | Description                                     |
|------|--------|-------------|-------------------------------------------------|
| 31:5 | RO     | 0x0         | reserved                                        |
|      |        |             | t_wr                                            |
|      | $\cup$ |             | Write recovery time in memory clock cycles.     |
|      | 7      |             | When using close page the PCTL setting must     |
| 4:0  | RW     | 0x06        | be consistent with the WR field setting of MR0. |
| 4.0  |        |             | mDDR Legal Values: 23                           |
|      |        |             | LPDDR2 Legal Values: 38                         |
|      |        |             | DDR2 Legal Values: 38                           |
|      |        |             | DDR3 Legal Values: 616                          |

# DDR\_PCTL\_TWTR

Address: Operational Base + offset (0x0108)

t\_wtr Timing Register



| Bit  | Attr | Reset Value | Description                              |
|------|------|-------------|------------------------------------------|
| 31:4 | RO   | 0x0         | reserved                                 |
|      |      |             | t_wtr                                    |
|      |      |             | Write to Read turnaround time, in memory |
|      |      |             | clock cycles.                            |
| 3:0  | RW   | 0x4         | mDDR Legal Values: 12                    |
|      |      |             | LPDDR2 Legal Values: 24                  |
|      |      |             | DDR2 Legal Values: 24                    |
|      |      |             | DDR3 Legal Values: 38                    |

### DDR\_PCTL\_TEXSR

Address: Operational Base + offset (0x010c)

t exsr Timina Register

| t_exsr Timing Register |      |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------------------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 31:10                  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 9:0                    | RW   | 0x001       | t_exsr Exit Self Refresh to first valid command delay, in memory clock cycles. For mDDR, this should be programmed to match tXSR. For LPDDR2, this should be programmed to match tXSR. For DDR2, this should be programmed to match tXSR. For DDR2, this should be programmed to match tXSRD (SRE to read-related command) as defined by the memory devicespecification. For DDR3, this should be programmed to match tXSDLL (SRE to a command requiring DLL locked) as defined by the memory device specification. mDDR Legal Values: 1740 LPDDR2 Legal Values: 17117 DDR2 Typical Value: 200 DDR3 Typical Value: 512 |

## DDR\_PCTL\_TXP

Address: Operational Base + offset (0x0110)

t\_xp Timing Register

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:3 | RO   | 0x0         | reserved    |



| Bit | Attr | Reset Value | Description                                          |
|-----|------|-------------|------------------------------------------------------|
|     |      |             | t_xp<br>Exit Power Down to first valid command delay |
| 2:0 | RW   | 0x1         | when DLL is on (fast exit), measured in              |
|     |      |             | memory clock cycles.                                 |
|     |      |             | Legal Values: 17                                     |

## DDR\_PCTL\_TXPDLL

Address: Operational Base + offset (0x0114)

t xpdll Timing Register

| Bit  | Attr | Reset Value | Description                                  |
|------|------|-------------|----------------------------------------------|
| 31:6 | RO   | 0x0         | reserved                                     |
|      |      | 0x00        | t_xpdll                                      |
|      | RW   |             | Exit Power Down to first valid command delay |
| 5:0  |      |             | when DLL is off (slow exit), measured in     |
| 5:0  |      |             | memory clock cycles.                         |
|      |      |             | mDDR/LPDDR2 Value: 0                         |
|      |      |             | DDR2/DDR3 Legal Values: 363                  |

## DDR\_PCTL\_TZQCS

Address: Operational Base + offset (0x0118)

t zacs Timing Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                 |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7 | RO   | 0x0         | reserved                                                                                                                                                                                                                                    |
| 6:0  | RW   | 0×00        | t_zqcs SDRAM ZQ Calibration Short period, in memory clock cycles. Should be programmed to match the tZQCS timing value as defined in the memory specification. mDDR Value: 0 LPDDR2 Legal Values: 1548 DDR2 Value: 0 DDR3 Typical Value: 64 |

# DDR\_PCTL\_TZQCSI

Address: Operational Base + offset (0x011c)

t zacsi Timing Register

|     |      | - 3         |             |
|-----|------|-------------|-------------|
|     |      | D 11/1      |             |
| Bit | Attr | Reset Value | Description |



| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                               |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0×00000000  | t_zqcsi SDRAM ZQCS interval, measured in Refresh interval units. The total time period defined is TZQCSI*TREFI * TOGCNT100N * internal timers clock period. Programming a value of 0 in t_zqcsi disables the auto-ZQCS functionality in PCTL. mDDR Value: 0 LPDDR2 Legal Values: 04294967295 DDR2 Value: 0 DDR3 Legal Values: 04294967295 |

# DDR\_PCTL\_TDQS

Address: Operational Base + offset (0x0120)

t das Timing Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                        |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                           |
| 2:0  | RW   | 0x1         | t_dqs Additional data turnaround time in memory clock cycles for accesses to different ranks. Used to increase the distance between column commands to different ranks, allowing more tolerance as the driver source changes on the bidirectional DQS and/or DQ signals. mDDR Legal Values: 17 LPDDR2 Legal Values: 17 DDR2 Legal Values: 17 DDR3 Legal Values: 17 |

### DDR\_PCTL\_TCKSRE

Address: Operational Base + offset (0x0124)

t\_cksre Timing Register

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:5 | RO   | 0x0         | reserved    |



| Attr | Reset Value       | Description                                                                                                                                                                                                                                                                                          |
|------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RW   | Reset Value  0x00 | t_cksre In DDR3, this is the time after Self Refresh Entry that CKE is held high before going low. In memory clock cycles. Specifies the clock disable delay after SRE. This should be programmed to match the greatest value between 10ns and 5 memory clock periods. mDDR Value: 0 LPDDR2 Value: 0 |
|      |                   | DDR2 Value: 0<br>DDR3 Legal Values: 515                                                                                                                                                                                                                                                              |
|      |                   |                                                                                                                                                                                                                                                                                                      |

# DDR\_PCTL\_TCKSRX

Address: Operational Base + offset (0x0128)

t cksrx Timing Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                        |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                           |
| 4:0  | RW   | 0×00        | t_cksrx In DDR3, this is the time (before Self Refresh Exit) that CKE is maintained high before issuing SRX. In memory clock cycles. Specifies the clock stable time before SRX. This should be programmed to match the greatest value between 10ns and 5 memory clock periods. mDDR Value: 0 LPDDR2 Value: 0 DDR2 Value: 0 DDR3 Legal Values: 515 |

### DDR\_PCTL\_TCKE

Address: Operational Base + offset (0x012c)

t\_cke Timing Register

| Bit  | Attr | Reset Value | Description                             |
|------|------|-------------|-----------------------------------------|
| 31:3 | RO   | 0x0         | reserved                                |
|      |      |             | t_cke                                   |
|      |      |             | CKE minimum pulse width in memory clock |
|      |      |             | cycles.                                 |
| 2:0  | RW   | 0x3         | mDDR Legal Value: 2                     |
|      |      |             | LPDDR2 Legal Values: 3                  |
|      |      |             | DDR2 Legal Value: 3                     |
|      |      |             | DDR3 Legal Values: 36                   |



DDR\_PCTL\_TMOD

Address: Operational Base + offset (0x0130)

t mod Timing Register

| Bit  | Attr   | Reset Value | Description                                |
|------|--------|-------------|--------------------------------------------|
| 31:5 | RO     | 0x0         | reserved                                   |
|      |        |             | t_mod                                      |
|      |        |             | In DDR3 mode, this is the time from MRS to |
|      |        | V 0x00      | any valid non-MRS command (except          |
| 4.0  | 4:0 RW |             | DESELECT or NOP) in memory clock cycles.   |
| 4:0  |        |             | mDDR Value: 0                              |
|      |        |             | LPDDR2 Value: 0                            |
|      |        |             | DDR2 Value: 0                              |
|      |        |             | DDR3 Legal Values: 031                     |

### DDR\_PCTL\_TRSTL

Address: Operational Base + offset (0x0134)

Reset Low Timing Register

| Bit  | Attr | Reset Value | Description                              |
|------|------|-------------|------------------------------------------|
| 31:7 | RO   | 0x0         | reserved                                 |
|      |      |             | t_rstl                                   |
|      |      |             | Memory Reset Low time, in memory clock   |
|      |      |             | cycles. Defines the time period to hold  |
|      |      |             | dfi_reset_n signal low during a software |
|      |      |             | driven DDR3 Reset Operation. The value   |
| 6:0  | RW   | 0x00        | programmed must correspond to at least   |
|      |      |             | 100ns of delay.                          |
|      |      | * \         | mDDR Value: 0                            |
|      |      | 107         | LPDDR2 Value: 0                          |
|      |      |             | DDR2 Value: 0                            |
|      |      | . ( ) 7     | DDR3 Legal Values: 1127                  |

# DDR\_PCTL\_TZQCL

Address: Operational Base + offset (0x0138)

t zacl Timing Register

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:10 | RO   | 0x0         | reserved    |



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:0 | RW   | 0x000       | t_zqcl SDRAM ZQ Calibration Long period in memory clock cycles. If LPDDR2, should be programmed to tZQCL. If DDR3, should be programmed to match the memory tZQinit timing value for the first ZQCL command during memory initialization; should be programmed to match tZQoper timing value after reset and initialization. mDDR Value: 0 LPDDR2 Legal Values: 60192 DDR2 Value: 0 DDR3 Legal Values: 01023 |

# DDR\_PCTL\_TMRR

Address: Operational Base + offset (0x013c)

t\_mrr Timing Register

| Bit  | Attr | Reset Value | Description                                 |
|------|------|-------------|---------------------------------------------|
| 31:8 | RO   | 0x0         | reserved                                    |
| 7:0  | RW   | 0x02        | t_mrr<br>Time for a Mode Register Read (MRR |
|      |      |             | command from MCMD).                         |

## DDR\_PCTL\_TCKESR

Address: Operational Base + offset (0x0140)

t\_ckesr Timing Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                    |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                       |
| 31:4 | RO   | 0x0<br>0x4  | reserved  t_ckesr  Minimum CKE low width for Self Refresh entry to exit timing in memory clock cycles.  Recommended settings: - mDDR: t_ckesr = 0 - LPDDR2: t_ckesr = tCKESR setting from memories, rounded up in terms of memory cycles DDR2: t_ckesr = 0 - DDR3: t_ckesr = t_cke + 1     mDDR Value: 0 LPDDR2 Legal Values: 38 DDR2 Value: 0 |
|      |      |             | DDR3 Legal Values: 47                                                                                                                                                                                                                                                                                                                          |



# DDR\_PCTL\_TDPD

Address: Operational Base + offset (0x0144)

t dpd Timina Register

| Bit     | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 F | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 9:0     | RW   | 0×000       | t_dpd Minimum Deep Power Down time. Is in terms of us. When a MCMD.DPDE command occurs, TDPD time is waited before MCMD.start_cmd can be cleared. MCMD_cmd_add_del (if any) does not start until TDPD has completed. This ensures TDPD requirement for the memory is not violated. The actual time period defined is TDPD* TOGCNT1U * internal timers clock period. Only applies for mDDR and LPDDR2 as Deep Power Down (DPD) is only valid for these memory types. For mDDR, tDPD=0, while for LPDDR2, tDPD=500 us. For LPDDR2, if 500 us is waited externally by system, then set tDPD=0.  mDDR Value: 0 LPDDR2 Legal Values: 0 or 500 DDR2 Legal Values: 0 DDR3 Legal Values: 0 |

# DDR\_PCTL\_DTUWACTL

Address: Operational Base + offset (0x0200)

DTU Write Address Control

| Bit      | Attr | Reset Value | Description                                   |
|----------|------|-------------|-----------------------------------------------|
| 31:30    | DW   | 0x0         | dtu_wr_rank                                   |
| 31.30    | RW   |             | Write rank to where data is to be targeted    |
| 29       | RO   | 0x0         | reserved                                      |
| 28:13    | RW   | 0x0000      | dtu_wr_row                                    |
| 20.13    |      |             | Write row to where data is to be targeted     |
| 12:10 RV | DW   | ₹W 1()Y() 1 | dtu_wr_bank                                   |
|          | KVV  |             | Write bank to where data is to be targeted    |
| 9:0      | RW   | 0x000       | dtu_wr_col                                    |
|          |      |             | FWrite column to where data is to be targeted |



# DDR\_PCTL\_DTURACTL

Address: Operational Base + offset (0x0204)

DTU Read Address Control Register

| Bit   | Attr | Reset Value | Description                       |
|-------|------|-------------|-----------------------------------|
| 31:30 | RW   | 0×0         | dtu_rd_rank                       |
| 31.30 | KVV  | UXU         | Read rank from where data comes   |
| 29    | RO   | 0x0         | reserved                          |
| 28:13 | RW   | 0x0000      | dtu_rd_row                        |
| 26:13 |      |             | Read row from where data comes    |
| 12:10 | RW   | NW 00       | dtu_rd_bank                       |
| 12:10 | KVV  | 0x0         | Read bank from where data comes   |
| 9:0   | RW   | DW 0000     | dtu_rd_col                        |
|       |      | RW 0x000    | Read column from where data comes |

# DDR\_PCTL\_DTUCFG

Address: Operational Base + offset (0x0208)

DTU Configuration Control Register

| Bit   | Attr   | <b>Reset Value</b> | Description                                    |
|-------|--------|--------------------|------------------------------------------------|
| 31:23 | RO     | 0x0                | reserved                                       |
|       |        |                    | dtu_row_increments                             |
| 22:16 | RW     | 0×00               | Number of times to increment the row address   |
| 22.10 | IX V V | 0.000              | when generating random data, up to a           |
|       |        |                    | maximum of 127 times.                          |
|       |        |                    | dtu_wr_multi_rd                                |
| 15    | RW     | 0x0                | When set puts the DTU into write once multiple |
|       |        |                    | reads mode.                                    |
|       |        | 1                  | dtu_data_mask_en                               |
|       |        | V A                | Controls whether random generated data         |
| 14    | RW     | 0x0                | masks are transmitted. Unless enabled all data |
|       | A 1    |                    | bytes are written to memory and expected to    |
|       |        | 7                  | be read from memory.                           |
|       |        |                    | dtu_target_lane                                |
| 13:10 | RW     | 0×0                | Selects one of the byte lanes for data         |
| 13.10 | /      | 0.00               | comparison into the programmable read data     |
|       |        |                    | buffer.                                        |
|       |        |                    | dtu_generate_random                            |
| 9     | RW     | 0×0                | Generate transfers using random data,          |
|       | IXVV   | 0.00               | otherwise generate transfers from the          |
|       |        |                    | programmable write data buffers.               |
|       |        |                    | dtu_incr_banks                                 |
| 8     | RW     | 0×0                | When the column address rolls over increment   |
|       | INV    | 0.00               | the bank address until we reach and conclude   |
|       |        |                    | bank 7.                                        |



| Bit | Attr | Reset Value | Description                                  |
|-----|------|-------------|----------------------------------------------|
|     |      |             | dtu_incr_cols                                |
|     |      |             | Increment the column address until we        |
| 7   | RW   | 0x0         | saturate. Return to zero if                  |
|     |      |             | DTUCFG.dtu_incr_banks is set to 1 and we are |
|     |      |             | not at bank 7.                               |
|     | DW   | 0×00        | dtu_nalen                                    |
| 6:1 |      |             | Length of the NIF transfer sequence that is  |
| 0.1 | RW   | UXUU        | passed through the PCTL for each created     |
|     |      |             | address.                                     |
|     |      |             | dtu_enable                                   |
|     |      |             | When set, allows the DTU module to take      |
| 0   | RW   | 0x0         | ownership of the NIF interface:              |
|     |      |             | 1: DTU enabled                               |
|     |      |             | 0: DTU disabled                              |

# DDR\_PCTL\_DTUECTL

Address: Operational Base + offset (0x020c)

DTU Execute Control Register

| Bit  | Attr  | Reset Value | Description                                                                                                                                                                                                    |
|------|-------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | RO    | 0x0         | reserved                                                                                                                                                                                                       |
| 2 R  | R/WSC | 0x0         | wr_multi_rd_rst When set, resets the DTU in write once                                                                                                                                                         |
|      | ,     |             | multiple reads mode, to allow a new write to be performed. This bit automatically clears.                                                                                                                      |
| 1    | R/WSC | 0x0         | run_error_reports When set, initiates the calculation of the error status bits. This bit automatically clears when the re-calculation is done. This is only used in debug mode to verify the comparison logic. |
| 0    | R/WSC | 0×0         | run_dtu When set, initiates the running of the DTU read and write transfer. This bit automatically clears when the transfers are completed                                                                     |

## DDR\_PCTL\_DTUWD0

Address: Operational Base + offset (0x0210)

DTU Write Data #0 Register

| DIO WIII | of write bata no register |             |                 |  |  |
|----------|---------------------------|-------------|-----------------|--|--|
| Bit      | Attr                      | Reset Value | Description     |  |  |
| 31:24    | RW                        | 0x00        | dtu_wr_byte3    |  |  |
|          |                           |             | Write data byte |  |  |
| 23:16    | RW                        | 0x00        | dtu_wr_byte2    |  |  |
|          |                           |             | Write data byte |  |  |



| Bit  | Attr | Reset Value       | Description     |
|------|------|-------------------|-----------------|
| 15:8 | RW   | (() <b>x</b> ()() | dtu_wr_byte1    |
|      |      |                   | Write data byte |
| 7:0  | RW   | 0x00              | dtu_wr_byte0    |
|      |      |                   | Write data byte |

### DDR\_PCTL\_DTUWD1

Address: Operational Base + offset (0x0214)

DTU Write Data #1 Register

| Bit   | Attr | Reset Value | Description     |
|-------|------|-------------|-----------------|
| 31:24 | RW   | 0×00        | dtu_wr_byte7    |
| 31.24 | KVV  | UXUU        | Write data byte |
| 22.16 | RW   | 0,400       | dtu_wr_byte6    |
| 23:16 | KVV  | 0x00        | Write data byte |
| 1 5.0 | DW   | 0,400       | dtu_wr_byte5    |
| 15:8  | RW   | 0x00        | Write data byte |
| 7.0   | DW   | 0,400       | dtu_wr_byte4    |
| 7:0   | RW   | 0x00        | Write data byte |

## DDR\_PCTL\_DTUWD2

Address: Operational Base + offset (0x0218)

DTU Write Data #2 Register

| Bit   | Attr | Reset Value | Description                      |
|-------|------|-------------|----------------------------------|
| 31:24 | RW   | 0x00        | dtu_wr_byte11<br>Write data byte |
| 23:16 | RW   | 0x00        | dtu_wr_byte10<br>Write data byte |
| 15:8  | RW   | 0x00        | dtu_wr_byte9<br>Write data byte  |
| 7:0   | RW   | 0x00        | dtu_wr_byte8<br>Write data byte  |

# DDR\_PCTL\_DTUWD3

Address: Operational Base + offset (0x021c)

DTU Write Data #3 Register

| Bit     | Attr | Reset Value | Description     |
|---------|------|-------------|-----------------|
| 31:24 R | DW   | 0x00        | dtu_wr_byte15   |
|         | RW   |             | Write data byte |
| 22-16   | DW   | 000         | dtu_wr_byte14   |
| 23:16   | RW   | 0x00        | Write data byte |
| 15:8    | RW   | RW 0x00     | dtu_wr_byte13   |
|         |      |             | Write data byte |



| Bit   | Attr   | Reset Value | Description     |
|-------|--------|-------------|-----------------|
| 7:0 R | RW     | 0×00        | dtu_wr_byte12   |
| 7.0   | IX V V | 0.00        | Write data byte |

# DDR\_PCTL\_DTUWDM

Address: Operational Base + offset (0x0220)

DTU Write Data Mask Register

| Bit   | Attr | Reset Value | Description                                                                                                                  |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                                                                                                     |
| 15:0  | RW   | 0×0000      | dm_wr_byte0 Write data mask bit, one bit for each byte. Each bit should be 0 for a byte lane that contains valid write data. |

### DDR\_PCTL\_DTURD0

Address: Operational Base + offset (0x0224)

DTU Read Data #0 Register

| Bit   | Attr | Reset Value | Description  |
|-------|------|-------------|--------------|
| 31:24 | RO   | 0x00        | dtu_rd_byte3 |
| 31.24 | KO   |             | Read byte    |
| 23:16 | RO   | 0x00        | dtu_rd_byte2 |
| 23:10 |      |             | Read byte    |
| 15.0  | RO   | 000         | dtu_rd_byte1 |
| 15:8  | RO   | 0×00        | Read byte    |
| 7:0   | RO   | 0x00        | dtu_rd_byte0 |
|       |      |             | Read byte    |

# DDR\_PCTL\_DTURD1

Address: Operational Base + offset (0x0228)

DTU Read Data #1 Register

| Bit   | Attr | Reset Value           | Description  |
|-------|------|-----------------------|--------------|
| 31:24 | RO   | 0x00                  | dtu_rd_byte7 |
| 31.24 | KO   |                       | Read byte    |
| 23:16 | RO   | 0x00                  | dtu_rd_byte6 |
| 23:10 | KU   |                       | Read byte    |
| 15:8  | RO   | 000                   | dtu_rd_byte5 |
| 15:6  | RU   | 0×00                  | Read byte    |
| 7:0   | RO   | ?()  () <b>x</b> ()() | dtu_rd_byte4 |
|       |      |                       | Read byte    |

### DDR\_PCTL\_DTURD2

Address: Operational Base + offset (0x022c)

DTU Read Data #2 Register



| Bit   | Attr | Reset Value | Description   |
|-------|------|-------------|---------------|
| 31:24 | RO   | 0x00        | dtu_rd_byte11 |
| 31.24 | KO   |             | Read byte     |
| 22.16 | RO   | 0x00        | dtu_rd_byte10 |
| 23:16 |      |             | Read byte     |
| 15.0  | D.O. | 000         | dtu_rd_byte9  |
| 15:8  | RO   | 0×00        | Read byte     |
| 7:0   | RO   | 0x00        | dtu_rd_byte8  |
|       |      |             | Read byte     |

### DDR\_PCTL\_DTURD3

Address: Operational Base + offset (0x0230)

DTU Read Data #3 Register

| Bit     | Attr | Reset Value | Description   |
|---------|------|-------------|---------------|
| 21.24   | D.O. | 0,400       | dtu_rd_byte15 |
| 31:24   | RO   | 0x00        | Read byte     |
| 23:16   | D.O. | 0x00        | dtu_rd_byte14 |
|         | RO   |             | Read byte     |
| 1 5 . 0 | DO.  | 0,400       | dtu_rd_byte13 |
| 15:8    | RO   | 0x00        | Read byte     |
| 7:0     | DO.  | 20 000      | dtu_rd_byte12 |
|         | KU   | RO 0x00     | Read byte     |

### DDR\_PCTL\_DTULFSRWD

Address: Operational Base + offset (0x0234)

DTU LFSR Seed for Write Data Generation Register

| Bit  | Attr | Reset Value | Description                                   |
|------|------|-------------|-----------------------------------------------|
|      |      |             | dtu_lfsr_wseed                                |
|      |      | ( ) >       | This is the initial seed for the random write |
| 31:0 | RW   | 0x00000000  | data generation LFSR (linear feedback shift   |
|      |      |             | register), shared with the write mask         |
|      |      |             | generation.                                   |

### DDR\_PCTL\_DTULFSRRD

Address: Operational Base + offset (0x0238)DTU LFSR Seed for Read Data Generation Register

Bit **Reset Value** Attr **Description** 



| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                  |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0×00000000  | dtu_lfsr_rseed This is the initial seed for the random read data generation LFSR (linear feedback shift register), this is shared with the read mask generation. The read data mask is reconstructed the same as the write data mask was created, allowing the " on the fly comparison" ignore bytes which were not written. |

### DDR\_PCTL\_DTUEAF

Address: Operational Base + offset (0x023c)

DTU Error Address FIFO Register

| DIU Error Address FIFO Register |      |             |                                                                                                                                                                                      |
|---------------------------------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                             | Attr | Reset Value | Description                                                                                                                                                                          |
| 31:30                           | RO   | 0×0         | ea_rank Indicates the rank that the error occurred in during random data generation. There could be a number of entries in this FIFO. If FIFO is empty one reads zeroes.             |
| 29                              | RO   | 0x0         | reserved                                                                                                                                                                             |
| 28:13                           | RO   | 0x0000      | ea_row Indicates the row that the error occurred in during random data generation. There could be a number of entries in this FIFO. If FIFO is empty one reads zeroes.               |
| 12:10                           | RO   | 0x0         | ea_bank Indicates the bank that the error occurred in during random data generation. There could be a number of entries in this FIFO. If FIFO is empty one reads zeroes              |
| 9:0                             | RO   | 0x000       | ea_column Indicates the column address that the error occurred in during random data generation. There could be a number of entries in this FIFO. If FIFO is empty one reads zeroes. |

## DDR\_PCTL\_DFITCTRLDELAY

Address: Operational Base + offset (0x0240)

DFI tctrl\_delay Register

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:4 | RO   | 0x0         | reserved    |



| Bit | Attr              | Reset Value      | Description                                                                                                                                                                                                                                                                          |
|-----|-------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0 | <b>Attr</b><br>RW | Reset Value  0x2 | tctrl_delay Specifies the number of DFI clock cycles after an assertion or deassertion of the DFI control signals that the control signals at the PHY-DRAM interface reflect the assertion or de-assertion. If the DFI clock and the memory clock are not phase-aligned, this timing |
|     |                   |                  | parameter should be rounded up to the next integer value.                                                                                                                                                                                                                            |

## DDR\_PCTL\_DFIODTCFG

Address: Operational Base + offset (0x0244) DFI ODT Configuration

| וטט נוט  | Configu | nation      | X /                                          |
|----------|---------|-------------|----------------------------------------------|
| Bit      | Attr    | Reset Value | Description                                  |
| 31:29    | RO      | 0x0         | reserved                                     |
|          |         |             | rank3_odt_default                            |
| 28       | RW      | 0x0         | Default ODT value of rank 3 when there is no |
|          |         |             | read/write activity                          |
|          |         |             | rank3_odt_write_sel                          |
| 27       | RW      | 0x0         | Enable/disable ODT for rank 3 when a write   |
|          |         |             | access is occurring on this rank             |
|          |         |             | rank3_odt_write_nse                          |
| 26       | RW      | 0x0         | Enable/disable ODT for rank 3 when a write   |
|          |         |             | access is occurring on a different rank      |
|          |         | • (1)       | rank3_odt_read_sel                           |
| 25       | RW      | 0x0         | Enable/disable ODT for rank 3 when a read    |
|          |         |             | access is occurring on this rank             |
|          |         |             | rank3_odt_read_nsel                          |
| 24       | RW      | 0×0         | Enable/disable ODT for rank 3 when a read    |
|          |         | 7           | access is occurring on a different rank      |
| 23:21    | RO      | 0x0         | reserved                                     |
|          |         |             | rank2_odt_default                            |
| 20       | RW      | 0x0         | Default ODT value of rank 2 when there is no |
| <b>Y</b> |         |             | read/write activity                          |
|          |         |             | rank2_odt_write_sel                          |
| 19       | RW      | 0x0         | Enable/disable ODT for rank 2 when a write   |
|          |         |             | access is occurring on this rank             |
|          |         |             | rank2_odt_write_nse                          |
| 18       | RW      | 0x0         | Enable/disable ODT for rank 2 when a write   |
|          |         |             | access is occurring on a different rank      |



| Bit   | Attr   | Reset Value | Description                                  |
|-------|--------|-------------|----------------------------------------------|
|       |        |             | rank2_odt_read_sel                           |
| 17    | RW     | 0x0         | Enable/disable ODT for rank 2 when a read    |
|       |        |             | access is occurring on this rank             |
|       |        |             | rank2_odt_read_nsel                          |
| 16    | RW     | 0x0         | Enable/disable ODT for rank 2 when a read    |
|       |        |             | access is occurring on a different rank      |
| 15:13 | RO     | 0x0         | reserved                                     |
|       |        |             | rank1_odt_default                            |
| 12    | RW     | 0x0         | Default ODT value of rank 1 when there is no |
|       |        |             | read/write activity                          |
|       |        |             | rank1_odt_write_sel                          |
| 11    | RW     | 0x0         | Enable/disable ODT for rank 1 when a write   |
|       |        |             | access is occurring on this rank             |
|       |        |             | rank1_odt_write_nse                          |
| 10    | RW     | 0x0         | Enable/disable ODT for rank 1 when a write   |
|       |        |             | access is occurring on a different rank      |
|       |        |             | rank1_odt_read_sel                           |
| 9     | RW     | 0x0         | Enable/disable ODT for rank 1 when a read    |
|       |        |             | access is occurring on this rank             |
|       |        |             | rank1_odt_read_nsel                          |
| 8     | RW     | 0x0         | Enable/disable ODT for rank 1 when a read    |
|       |        |             | access is occurring on a different rank      |
| 7:5   | RO     | 0x0         | reserved                                     |
|       |        |             | rank0_odt_default                            |
| 4     | RW     | 0x0         | Default ODT value of rank 0 when there is no |
|       |        |             | read/write activity                          |
|       |        |             | rank0_odt_write_sel                          |
| 3     | RW     | 0x0         | Enable/disable ODT for rank 0 when a write   |
|       | 1      |             | access is occurring on this rank             |
|       |        |             | rank0_odt_write_nse                          |
| 2     | RW     | 0x0         | Enable/disable ODT for rank 0 when a write   |
|       | $\cup$ |             | access is occurring on a different rank      |
|       |        |             | rank0_odt_read_sel                           |
| 1     | RW     | 0x0         | Enable/disable ODT for rank 0 when a read    |
|       |        |             | access is occurring on this rank             |
|       |        |             | rank0_odt_read_nsel                          |
| 0     | RW     | 0x0         | Enable/disable ODT for rank 0 when a read    |
|       |        |             | access is occurring on a different rank      |

# DDR\_PCTL\_DFIODTCFG1

Address: Operational Base + offset (0x0248)

DFI ODT Timing Configuration 1 (for Latency and Length)



| Bit   | Attr | Reset Value | Description                                      |
|-------|------|-------------|--------------------------------------------------|
| 31:27 | RO   | 0x0         | reserved                                         |
|       |      |             | ODT length for BL8 read transfers                |
|       |      |             | Length of dfi_odt signal for BL8 reads. This is  |
| 26:24 | RW   | 0x6         | in terms of SDR cycles. For BL4 reads, the       |
|       |      |             | length of dfi_odt is always 2 cycles shorter     |
|       |      |             | than the value in this register field.           |
| 23:19 | RO   | 0x0         | reserved                                         |
|       |      |             | ODT length for BL8 write transfers               |
|       |      |             | Length of dfi_odt signal for BL8 writes. This is |
| 18:16 | RW   | W 0x6       | in terms of SDR cycles.                          |
| 10.10 |      |             | For BL4 writes, the length of dfi_odt is always  |
|       |      |             | 2 cycles shorter than the value in this register |
|       |      |             | field.                                           |
| 15:13 | RO   | 0x0         | reserved                                         |
|       |      |             | ODT latency for reads                            |
| 12:8  | RW   | 0x00        | Latency after a read command that dfi_odt is     |
|       |      |             | set. This is in terms of SDR cycles.             |
| 7:5   | RO   | 0x0         | reserved                                         |
|       |      |             | ODT latency for writes                           |
| 4:0   | RW   | 0x00        | Latency after a write command that dfi_odt is    |
|       |      |             | set. This is in terms of SDR cycles              |

# DDR\_PCTL\_DFIODTRANKMAP

Address: Operational Base + offset (0x024c)

DFI ODT Rank Mapping

| Bit   | Attr | Reset Value | Description                                                                                                                                                            |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                                                                                                                                               |
|       | S    |             | Rank mapping for dfi_odt[3]  Determines whether dfi_odt[3] should be asserted when the PCTLrequires to terminate each rank  Bit 15 = 1: dfi_odt[3] will be asserted to |
| 15:12 | RW   | 0x8         | terminate rank 3  Bit 14 = 1: dfi_odt[3] will be asserted to terminate rank 2                                                                                          |
|       |      |             | Bit 13 = 1: dfi_odt[3] will be asserted to terminate rank 1 Bit 12 = 1: dfi_odt[3] will be asserted to terminate rank 0 This field exists only if PCTL_M_NRANKS = 4    |



| Bit   | Attr | Reset Value | Description                                 |
|-------|------|-------------|---------------------------------------------|
|       |      |             | Rank mapping for dfi_odt[2]                 |
|       |      |             | Determines which rank access(es) will cause |
|       |      |             | dfi_odt[2] to be asserted                   |
|       |      |             | Bit 11 = 1: dfi_odt[2] will be asserted to  |
|       |      |             | terminate rank 3                            |
| 11:8  | RW   | 0x4         | Bit 10 = 1: dfi_odt[2] will be asserted to  |
| 11.0  | IXVV | 0.74        | terminate rank 2                            |
|       |      |             | Bit 9 = 1: dfi_odt[2] will be asserted to   |
|       |      |             | terminate rank 1                            |
|       |      |             | Bit 8 = 1: dfi_odt[2] will be asserted to   |
|       |      |             | terminate rank 0                            |
|       |      |             | This field exists only if PCTL_M_NRANKS = 4 |
|       |      |             | Rank mapping for dfi_odt[1]                 |
|       |      |             | Determines which rank access(es) will cause |
|       |      |             | dfi_odt[1] to be asserted                   |
|       |      |             | Bit 7= 1: dfi_odt[1] will be asserted to    |
|       |      |             | terminate rank 3                            |
| 7:4   | RW   | 0x2         | Bit 6= 1: dfi_odt[1] will be asserted to    |
| / . ¬ |      | UXZ         | terminate rank 2                            |
|       |      |             | Bit 5= 1: dfi_odt[1] will be asserted to    |
|       |      |             | terminate rank 1                            |
|       |      |             | Bit 4= 1: dfi_odt[1] will be asserted to    |
|       |      |             | terminate rank 0                            |
|       |      |             | This field exists only if PCTL_M_NRANKS >   |
|       |      | . ()        | Rank mapping for dfi_odt[0]                 |
|       |      | 1           | Determines which rank access(es) will cause |
|       |      |             | dfi_odt[0] to be asserted                   |
|       |      |             | Bit 3= 1: dfi_odt[0] will be asserted to    |
|       | 11   |             | terminate rank 3                            |
| 3:0   | RW   | 0x1         | Bit 2= 1: dfi_odt[0] will be asserted to    |
|       |      |             | terminate rank 2                            |
|       |      |             | Bit 1= 1: dfi_odt[0] will be asserted to    |
|       | 7    |             | terminate rank 1                            |
| 7     |      |             | Bit 0= 1: dfi_odt[0] will be asserted to    |
|       |      |             | terminate rank 0                            |

## DDR\_PCTL\_DFITPHYWRDATA

Address: Operational Base + offset (0x0250)

DFI tphy\_wrdata Register

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:6 | RO   | 0x0         | reserved    |



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                      |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:0 | RW   | 0x01        | tphy_wrdata Specifies the number of DFI clock cycles between when the dfi_wrdata_en signal is asserted to when the associated write data is driven on the dfi_wrdata signal. This has no impact on performance, only adjusts the |
|     |      |             | relative time between enable and data transfer.                                                                                                                                                                                  |

### DDR\_PCTL\_DFITPHYWRLAT

Address: Operational Base + offset (0x0254)

DFI tphy wrlat Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                          |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | RO   | 0x0         | reserved                                                                                                                                                             |
| 5:0  | RW   | 0×01        | tphy_wrlat Specifies the number of DFI clock cycles between when a write command is sent on the DFI control interface and when the dfi_wrdata_en signal is asserted. |

### DDR\_PCTL\_DFITRDDATAEN

Address: Operational Base + offset (0x0260)

DFI trddata en Register

| Dirtia | Dir dadad_cir register |             |                                               |  |  |
|--------|------------------------|-------------|-----------------------------------------------|--|--|
| Bit    | Attr                   | Reset Value | Description                                   |  |  |
| 31:6   | RO                     | 0x0         | reserved                                      |  |  |
| 5:0    | RW                     | 0x01        | trddata_en                                    |  |  |
|        |                        |             | Specifies the number of DFI clock cycles from |  |  |
|        |                        |             | the assertion of a read command on the DFI to |  |  |
|        |                        |             | the assertion of the dfi_rddata_en signal.    |  |  |

## DDR\_PCTL\_DFITPHYRDLAT

Address: Operational Base + offset (0x0264)

DFI tphy\_rdlat Register

| Bit  | Attr | Reset Value | Description                                  |
|------|------|-------------|----------------------------------------------|
| 31:6 | RO   | 0x0         | reserved                                     |
|      |      |             | tphy_rdlat                                   |
|      |      |             | Specifies the maximum number of DFI clock    |
| 5:0  | RW   | 0x0f        | cycles allowed from the assertion of the     |
|      |      |             | dfi_rddata_en signal to the assertion of the |
|      |      |             | dfi_rddata_valid signal.                     |

### DDR\_PCTL\_DFITPHYUPDTYPE0



Address: Operational Base + offset (0x0270)

DFI tphyupd\_type0 Register

| Bit   | Attr | Reset Value | Description                                  |
|-------|------|-------------|----------------------------------------------|
| 31:12 | RO   | 0x0         | reserved                                     |
|       |      |             | tphyupd_type0                                |
| 11:0  | RW   | 0×010       | Specifies the maximum number of DFI clock    |
|       |      |             | cycles that the dfi_phyupd_req signal may    |
|       |      |             | remain asserted after the assertion of the   |
| 11.0  | KVV  | 00010       | dfi_phyupd_ack signal for dfi_phyupd_type =  |
|       |      |             | 0x0. The dfi_phyupd_req signal may de-assert |
|       |      |             | at any cycle after the assertion of the      |
|       |      |             | dfi_phyupd_ack signal.                       |

### DDR\_PCTL\_DFITPHYUPDTYPE1

Address: Operational Base + offset (0x0274)

DFI tphyupd\_type1 Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                          |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                             |
| 11:0  | RW   | 0x010       | tphyupd_type1 Specifies the maximum number of DFI clock cycles that the dfi_phyupd_req signal may remain asserted after the assertion of the dfi_phyupd_ack signal for dfi_phyupd_type = 0x1. The dfi_phyupd_req signal may de-assert at any cycle after the assertion of the dfi_phyupd_ack signal. |

# DDR\_PCTL\_DFITPHYUPDTYPE2

Address: Operational Base + offset (0x0278)

DFI tphyupd\_type2 Register

| Bit   | Attr | Reset Value | Description                                  |
|-------|------|-------------|----------------------------------------------|
| 31:12 | RO   | 0x0         | reserved                                     |
|       |      |             | tphyupd_type2                                |
|       | ,    |             | Specifies the maximum number of DFI clock    |
|       |      |             | cycles that the dfi_phyupd_req signal may    |
| 11:0  | 0 RW | 10×010      | remain asserted after the assertion of the   |
| 11.0  |      |             | dfi_phyupd_ack signal for dfi_phyupd_type =  |
|       |      |             | 0x2. The dfi_phyupd_req signal may de-assert |
|       |      |             | at any cycle after the assertion of the      |
|       |      |             | dfi_phyupd_ack signal.                       |

### DDR\_PCTL\_DFITPHYUPDTYPE3

Address: Operational Base + offset (0x027c)

DFI tphyupd\_type3 Register



| Bit   | Attr | Reset Value | Description                                  |
|-------|------|-------------|----------------------------------------------|
| 31:12 | RO   | 0x0         | reserved                                     |
|       |      | W 0x010     | tphyupd_type3                                |
|       | RW   |             | Specifies the maximum number of DFI clock    |
|       |      |             | cycles that the dfi_phyupd_req signal may    |
| 11:0  |      |             | remain asserted after the assertion of the   |
|       |      |             | dfi_phyupd_ack signal for dfi_phyupd_type =  |
|       |      |             | 0x3. The dfi_phyupd_req signal may de-assert |
|       |      |             | at any cycle after the assertion of the      |
|       |      |             | dfi_phyupd_ack signal.                       |

## DDR\_PCTL\_DFITCTRLUPDMIN

Address: Operational Base + offset (0x0280)

DFI tctrlupd\_min Register

| Bit   | Attr | Reset Value | Description                                                                                                     |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                                                                                        |
| 15:0  | RW   | 0x0010      | tctrlupd_min Specifies the minimum number of DFI clock cycles that the dfi_ctrlupd_req signal must be asserted. |

## DDR\_PCTL\_DFITCTRLUPDMAX

Address: Operational Base + offset (0x0284)

DFI tctrlupd\_max Register

| Bit   | Attr | Reset Value | Description                                                                                               |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                                                                                  |
| 15:0  | RW   | 0x0040      | tctrlupd_max Specifies the maximum number of DFI clock cycles that the dfi_ctrlupd_req signal can assert. |

# DDR\_PCTL\_DFITCTRLUPDDLY

Address: Operational Base + offset (0x0288)

DFI tctrlupddly Register

| Bit  | Attr | Reset Value | Description                                |
|------|------|-------------|--------------------------------------------|
| 31:4 | RO   | 0x0         | reserved                                   |
|      |      |             | tctrlupd_dly                               |
|      |      |             | Delay in DFI clock cycles between time a   |
| 3:0  | RW   | 0x8         | PCTL-initiated update could be started and |
|      |      |             | time PCTL-initated update actually starts  |
|      |      |             | (dfi_ctrlupd_req going high).              |

### DDR\_PCTL\_DFIUPDCFG



Address: Operational Base + offset (0x0290)

DFI Update Configuration Register

| Bit  | Attr | Reset Value | Description                              |
|------|------|-------------|------------------------------------------|
| 31:2 | RO   | 0x0         | reserved                                 |
|      |      |             | dfi_phyupd_en                            |
|      |      |             | Enables the support for acknowledging    |
| 1    | RW   | 0x1         | PHY-initiated updates:                   |
|      |      |             | 1'b0 = Disabled                          |
|      |      |             | 1'b1 = Enabled                           |
|      |      |             | dfi_ctrlupd_en                           |
|      |      |             | Enables the generation of PCTL-initiated |
| 0    | RW   | 0x1         | updates:                                 |
|      |      |             | 1'b0 = Disabled                          |
|      |      |             | 1'b1 = Enabled                           |

# DDR\_PCTL\_DFITREFMSKI

Address: Operational Base + offset (0x0294)

DFI Masked Refresh Interval

| Bit  | Attr | Reset Value | Description                                     |
|------|------|-------------|-------------------------------------------------|
| 31:8 | RO   | 0x0         | reserved                                        |
|      |      |             | trefmski                                        |
|      |      | 0x00        | Time period of the masked Refresh interva       |
| 7.0  | RW   |             | This value is only used if TREFI==0.            |
|      |      |             | Defines the time period (in 100ns units) of the |
| 7:0  |      |             | masked Refresh (REFMSK) interval.               |
|      |      |             | The actual time period defined is               |
|      |      |             | DFITREFMSKI* TOGCNT100N * internal timers       |
|      |      | VO X        | clock period.                                   |

# DDR\_PCTL\_DFITCTRLUPDI

Address: Operational Base + offset (0x0298)

DFI tctrlupd\_interval Register

| Bit | Attr    | Reset Value  | Description |
|-----|---------|--------------|-------------|
| 7.9 | ,,,,,,, | iteset raide |             |



| Bit             | Attr | Reset Value                   | Description                                                                                                                                                                                                                                                                                                                                                                         |
|-----------------|------|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b> 31:0 | Attr | <b>Reset Value</b> 0×00000000 | tctrlupd_interval DFI PCTL-initiated updates interval, measured in terms of Refresh interval units. If TREFI!=0, the time period is defined as DFITCTRLUPDI*TREFI * TOGCNT100N * internal timers clock period. If TREFI==0 and DFITREFMSKI!=0, the period changes to DFITCTRLUPDI*DFITREFMSKI* * TOGCNT100N * internal timers clock period. Programming a value of 0 is the same as |
|                 |      |                               | programming a value of 1; for instance, a                                                                                                                                                                                                                                                                                                                                           |
|                 |      |                               |                                                                                                                                                                                                                                                                                                                                                                                     |
|                 |      |                               | programming a value of 1; for instance, a                                                                                                                                                                                                                                                                                                                                           |
|                 |      |                               | PCTL-initiated update occurs every Refresh                                                                                                                                                                                                                                                                                                                                          |
|                 |      |                               | interval.                                                                                                                                                                                                                                                                                                                                                                           |

# DDR\_PCTL\_DFITRCFG0

Address: Operational Base + offset (0x02ac)

DFI Training Configuration 0 Register

| Bit   | Attr | Reset Value | Description                                    |
|-------|------|-------------|------------------------------------------------|
| 31:20 | RO   | 0x0         | reserved                                       |
|       |      |             | dfi_wrlvl_rank_sel                             |
|       |      |             | Determines the value to drive on the output    |
| 19:16 | RW   | 0x0         | signal dfi_wrlvl_cs_n.                         |
|       |      |             | The value on dfi_wrlvl_cs_n is the inverse of  |
|       |      |             | the setting in this field.                     |
| 15:13 | RO   | 0x0         | reserved                                       |
|       |      |             | dfi_rdlvl_edge                                 |
|       |      |             | Determines the value to drive on the output    |
| 12:4  | RW   | 0x000       | signal dfi_rdlvl_edge.                         |
|       | 1    |             | The value on dfi_rdlvl_edge is the same as the |
|       |      | <b>Y</b>    | setting in this field.                         |
| /     |      |             | dfi_rdlvl_rank_sel                             |
|       |      |             | Determines the value to drive on the output    |
| 3:0   | RW   | 0x0         | signal dfi_rdlvl_cs_n.                         |
| 7     |      |             | The value on dfi_rdlvl_cs_n is the inverse of  |
|       |      |             | the setting in this field.                     |

## DDR\_PCTL\_DFITRSTATO

Address: Operational Base + offset (0x02b0)

DFI Training Status 0 Register

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:18 | RO   | 0x0         | reserved    |



| Bit   | Attr | Reset Value | Description                           |
|-------|------|-------------|---------------------------------------|
|       |      |             | dfi_wrlvl_mode                        |
| 17:16 | RO   | 0x0         | Reports the value of the input signal |
|       |      |             | dfi_wrlvl_mode.                       |
| 15:10 | RO   | 0x0         | reserved                              |
|       |      |             | dfi_rdlvl_gate_mode                   |
| 9:8   | RO   | 0x0         | Reports the value of the input signal |
|       |      |             | dfi_rdlvl_gate_mode.                  |
| 7:2   | RO   | 0x0         | reserved                              |
|       |      |             | dfi_rdlvl_mode                        |
| 1:0   | RO   | 0x0         | Reports the value of the input signal |
|       |      |             | dfi_rdlvl_mode.                       |

## DDR\_PCTL\_DFITRWRLVLEN

Address: Operational Base + offset (0x02b4)

DFI Training dfi\_wrlvl\_en Register

| Bit  | Attr | Reset Value | Description                                 |
|------|------|-------------|---------------------------------------------|
| 31:9 | RO   | 0x0         | reserved                                    |
|      |      |             | dfi_wrlvl_en                                |
| 8:0  | RW   | 0x000       | Determines the value to drive on the output |
|      |      |             | signal dfi_wrlvl_en.                        |

## DDR\_PCTL\_DFITRRDLVLEN

Address: Operational Base + offset (0x02b8)

DFI Training dfi rdlvl en Register

| Bit  | Attr | Reset Value | Description                                 |
|------|------|-------------|---------------------------------------------|
| 31:9 | RO   | 0x0         | reserved                                    |
|      |      |             | dfi_rdlvl_en                                |
| 8:0  | RW   | 0x000       | Determines the value to drive on the output |
|      |      |             | signal dfi_rdlvl_en.                        |

## DDR\_PCTL\_DFITRRDLVLGATEEN

Address: Operational Base + offset (0x02bc)

DFI Training dfi\_rdlvl\_gate\_en Register

| Bit  | Attr | Reset Value | Description                                 |
|------|------|-------------|---------------------------------------------|
| 31:9 | RO   | 0x0         | reserved                                    |
|      |      |             | dfi_rdlvl_gate_en                           |
| 8:0  | RW   | 0x000       | Determines the value to drive on the output |
|      |      |             | signal dfi_rdlvl_gate_en.                   |

## DDR\_PCTL\_DFISTSTATO

Address: Operational Base + offset (0x02c0)

DFI Status Status 0 Register



| Bit   | Attr | Reset Value | Description                            |
|-------|------|-------------|----------------------------------------|
| 31:25 | RO   | 0x0         | reserved                               |
|       |      |             | dfi_data_byte_disable                  |
| 24:16 | RO   | 0x000       | Reports the value of the output signal |
|       |      |             | dfi_data_byte_disable.                 |
| 15:6  | RO   | 0x0         | reserved                               |
|       |      |             | dfi_freq_ratio                         |
| 5:4   | RO   | 0x0         | Reports the value of the output signal |
|       |      |             | dfi_freq_ratio.                        |
| 3:2   | RO   | 0x0         | reserved                               |
|       |      |             | dfi_init_start                         |
| 1     | RO   | 0x0         | Reports the value of the output signal |
|       |      |             | dfi_init_start.                        |
|       |      |             | dfi_init_complete                      |
| 0     | RO   | 0x0         | Reports the value of the input signal  |
|       |      |             | dfi_init_complete.                     |

# DDR\_PCTL\_DFISTCFG0

Address: Operational Base + offset (0x02c4)

DFI Status Configuration 0 Register

| Bit  | Attr   | Reset Value | Description                                     |
|------|--------|-------------|-------------------------------------------------|
| 31:3 | RO     | 0x0         | reserved                                        |
|      |        |             | dfi_data_byte_disable_en                        |
|      |        |             | Enables the driving of the                      |
|      |        |             | dfi_data_byte_disable signal. The value driven  |
|      |        | • 1         | on dfi_data_byte_disable is dependent on the    |
|      |        |             | setting of PPCFG register.                      |
| 2    | RW     | 0x0         | 1'b0 - Drive dfi_data_byte_disable to default   |
|      |        |             | value of all zeroes.                            |
|      |        |             | 1'b1 - Drive dfi_data_byte_disable according to |
|      |        | · /         | value as defined by PPCFG register setting.     |
|      |        |             | Note: should be set to 1 only after PPCFG is    |
|      | $\cup$ |             | correctly set.                                  |



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                          |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | RW   | 0x0         | dfi_freq_ratio_en Enables the driving of the dfi_freq_ratio signal. When enabled, the dfi_freq_ratio value driven is dependent on configuration parameter PCTL_FREQ_RATIO: 2'b00 is driven when PCTL_FREQ_RATIO=1; 2'b01 is driven when PCTL_FREQ_RATIO=2. 1'b0 - Drive dfi_freq_ratio to default value of 2'b00. 1'b1 - Drive dfi_freq_ratio value according to how configuration parameter is set. |
| 0   | RW   | 0×0         | dfi_init_start Sets the value of the dfi_init_start signal. 1'b0 - dfi_init_start is driven low 1'b1 - dfiinit_start is driven high                                                                                                                                                                                                                                                                  |

# DDR\_PCTL\_DFISTCFG1

Address: Operational Base + offset (0x02c8)

DFI Status Configuration 1 Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                          |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                             |
| 1    | RW   | 0x0         | dfi_dram_clk_disable_en_dpd Enables support of the dfi_dram_clk_disable signal with Deep Power Down (DPD). DPD is only for mDDR/LPDDR2. 1'b0 - Disable dfi_dram_clk_disable support in relation to DPD 1'b1 - Enable dfi_dram_clk_disable support in relation to DPD |
| 0    | RW   | 0×0         | dfi_dram_clk_disable_en Enables support of the dfi_dram_clk_disable signal with Self Refresh (SR). 1'b0 - Disable dfi_dram_clk_disable support in relation to SR 1'b1 - Enable dfi_dram_clk_disable support in relation to SR                                        |

# DDR\_PCTL\_DFITDRAMCLKEN

Address: Operational Base + offset (0x02d0)

DFI tdram clk enable Register

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:4 | RO   | 0x0         | reserved    |



| Bit | Attr | Reset Value | Description                                         |
|-----|------|-------------|-----------------------------------------------------|
|     |      |             | tdram_clk_enable                                    |
|     |      |             | Specifies the number of DFI clock cycles from       |
|     |      |             | the de-assertion of the dfi_dram_clk_disable        |
|     |      |             | signal on the DFI until the first valid rising edge |
| 3:0 | RW   | 0x2         | of the clock to the DRAM memory devices, at         |
|     |      |             | the PHY-DRAM boundary. If the DFI clock and         |
|     |      |             | the memory clock are not phasealigned, this         |
|     |      |             | timing parameter should be rounded up to the        |
|     |      |             | next integer value.                                 |

## DDR\_PCTL\_DFITDRAMCLKDIS

Address: Operational Base + offset (0x02d4)

DFI tdram clk disable Register

| Bit  | Attr | Reset Value | Description                                     |
|------|------|-------------|-------------------------------------------------|
| 31:4 | RO   | 0x0         | reserved                                        |
|      |      |             | tdram_clk_disable                               |
|      |      |             | Specifies the number of DFI clock cycles from   |
|      |      |             | the assertion of the dfi_dram_clk_disable       |
|      |      |             | signal on the DFI until the clock to the DRAM   |
| 3:0  | RW   | 0x2         | memory devices, at the PHY-DRAM boundary,       |
|      |      |             | maintains a low value. If the DFI clock and the |
|      |      |             | memory clock are not phasealigned, this         |
|      |      |             | timing parameter should be rounded up to the    |
|      |      |             | next integer value.                             |

# DDR\_PCTL\_DFISTCFG2

Address: Operational Base + offset (0x02d8)

DFI Status Configuration 2 Register

| Bit      | Attr | Reset Value | Description                                      |
|----------|------|-------------|--------------------------------------------------|
| 31:2     | RO   | 0x0         | reserved                                         |
|          |      |             | parity_en                                        |
| 0        |      |             | Enables the DFI parity generation feature        |
| 1        | RW   | 0x0         | (driven on output signal dfi_parity_in)          |
| <b>y</b> |      |             | 1'b0 - Disable DFI parity generation             |
|          |      |             | 1'b1 - Enable DFI parity generation              |
|          |      |             | parity_intr_en                                   |
|          |      |             | Enable interrupt generation for DFI parity error |
| 0        | RW   | 0x0         | (from input signal dfi_parity_error).            |
|          |      |             | 1'b0 - Disable interrupt                         |
|          |      |             | 1'b1 - Enable interrupt                          |

# DDR\_PCTL\_DFISTPARCLR



Address: Operational Base + offset (0x02dc)

DFI Status Parity Clear Register

| Bit  | Attr   | Reset Value | Description                                         |
|------|--------|-------------|-----------------------------------------------------|
| 31:2 | RO     | 0x0         | reserved                                            |
|      |        |             | parity_log_clr                                      |
|      |        |             | Set this bit to 1'b1 to clear the DFI Status Parity |
| 1    | R/WSC  | 0×0         | Log register (DFISTPARLOG).                         |
| 1    | K) W3C | UXU         | 1'b0 = Do not clear DFI status Parity Log           |
|      |        |             | register                                            |
|      |        |             | 1'b1 = Clear DFI status Parity Log register         |
|      | R/WSC  |             | parity_intr_clr                                     |
|      |        |             | Set this bit to 1'b1 to clear the interrupt         |
|      |        |             | generated by an DFI parity error (as enabled        |
| 0    |        |             | by DFISTCFG2.parity_intr_en). It also clears        |
|      |        |             | the INTRSTAT.parity_intr register field. It is      |
|      |        |             | automatically cleared by hardware when the          |
|      |        |             | interrupt has been cleared.                         |

# DDR\_PCTL\_DFISTPARLOG

Address: Operational Base + offset (0x02e0)

DFI Status Parity Log Register

| Bit  | Attr | Reset Value | Description                                             |
|------|------|-------------|---------------------------------------------------------|
| 31:0 | RO   | 0×00000000  | parity_err_cnt Increments any time the DFI parity logic |
|      |      |             | detects a parity error(s) (on dfi_parity_error).        |

# DDR\_PCTL\_DFILPCFG0

Address: Operational Base + offset (0x02f0) DFI Low Power Configuration 0 Register

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
|-----|------|-------------|-------------|



| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
|       |      |             | dfi_lp_wakeup_dpd                             |
|       |      |             | Value to drive on dfi_lp_wakeup signal when   |
|       |      |             | Deep Power Down mode is entered.              |
|       |      |             | Determines the DFI's tlp_wakeup time:         |
|       |      |             | 4'b0000 - 16 cycles                           |
|       |      |             | 4'b0001 - 32 cycles                           |
|       |      |             | 4'b0010 - 64 cycles                           |
|       |      |             | 4'b0011 - 128 cycles                          |
|       |      |             | 4'b0100 - 256 cycles                          |
| 31:28 | RW   | 0×0         | 4'b0101 - 512 cycles                          |
| 31.20 |      | 0.00        | 4'b0110 - 1024 cycles                         |
|       |      |             | 4'b0111 - 2048 cycles                         |
|       |      |             | 4'b1000 - 4096 cycles                         |
|       |      |             | 4'b1001 - 8192 cycles                         |
|       |      |             | 4'b1010 - 16384 cycles                        |
|       |      |             | 4'b1011 - 32768 cycles                        |
|       |      |             | 4'b1100 - 65536 cycles                        |
|       |      |             | 4'b1101 - 131072 cycles                       |
|       |      |             | 4'b1110 - 262144 cycles                       |
|       |      |             | 4'b1111 - Unlimited                           |
| 27:25 | RO   | 0x0         | reserved                                      |
|       |      |             | dfi_lp_en_dpd                                 |
|       |      |             | Enables DFI Low Power interface handshaking   |
| 24    | RW   | 0x0         | during Deep Power Down Entry/Exit.            |
|       |      | . ()        | 1'b0 - Disabled                               |
|       |      |             | 1'b1 - Enabled                                |
| 23:20 | RO   | 0x0         | reserved                                      |
|       |      | ()          | dfi_tlp_resp                                  |
|       | 11   |             | Setting for tlp_resp time.                    |
| 19:16 | RW   | 0x7         | Same value is used for both Power Down and    |
|       |      |             | Self refresh and Deep Power Down modes.       |
|       |      |             | DFI 2.1 specification, recommends using value |
|       |      |             | of 7 always.                                  |

| Bit   | Attr | Reset Value | Description                                 |
|-------|------|-------------|---------------------------------------------|
|       |      |             | dfi_lp_wakeup_sr                            |
|       |      |             | Value to drive on dfi_lp_wakeup signal when |
|       |      |             | Self Refresh mode is entered.               |
|       |      |             | Determines the DFI's tlp_wakeup time:       |
|       |      |             | 4'b0000 - 16 cycles                         |
|       |      |             | 4'b0001 - 32 cycles                         |
|       |      |             | 4'b0010 - 64 cycles                         |
|       |      |             | 4'b0011 - 128 cycles                        |
|       |      |             | 4'b0100 - 256 cycles                        |
| 15:12 | RW   | 0x0         | 4'b0101 - 512 cycles                        |
| 15.12 | KVV  |             | 4'b0110 - 1024 cycles                       |
|       |      |             | 4'b0111 - 2048 cycles                       |
|       |      |             | 4'b1000 - 4096 cycles                       |
|       |      |             | 4'b1001 - 8192 cycles                       |
|       |      |             | 4'b1010 - 16384 cycles                      |
|       |      |             | 4'b1011 - 32768 cycles                      |
|       |      |             | 4'b1100 - 65536 cycles                      |
|       |      |             | 4'b1101 - 131072 cycles                     |
|       |      |             | 4'b1110 - 262144 cycles                     |
|       |      |             | 4'b1111 - Unlimited                         |
| 11:9  | RO   | 0x0         | reserved                                    |
|       |      | 0x0         | dfi_lp_en_sr                                |
|       |      |             | Enables DFI Low Power interface handshaking |
| 8     | RW   |             | during Self Refresh Entry/Exit.             |
|       |      |             | 1'b0 - Disabled                             |
|       |      |             | 1'b1 - Enabled                              |



| Bit   | Attr | Reset Value | Description                                 |
|-------|------|-------------|---------------------------------------------|
|       |      |             | dfi_lp_wakeup_pd                            |
|       |      |             | Value to drive on dfi_lp_wakeup signal when |
|       |      |             | Power Down mode is entered.                 |
|       |      |             | Determines the DFI's tlp_wakeup time:       |
|       |      |             | 4'b0000 - 16 cycles                         |
|       |      |             | 4'b0001 - 32 cycles                         |
|       |      |             | 4'b0010 - 64 cycles                         |
|       |      |             | 4'b0011 - 128 cycles                        |
|       |      |             | 4'b0100 - 256 cycles                        |
| 7:4   | RW   | 0×0         | 4'b0101 - 512 cycles                        |
| , . ¬ |      | OXO         | 4'b0110 - 1024 cycles                       |
|       |      |             | 4'b0111 - 2048 cycles                       |
|       |      |             | 4'b1000 - 4096 cycles                       |
|       |      |             | 4'b1001 - 8192 cycles                       |
|       |      |             | 4'b1010 - 16384 cycles                      |
|       |      |             | 4'b1011 - 32768 cycles                      |
|       |      |             | 4'b1100 - 65536 cycles                      |
|       |      |             | 4'b1101 - 131072 cycles                     |
|       |      |             | 4'b1110 - 262144 cycles                     |
|       |      |             | 4'b1111 - Unlimited                         |
| 3:1   | RO   | 0x0         | reserved                                    |
|       |      |             | dfi_lp_en_pd                                |
|       |      |             | Enables DFI Low Power interface handshaking |
| 0     | RW   | 0x0         | during Power Down Entry/Exit.               |
|       |      | . (         | 1'b0 - Disabled                             |
|       |      |             | 1'b1 - Enabled                              |

# DDR\_PCTL\_DFITRWRLVLRESP0

Address: Operational Base + offset (0x0300) DFI Training dfi wrlvl resp Status 0 Register

| Bit  | Attr | Reset Value | Description                                                            |
|------|------|-------------|------------------------------------------------------------------------|
| 31:0 | RO   | 0×00000000  | dfi_wrlvl_resp0 Reports the status of the dif_wrlvl_resp[31:0] signal. |

## DDR\_PCTL\_DFITRWRLVLRESP1

Address: Operational Base + offset (0x0304) DFI Training dfi\_wrlvl\_resp Status 1 Register

| Bit  | Attr | Reset Value | Description                   |
|------|------|-------------|-------------------------------|
|      |      |             | dfi_wrlvl_resp1               |
| 31:0 | RO   | 0x00000000  | Reports the status of the     |
|      |      |             | dif_wrlvl_resp[63:32] signal. |



## DDR\_PCTL\_DFITRWRLVLRESP2

Address: Operational Base + offset (0x0308)DFI Training dfi wrlvl resp Status 2 Register

| Bit  | Attr | Reset Value | Description                   |
|------|------|-------------|-------------------------------|
| 31:8 | RO   | 0x0         | reserved                      |
|      |      |             | dfi_wrlvl_resp2               |
| 7:0  | RO   | 0x00        | Reports the status of the     |
|      |      |             | dif_wrlvl_resp[71:64] signal. |

## DDR\_PCTL\_DFITRRDLVLRESP0

Address: Operational Base + offset (0x030c)DFI Training dfi\_rdlvl\_resp Status 0 Register

| Bit  | Attr | Reset Value | Description                                                            |
|------|------|-------------|------------------------------------------------------------------------|
| 31:0 | RO   |             | dfi_rdlvl_resp0 Reports the status of the dif_rdlvl_resp[31:0] signal. |

### DDR\_PCTL\_DFITRRDLVLRESP1

Address: Operational Base + offset (0x0310) DFI Training dfi rdlyl resp Status 1 Register

| Bit  | Attr | Reset Value | Description                   |
|------|------|-------------|-------------------------------|
|      |      |             | dfi_rdlvl_resp1               |
| 31:0 | RO   | 0x00000000  | Reports the status of the     |
|      |      |             | dif_rdlvl_resp[63:32] signal. |

#### DDR PCTL DFITRRDLVLRESP2

Address: Operational Base + offset (0x0314) DFI Training dfi\_rdlvl\_resp Status 2 Register

| Bit  | Attr | Reset Value | Description                                     |
|------|------|-------------|-------------------------------------------------|
| 31:8 | RO   | 0x0         | reserved                                        |
|      |      |             | dfi_rdlvl_resp2                                 |
| 7:0  | RO   | 0x00        | Reports the status of the dif_rdlvl_resp[71:64] |
|      | )    |             | signal.                                         |

# DDR\_PCTL\_DFITRWRLVLDELAY0

Address: Operational Base + offset (0x0318)

DFI Training dfi\_wrlvl\_delay Configuration 0 Register

| Bit  | Attr | Reset Value | Description                               |
|------|------|-------------|-------------------------------------------|
|      |      |             | dfi_wrlvl_delay0                          |
| 31:0 | RW   | 0x00000000  | Sets the value to be driven on the signal |
|      |      |             | dfi_wrlvl_delay_x[31:0].                  |



# DDR\_PCTL\_DFITRWRLVLDELAY1

Address: Operational Base + offset (0x031c)

DFI Training dfi wrlvl delay Configuration 1 Register

| Bit  | Attr | Reset Value | Description                               |
|------|------|-------------|-------------------------------------------|
|      |      |             | dfi_wrlvl_delay1                          |
| 31:0 | RW   | 0x00000000  | Sets the value to be driven on the signal |
|      |      |             | dfi_wrlvl_delay_x[63:32].                 |

#### DDR\_PCTL\_DFITRWRLVLDELAY2

Address: Operational Base + offset (0x0320)

DFI Training dfi\_wrlvl\_delay Configuration 2 Register

| Bit  | Attr | Reset Value | Description                               |
|------|------|-------------|-------------------------------------------|
| 31:8 | RO   | 0x0         | reserved                                  |
|      |      |             | dfi_wrlvl_delay2                          |
| 7:0  | RW   | 0x00        | Sets the value to be driven on the signal |
|      |      |             | dfi_wrlvl_delay_x[71:64].                 |

### DDR\_PCTL\_DFITRRDLVLDELAY0

Address: Operational Base + offset (0x0324)

DFI Training dfi\_rdlvl\_delay Configuration 0 Register

| Bit  | Attr | Reset Value | Description                               |
|------|------|-------------|-------------------------------------------|
|      |      |             | dfi_rdlvl_delay0                          |
| 31:0 | RW   | 0x00000000  | Sets the value to be driven on the signal |
|      |      |             | dfi_rdlvl_delay_x[31:0].                  |

#### DDR\_PCTL\_DFITRRDLVLDELAY1

Address: Operational Base + offset (0x0328)

DFI Training dfi rdlyl delay Configuration 1 Register

| Bit  | Attr | Reset Value | Description                               |
|------|------|-------------|-------------------------------------------|
|      |      |             | dfi_rdlvl_delay1                          |
| 31:0 | RW   | 0x00000000  | Sets the value to be driven on the signal |
|      |      | 7           | dfi_rdlvl_delay_x[63:32].                 |

#### DDR\_PCTL\_DFITRRDLVLDELAY2

Address: Operational Base + offset (0x032c)

DFI Training dfi\_rdlvl\_delay Configuration 2 Register

| Bit  | Attr | Reset Value | Description                               |
|------|------|-------------|-------------------------------------------|
| 31:8 | RO   | 0x0         | reserved                                  |
|      |      |             | dfi_rdlvl_delay2                          |
| 7:0  | RW   | 0x00        | Sets the value to be driven on the signal |
|      |      |             | dfi_rdlvl_delay_x[71:64].                 |

#### DDR\_PCTL\_DFITRRDLVLGATEDELAY0



Address: Operational Base + offset (0x0330)DFI Training dfi\_rdlvl\_gate\_delay Configuration 0

| Bit  | Attr | Reset Value | Description                               |
|------|------|-------------|-------------------------------------------|
|      |      |             | dfi_rdlvl_gate_delay0                     |
| 31:0 | RW   | 0x00000000  | Sets the value to be driven on the signal |
|      |      |             | dfi_rdlvl_gate_delay_x[31:0].             |

#### DDR\_PCTL\_DFITRRDLVLGATEDELAY1

Address: Operational Base + offset (0x0334)DFI Training dfi\_rdlvl\_gate\_delay Configuration 1

| Bit  | Attr | Reset Value | Description                               |
|------|------|-------------|-------------------------------------------|
|      |      |             | dfi_rdlvl_gate_delay1                     |
| 31:0 | RW   | 0x00000000  | Sets the value to be driven on the signal |
|      |      |             | dfi_rdlvl_gate_delay_x[63:32].            |

# DDR\_PCTL\_DFITRRDLVLGATEDELAY2

Address: Operational Base + offset (0x0338)DFI Training dfi\_rdlvl\_gate\_delay Configuration 2

| Bit  | Attr | Reset Value | Description                               |
|------|------|-------------|-------------------------------------------|
| 31:8 | RO   | 0x0         | reserved                                  |
|      |      |             | dfi_rdlvl_gate_delay2                     |
| 7:0  | RW   | 0x00        | Sets the value to be driven on the signal |
|      |      |             | dfi_rdlvl_gate_delay_x[71:64].            |

#### DDR\_PCTL\_DFITRCMD

Address: Operational Base + offset (0x033c)

DFI Training Command Register

| Bit   | Attr  | Reset Value | Description                                       |
|-------|-------|-------------|---------------------------------------------------|
|       |       |             | dfitrcmd_start                                    |
|       | 11    |             | DFI Training Command Start. When this bit is      |
|       | 63    |             | set to 1, the command operation defined in        |
| /     |       |             | the dfitrcmd_opcode field is started. This bit is |
| 31    | R/WSC | 0x0         | automatically cleared by the PCTL after the       |
|       |       |             | command is finished. The application can poll     |
| 7     |       |             | this bit to determine when PCTL is ready to       |
|       |       |             | accept another command. This bit cannot be        |
|       |       |             | cleared to 1b0 by software.                       |
| 30:13 | RO    | 0x0         | reserved                                          |
|       |       |             | dfitrcmd_en                                       |
| 12:4  | RW    | 0×000       | DFI Training Command Enable. Selects which        |
| 12.4  | KVV   | 0000        | bits of chosen DFI Training command to drive      |
|       |       |             | to 1'b1.                                          |
| 3:2   | RO    | 0x0         | reserved                                          |



| Bit | Attr | Reset Value | Description                               |
|-----|------|-------------|-------------------------------------------|
|     |      | 0×0         | dfitrcmd_opcode                           |
|     |      |             | DFI Training Command Opcode. Select which |
|     | RW   |             | DFI Training command to generate for one  |
| 1:0 |      |             | n_clk cycle:                              |
| 1:0 |      |             | 2'b00 - dfi_wrlvl_load                    |
|     |      |             | 2'b01 - dfi_wrlvl_strobe                  |
|     |      |             | 2'b10 - dfi_rdlvl_load                    |
|     |      |             | 2'b11 - Reserved.                         |

## DDR\_PCTL\_IPVR

Address: Operational Base + offset (0x03f8)

IP Version Register

| Bit  | Attr | Reset Value | Description                                                             |
|------|------|-------------|-------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | ip_version ASCII value for each number in the version, followed by a *. |

# DDR\_PCTL\_IPTR

Address: Operational Base + offset (0x03fc)

IP Type Register

| Bit  | Attr | Reset Value | Description                                     |
|------|------|-------------|-------------------------------------------------|
|      |      |             | ip_type                                         |
|      |      |             | Contains the IP's identification code, which is |
| 31:0 | RO   | 0x44574300  | an ASCII value to identify the component and    |
|      |      | • 0         | it is currently set to the string "DWC". This   |
|      |      |             | value never changes.                            |

# DDR\_PHYCTL\_RIDR

Address: Operational Base + offset (0x0000)

Revision Identification Register

| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
|       |      |             | UDRID                                         |
| 31:24 | RO   | 0x00        | User-Defined Revision ID: General purpose     |
|       |      |             | revision identification set by the user.      |
|       |      |             | PHYMJR                                        |
|       |      |             | PHY Major Revision: Indicates major revision  |
| 23:20 | RO   | 0x1         | of the PHY such addition of the features that |
|       |      |             | make the new version not compatible with      |
|       |      |             | previous versions.                            |



| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
|       |      |             | PHYMDR                                        |
|       |      |             | PHY Moderate Revision: Indicates moderate     |
| 19:16 | RO   | 0x0         | revision of the PHY such as addition of new   |
|       |      |             | features. Normally the new version is still   |
|       |      |             | compatible with previous versions.            |
|       |      |             | PHYMNR                                        |
| 15:12 | RO   | 0x0         | PHY Minor Revision: Indicates minor update of |
| 15.12 |      | 0.00        | the PHY such as bug fixes. Normally no new    |
|       |      |             | features are included.                        |
|       |      |             | PUBMJR                                        |
|       | RO   | 0×1         | PUB Major Revision: Indicates major revision  |
| 11:8  |      |             | of the PUB such addition of the features that |
|       |      |             | make the new version not compatible with      |
|       |      |             | previous versions.                            |
|       |      |             | PUBMDR                                        |
|       |      |             | PUB Moderate Revision: Indicates moderate     |
| 7:4   | RO   | 0x4         | revision of the PUB such as addition of new   |
|       |      |             | features. Normally the new version is still   |
|       |      |             | compatible with previous versions.            |
|       | RO   | 0×0         | PUBMNR                                        |
| 3:0   |      |             | PUB Minor Revision: Indicates minor update of |
|       |      |             | the PUB such as bug fixes. Normally no new    |
|       |      |             | features are included.                        |

# DDR\_PHYCTL\_PIR

Address: Operational Base + offset (0x0004) PHY Initialization Register

|     | PHY Initialization Register |             |                                                   |  |  |
|-----|-----------------------------|-------------|---------------------------------------------------|--|--|
| Bit | Attr                        | Reset Value | Description                                       |  |  |
|     | 11                          |             | INITBYP                                           |  |  |
|     | 63                          |             | Initialization Bypass: Bypasses or stops, if set, |  |  |
|     |                             |             | all initialization routines currently running,    |  |  |
| 31  | R/WSC                       | 0×0         | including PHY initialization, DRAM                |  |  |
| 31  | Ny WSC                      | UXU         | initialization, and PHY training. Initialization  |  |  |
| Y   |                             |             | may be triggered manually using INIT and the      |  |  |
|     |                             |             | other relevant bits of the PIR register. This bit |  |  |
|     |                             |             | is self-clearing.                                 |  |  |
|     |                             |             | ZCALBYP                                           |  |  |
|     | R/WSC                       | SC 0x0      | Impedance Calibration Bypass: Bypasses or         |  |  |
|     |                             |             | stops, if set, impedance calibration of all ZQ    |  |  |
| 30  |                             |             | control blocks that automatically triggers after  |  |  |
|     |                             |             | reset. Impedance calibration may be               |  |  |
|     |                             |             | triggered manually using INIT and ZCAL bits       |  |  |
|     |                             |             | of the PIR register. This bit is self-clearing.   |  |  |



| Bit      | Attr     | Reset Value                           | Description                                        |
|----------|----------|---------------------------------------|----------------------------------------------------|
|          |          |                                       | LOCKBYP                                            |
|          |          |                                       | DLL Lock Bypass: Bypasses or stops, if set,        |
|          |          |                                       | the waiting of DLLs to lock. DLL lock wait is      |
| 29       | R/WSC    | 0x0                                   | automatically triggers after reset. DLL lock       |
|          |          |                                       | wait may be triggered manually using INIT          |
|          |          |                                       | and DLLLOCK bits of the PIR register. This bit     |
|          |          |                                       | is self-clearing.                                  |
|          |          |                                       | CLRSR                                              |
|          |          |                                       | Clear Status Registers: A write of '1' to this bit |
|          |          |                                       | will clear (reset to '0' all status registers,     |
|          |          |                                       | including PGSR and DXnGSR. The clear status        |
|          |          |                                       | register bit is self-clearing.                     |
|          |          |                                       | This bit is primarily for debug purposes and is    |
|          |          |                                       | typically not needed during normal functional      |
| 28       | R/WSC    | 0x0                                   | operation. It can be used when                     |
|          |          |                                       | PGSR.IDONE=1, to manually clear the PGSR           |
|          |          |                                       | status bits, although starting a new init          |
|          |          |                                       | process will automatically clear the PGSR          |
|          |          |                                       | status bits. Or it can be used to manually         |
|          |          |                                       | clear the DXnGSR status bits, although             |
|          |          |                                       | starting a new data training process will          |
|          |          |                                       | automatically clear the DXnGSR status bits.        |
| 27:19    | RO       | 0x0                                   | reserved                                           |
|          |          |                                       | CTLDINIT                                           |
|          |          | • 0                                   | Controller DRAM Initialization: Indicates if set   |
|          |          | ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ | that DRAM initialization will be performed by      |
| 18       | RW       | 0x0                                   | the controller. Otherwise if not set it indicates  |
|          |          |                                       | that DRAM initialization will be performed         |
|          | 11       |                                       | using the built-in initialization sequence or      |
|          |          |                                       | using software through the configuration port.     |
| /        |          |                                       | DLLBYP                                             |
| 17       | RW       | 0×0                                   | DLL Bypass: A setting of 1 on this bit will put    |
|          | <b>Y</b> |                                       | all PHY DLLs in bypass mode. A bypassed DLL        |
| <b>y</b> |          |                                       | is also powered down (disabled).                   |



| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16   | RW   | 0×0         | ICPC Initialization Complete Pin Configuration: Specifies how the DFI 2.1 initialization complete output pin should be used to indicate the status of initialization. Valid value are: 0 = Asserted after PHY initialization (DLL locking and impedance calibration) is complete. 1 = Asserted after PHY initialization is complete and the triggered the PHYCTL initialization (DRAM initialization, data training, or initialization trigger with no selected initialization) is complete. |
| 15:9 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 8    | RW   | 0×0         | EYETRN Read Data Eye Training: Executes a PHYCTL training routine to maximize the read data eye. This is not implemented in this version of the PHYCTL.                                                                                                                                                                                                                                                                                                                                      |
| 7    | RW   | 0x0         | QSTRN Read DQS Training: Executes a PHYCTL training routine to determine the optimum position of the read data DQS strobe for maximum system timing margins.                                                                                                                                                                                                                                                                                                                                 |
| 6    | RW   | 0×0         | DRAMINIT DRAM Initialization: Executes the DRAM initialization sequence.                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 5    | RW   | 0×0         | DRAMRST DRAM Reset (DDR3 Only): Issues a reset to the DRAM (by driving the DRAM reset pin low) and wait 200us. This can be triggered in isolation or with the full DRAM initialization (DRAMINIT). For the later case, the reset is issued and 200us is waited before starting the full initialization sequence.                                                                                                                                                                             |
| 4    | RW   | 0x0         | ITMSRST Interface Timing Module Soft Reset: Soft resets the interface timing modules for the data and data strobes, i.e., it asserts the ITM soft reset (srstb) signal.                                                                                                                                                                                                                                                                                                                      |



| Bit | Attr | Reset Value | Description                                         |
|-----|------|-------------|-----------------------------------------------------|
|     |      |             | ZCAL                                                |
| 3   | RW   | 0x0         | Impedance Calibrate: Performs PHY                   |
|     |      |             | impedance calibration.                              |
| 2   | RW   | 0x0         | DLLLOCK                                             |
| 2   | KVV  | UXU         | DLL Lock: Waits for the PHY DLLs to lock.           |
|     |      |             | DLLSRST                                             |
| 1   | RW   | 0x0         | DLL Soft Rest: Soft resets all PHY DLLs by          |
|     |      |             | driving the DLL soft reset pin.                     |
|     |      | 0x0         | INIT                                                |
|     |      |             | Initialization Trigger: A write of '1' to this bit  |
|     |      |             | triggers the DDR system initialization,             |
|     |      |             | including PHY initialization, DRAM                  |
| 0   | RW   |             | initialization, and PHY training. The exact         |
| ا   | L VV |             | initialization steps to be executes are specified   |
|     |      |             | in bits 1 to 6 of this register. A bit setting of 1 |
|     |      |             | means the step will be executed as part of the      |
|     |      |             | initialization sequence, while a setting of         |
|     |      |             | □initialization) is complete.                       |

# DDR\_PHYCTL\_PGCR

Address: Operational Base + offset (0x0008)

PHY General Configuration Register

| Bit | Attr     | Reset Value | Description                                    |
|-----|----------|-------------|------------------------------------------------|
|     |          |             | LBMODE                                         |
| 31  | RW       | 0x0         | Loopback Mode: Indicates if set that the       |
|     |          | . ~ >       | PHY/PUB is in loopback mode                    |
|     |          |             | LBGDQS                                         |
|     |          |             | Loopback DQS Gating: Selects the DQS gating    |
|     |          |             | mode that should be used when the PHY is in    |
| 30  | RW       | 0×0         | loopback mode, including BIST loopback         |
|     |          |             | mode. Valid values are:                        |
| 2   | $\cup$   |             | 0 = DQS gate training will be triggered on the |
|     | <b>Y</b> |             | PUB                                            |
| ,   |          |             | 1 = DQS gate is set manually using software    |
|     |          |             | LBDQSS                                         |
|     |          |             | Loopback DQS Shift: Selects how the read       |
|     |          |             | DQS is shifted during loopback to ensure that  |
|     | RW       | RW 0x0      | the read DQS is centered into the read data    |
| 29  |          |             | eye. Valid values are:                         |
|     |          |             | 0 = PUB sets the read DQS delay to 0; DQS is   |
|     |          |             | already shifted 90 degrees by write path       |
|     |          |             | 1 = The read DQS shift is set manually through |
|     |          |             | software                                       |



| Bit   | Attr | Reset Value | Description                                       |
|-------|------|-------------|---------------------------------------------------|
|       |      |             | RFSHDT                                            |
|       |      |             | Refresh During Training: A non-zero value         |
| 20.25 | DVA  |             | specifies that a burst of refreshes equal to the  |
| 28:25 | RW   | 0x0         | number specified in this field should be sent to  |
|       |      |             | the SDRAM after training each rank except the     |
|       |      |             | last rank.                                        |
|       |      |             | PDDISDX                                           |
| 24    | DW   | 01          | Power Down Disabled Byte: Indicates if set        |
| 24    | RW   | 0x1         | that the DLL and I/Os of a disabled byte should   |
|       |      |             | be powered down.                                  |
|       |      |             | ZCKSEL                                            |
|       |      |             | Impedance Clock Divider Select: Selects the       |
|       |      |             | divide ratio for the clock used by the            |
|       |      |             | impedance control logic relative to the clock     |
| 22.22 | DW   | 0.42        | used by the memory controller and SDRAM.          |
| 23:22 | RW   | 0x2         | Valid values are:                                 |
|       |      |             | 00 = Divide by 2                                  |
|       |      |             | 01 = Divide by 8                                  |
|       |      |             | 10 = Divide by 32                                 |
|       |      |             | 11 = Divide by 64                                 |
|       |      |             | RANKEN                                            |
|       |      |             | Rank Enable: Specifies the ranks that are         |
|       |      |             | enabled for data-training. Bit 0 controls rank    |
| 21:18 | RW   | 0xf         | 0, bit 1 controls rank 1, bit 2 controls rank 2,  |
|       |      |             | and bit 3 controls rank 3. Setting the bit to '0' |
|       |      |             | enables the rank, and setting it to '1' disables  |
|       |      | Y           | the rank.                                         |
|       |      |             | IODDRM                                            |
| 17:16 | RW   | 0x0         | I/O DDR Mode (D3F I/O Only): Selects the          |
|       | N    | 7           | DDR mode for the I/Os.                            |
|       |      |             | IOLB                                              |
|       |      |             | I/O Loop-Back Select: Selects where inside        |
|       | ,    |             | the I/O the loop-back of signals happens. Valid   |
| 15    | RW   | 0×0         | values are:                                       |
| 15    | 1244 | 0x0         | 0 = Loopback is after output buffer; output       |
|       |      |             | enable must be asserted                           |
|       |      |             | 1 = Loopback is before output buffer; output      |
|       |      |             | enable is don't care                              |
|       |      |             | CKINV                                             |
| 14    | RW   | 0×0         | CK Invert: Specifies if set that CK/CK# should    |
|       |      |             | be inverted. Otherwise CK/CK# toggles with        |
|       |      |             | normal polarity.                                  |



| Bit   | Attr | Reset Value | Description                                         |
|-------|------|-------------|-----------------------------------------------------|
|       |      |             | CKDV                                                |
|       |      |             | CK Disable Value: Specifies the static value        |
| 12.12 | DW   | 0.42        | that should be driven on CK/CK# pair(s) when        |
| 13:12 | RW   | 0x2         | the pair(s) is disabled. CKDV[0] specifies the      |
|       |      |             | value for CK and CKDV[1] specifies the value        |
|       |      |             | for CK#                                             |
|       |      |             | CKEN                                                |
|       |      |             | CK Enable: Controls whether the CK going to         |
| 11:9  | RW   | 0x7         | the SDRAM is enabled (toggling) or disabled         |
|       |      |             | (static value defined by CKDV). One bit for         |
|       |      |             | each of the three CK pairs.                         |
|       |      |             | DTOSEL                                              |
|       |      |             | Digital Test Output Select: Selects the PHY         |
|       |      |             | digital test output that should be driven onto      |
|       |      |             | PHY digital test output (phy_dto) pin: Valid        |
|       |      |             | values are:                                         |
|       |      |             | 0000 = DATX8 0 DLL digital test output              |
|       |      |             | 0001 = DATX8 1 DLL digital test output              |
| 0.5   | DW   | 0.40        | 0010 = DATX8 2 DLL digital test output              |
| 8:5   | RW   | 0x0         | 0011 = DATX8 3 DLL digital test output              |
|       |      |             | 0100 = DATX8 4 DLL digital test output              |
|       |      |             | 0101 = DATX8 5 DLL digital test output              |
|       |      |             | 0110 = DATX8 6 DLL digital test output              |
|       |      |             | 0111 = DATX8 7 DLL digital test output              |
|       |      |             | 1000 = DATX8 8 DLL digital test output              |
|       |      |             | 1001 = AC DLL digital test output                   |
|       |      | V Y         | 1010 - 01111 = Reserved                             |
|       |      |             | DFTLMT                                              |
|       | 41   |             | DQS Drift Limit: Specifies the expected limit of    |
|       |      | 7           | drift on read data strobes. A drift of this value   |
|       |      |             | or greater is reported as a drift error through     |
|       |      |             | the host port error flag. Valid values are:         |
|       |      |             | 00 = No limit (no error reported)                   |
| 4:3   | RW   | 0x0         | 01 = 90 deg drift                                   |
|       |      |             | 10 = 180 deg drift                                  |
|       |      |             | 11 = 270 deg or more drift                          |
|       |      |             | Note: Although reported through the error           |
|       |      |             | flag, this is not an error requiring any            |
|       |      |             | action. It is simply an indicator that the drift is |
|       |      |             | greater than expected.                              |



| Bit | Attr   | Reset Value | Description                                   |
|-----|--------|-------------|-----------------------------------------------|
|     |        |             | DFTCMP                                        |
|     |        |             | DQS Drift Compensation: Enables or disables   |
|     |        |             | DQS drift compensation. Valid values are:     |
| 2   | RW     | 0×1         | 0 = Disables data strobe drift compensation   |
| 2   | IX V V | OXI         | 1 = Enables data strobe drift compensation    |
|     |        |             | By default, drift compensation is enabled.    |
|     |        |             | Note: Drift compensation must be disabled for |
|     |        |             | LPDDR2.                                       |
|     |        |             | DQSCFG                                        |
|     |        | 0x0         | DQS Gating Configuration: Selects one of the  |
|     |        |             | two DQS gating schemes:                       |
|     |        |             | 0 = DQS gating is shut off using the rising   |
| 1   | RW     |             | edge of DQS_b (active windowing mode)         |
|     |        |             | 1 = DQS gating blankets the whole burst       |
|     |        |             | (passive windowing mode).                     |
|     |        |             | Note: Passive windowing must be used for      |
|     |        |             | LPDDR2.                                       |
|     |        | N 0×0       | ITMDMD                                        |
|     |        |             | ITM DDR Mode: Selects whether ITMS uses       |
| 0   |        |             | DQS and DQS# or it only uses DQS.             |
|     | RW     |             | Valid values are:                             |
|     |        |             | 0 = ITMS uses DQS and DQS#                    |
|     |        |             | 1 = ITMS uses DQS only                        |
|     |        |             | Note: The only valid value for DDR is 1.      |

# DDR\_PHYCTL\_PGSR

Address: Operational Base + offset (0x000c)

PHY General Status Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                     |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | RO   | 0×0         | TQ Temperature Output (LPDDR Only): Connected to the DRAM TQ pin which is defined to go high when the LPDDR device temperature equals to or exceeds 85C, otherwise it is low.                   |
| 30:8 | RO   | 0x0         | reserved                                                                                                                                                                                        |
| 7    | RO   | 0x0         | DFTERR DQS Drift Error: If set, indicates that at least one of the read data strobes has drifted by more than or equal to the drift limit set in the PHY General Configuration Register (PGCR). |



| Bit | Attr | Reset Value | Description                                      |
|-----|------|-------------|--------------------------------------------------|
|     |      |             | DTIERR                                           |
|     |      |             | Data Training Intermittent Error: If set,        |
| 6   | RO   | 0×0         | indicates that there was an intermittent error   |
| 0   | KO   | UXU         | during data training, such as a pass was         |
|     |      |             | followed by a fail then followed by another      |
|     |      |             | pass.                                            |
|     |      |             | DTERR                                            |
| 5   | RO   | 0×0         | Data Training Error: If set, indicates that a    |
| 3   | KO   | UXU         | valid DQS gating window could not be found       |
|     |      |             | during data training.                            |
|     |      |             | DTDONE                                           |
| 4   | RO   | 0x0         | Data Training Done: Indicates, if set, that the  |
|     |      |             | PHY has finished doing data training.            |
|     |      |             | DIDONE                                           |
| 3   | RO   | 0x0         | DRAM Initialization Done: Indicates if set that  |
|     |      |             | DRAM initialization has completed.               |
|     |      |             | ZCDONE                                           |
| 2   | RO   | 0x0         | Impedance Calibration Done: Indicates if set     |
|     |      |             | that impedance calibration has completed.        |
|     |      |             | DLDONE                                           |
| 1   | RO   | 0x0         | DLL Lock Done: Indicates if set that DLL         |
|     |      |             | locking has completed.                           |
|     |      |             | IDONE                                            |
|     |      |             | Initialization Done: Indicates if set that the   |
| 0   | RO   | RO 0x0      | DDR system initialization has completed. This    |
|     |      |             | bit is set after all the selected initialization |
|     |      |             | routines in PIR register have completed.         |

# DDR\_PHYCTL\_DLLGCR

Address: Operational Base + offset (0x0010)

**DLL General Control Register** 

| Bit   | Attr | Reset Value | Description                                     |
|-------|------|-------------|-------------------------------------------------|
| 31:30 | RO   | 0x0         | reserved                                        |
| 29    | DW   | 0x0         | LOCKDET                                         |
| 29    | RW   |             | Master lock detector enable.                    |
| 28    | RO   | 0x0         | reserved                                        |
|       |      |             | SBIAS                                           |
| 27:20 | RW   | 0x37        | Slave Bias Trim: Used to trim the bias for the  |
|       |      |             | slave DLL.                                      |
|       |      |             | MBIAS                                           |
| 19:12 | RW   | 0x37        | Master Bias Trim: Used to trim the bias for the |
|       |      |             | master DLL.                                     |

| Bit  | Attr | Reset Value | Description                                     |
|------|------|-------------|-------------------------------------------------|
|      |      |             | TESTSW                                          |
| 11   | RW   | 0x0         | Test Switch: Selects the test signals of either |
|      |      |             | the master DLL ('0') or the slave DLL ('1').    |
|      |      |             | ATC                                             |
|      |      |             | Analog Test Control: Selects the analog signal  |
|      |      |             | to be output on the DLL analog test output      |
|      |      | 0×0         | (test_out_a) when TESTEN is high (Output is     |
|      |      |             | Vss when TESTEN is low). The test output        |
|      |      |             | either comes from the master DLL or the slave   |
| 10:9 | RW   |             | DLL, depending on the setting of the test       |
|      | KVV  |             | switch (TESTSW). Both master DLL and slave      |
|      |      |             | DLL output similar analog test signals. Valid   |
|      |      |             | settings for analog test control are:           |
|      |      |             | 00 = Filter output (Vc)                         |
|      |      |             | 01 = Replica bias output for NMOS (Vbn)         |
|      |      |             | 10 = Replica bias output for PMOS (Vbp)         |
|      |      |             | 11 = Vdd 00                                     |



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | DTC Digital Test Control: Selects the digital signal to be output on the DLL digital test output (test_out_d[1]) when TESTEN is high (Output is '0' when TESTEN is low).                                                                                                                                                                                                                                                                                                                                                                                   |
| 8:6 | RW   | 0×0         | Valid settings for master DLL (such as, when TESTSW = '0'):  000 = 0 output clock (clk_0)  001 = 90 output clock (clk_90)  010 = 180 output clock (clk_180)  011 = 270 output clock (clk_270)  100 = 360 internal clock (clk_360_int)  101 = Speed-up pulse (spdup)  110 = Slow-down pulse (slwdn)  111 = 0 MCTL logic clock (cclk_0)  Valid settings for slave DLL (such as when TESTSW = '1'):  000 = Input DQS strobe (dqs)  001 = Input clock reference (clk_90_in)  010 = Internal feedback clock (clk_0_out)  011 = 90 output DQS_b strobe (dqsb_90) |
|     |      | 17          | 100 = 90 output DQS strobe (dqs_90)<br>101 = Speed-up pulse (spdup)<br>110 = Slow-down pulse (slwdn)<br>111 = Auto-lock enable signal                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 5   | RW   | 0×0         | TESTEN Test Enable: Enables digital and analog test outputs selected by DTC and ATC respectively.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 4:2 | RW   | 0x0         | IPUMP Charge Pump Current Trim: Used to trim charge pump current: 000 = maximum current 111 = minimum current                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 1:0 | RW   | 0x0         | DRES Delta Resistor Trim: Used to trim reference current versus resistor value variation: $00 = \text{Rnom}$ $01 = \text{Rnom} - 20\%$ $1x = \text{Rnom} + 20\%$                                                                                                                                                                                                                                                                                                                                                                                           |



Address: Operational Base + offset (0x0014)

AC DLL Control Register

| AC DLL ( | Attr | Reset Value | Description                                      |
|----------|------|-------------|--------------------------------------------------|
| _        |      |             | DLLDIS                                           |
| 31       | RW   | 0×0         | DLL Disable: A disabled DLL is bypassed.         |
|          |      |             | Default ('0') is DLL enabled.                    |
|          |      |             | DLLSRST                                          |
| 30       | RW   | 0x1         | DLL Soft Rest: Soft resets the AC DLL by         |
|          |      |             | driving the DLL soft reset pin.                  |
| 29:20    | RO   | 0x0         | reserved                                         |
|          |      |             | SDLBMODE                                         |
|          |      |             | Slave DLL Loopback Mode: If this bit is set, the |
|          |      |             | slave DLL is put in loopback mode in which       |
| 19       | RW   | 0x0         | there is no 90 degrees phase shift on read       |
|          |      |             | DQS/DQS#. This bit must be set when              |
|          |      |             | operating the byte PHYs in loopback mode         |
|          |      |             | such as during BIST loopback.                    |
|          |      |             | ATESTEN                                          |
|          |      |             | Analog Test Enable: Enables the analog test      |
| 18       | RW   | 0x0         | signal to be output on the DLL analog test       |
|          |      |             | output (test_out_a). The DLL analog test         |
|          |      |             | output is tri-stated when this bit is '0'.       |
|          |      |             | SDPHASE                                          |
|          |      |             | Slave DLL Phase Trim: Selects the phase          |
|          |      |             | difference between the input clock and the       |
|          |      | · ~ ~       | corresponding output clock of the slave DLL.     |
|          |      | 10 7        | Valid settings:                                  |
|          |      |             | 0000 = 90                                        |
|          |      | 0,          | 0001 = 72                                        |
|          |      | -           | 0010 = 54                                        |
|          |      | /           | 0011 = 36                                        |
|          |      |             | 0100 = 108                                       |
| 17:14    | RW   | 0x0         | 0101 = 90                                        |
|          |      |             | 0110 = 72                                        |
|          |      |             | 0111 = 54                                        |
|          |      |             | 1000 = 126                                       |
|          |      |             | 1001 = 108                                       |
|          |      |             | 1010 = 90                                        |
|          |      |             | 1011 = 72                                        |
|          |      |             | 1100 = 144                                       |
|          |      |             | 1101 = 126                                       |
|          |      |             | 1110 = 108                                       |
|          |      |             | 1111 = 90                                        |



| Bit   | Attr | Reset Value | Description                                    |
|-------|------|-------------|------------------------------------------------|
|       |      |             | SSTART                                         |
|       |      |             | Slave Auto Start-Up: Used to control how the   |
|       |      |             | slave DLL starts up relative to the master DLL |
|       |      |             | locking:                                       |
| 13:12 | RW   | 0×0         | 0X = Slave DLL automatically starts up once    |
| 13.12 | IXVV | 0.00        | the master DLL has achieved lock.              |
|       |      |             | 10 = The automatic startup of the slave DLL is |
|       |      |             | disabled; the phase detector is disabled.      |
|       |      |             | 11 = The automatic startup of the slave DLL is |
|       |      |             | disabled; the phase detector is enabled.       |
|       |      |             | MFWDLY                                         |
|       |      |             | Master Feed-Forward Delay Trim: Used to trim   |
| 11:9  | RW   | 0×0         | the delay in the master DLL feed-forward       |
| 11:9  | RW   |             | path:                                          |
|       |      |             | 000 = minimum delay                            |
|       |      |             | 111 = maximum delay                            |
|       |      |             | MFBDLY                                         |
|       |      |             | Master Feed-Back Delay Trim: Used to trim      |
| 8:6   | RW   | 0x0         | the delay in the master DLL feedback path:     |
|       |      |             | 000 = minimum delay                            |
|       |      |             | 111 = maximum delay                            |
|       |      |             | SFWDLY                                         |
|       |      |             | Slave Feed-Forward Delay Trim: Used to trim    |
| 5:3   | RW   | 0x0         | the delay in the slave DLL feed-forward path:  |
|       |      | . 0         | 000 = minimum delay                            |
|       |      |             | 111 = maximum delay                            |
|       |      | VO y        | SFBDLY                                         |
|       |      |             | Slave Feed-Back Delay Trim: Used to trim the   |
| 2:0   | RW   | 0x0         | delay in the slave DLL feedback path:          |
|       | N    | 7           | 000 = minimum delay                            |
|       |      |             | 111 = maximum delay                            |

# DDR\_PHYCTL\_PTR0

Address: Operational Base + offset (0x0018)

PHY Timing Register 0

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:22 | RO   | 0x0         | reserved    |



| Bit   | Attr | Reset Value | Description                                      |
|-------|------|-------------|--------------------------------------------------|
|       |      |             | tITMSRST                                         |
|       |      |             | ITM Soft Reset Time: Number of controller        |
|       |      |             | clock cycles that the ITM soft reset pin must    |
| 21:18 | RW   | 0x8         | remain asserted when the soft reset is applied   |
| 21:10 | KVV  | UXO         | to the ITMs. This must correspond to a value     |
|       |      |             | that is equal to or more than 8 controller clock |
|       |      |             | cycles. Default value corresponds to 8           |
|       |      |             | controller clock cycles.                         |
|       |      |             | tDLLLOCK                                         |
|       |      |             | DLL Lock Time: Number of clock cycles for the    |
|       |      | 0xabe       | DLL to stabilize and lock, i.e. number of clock  |
| 17.6  | RW   |             | cycles from when the DLL reset pin is            |
| 17:6  |      |             | de-asserted to when the DLL has locked and is    |
|       |      |             | ready for use. Refer to the PHY databook for     |
|       |      |             | the DLL lock time. Default value corresponds     |
|       |      |             | to 5.12us at 533MHz.                             |
|       |      |             | tDLLSRST                                         |
|       |      |             | DLL Soft Reset Time: Number of controller        |
|       |      |             | clock cycles that the DLL soft reset pin must    |
|       |      |             | remain asserted when the soft reset is           |
| 5:0   | RW   | 0x1b        | triggered through the PHY Initialization         |
|       |      |             | Register (PIR). This must correspond to a        |
|       |      |             | value that is equal to or more than 50ns or 8    |
|       |      |             | controller clock cycles, whichever is bigger.    |
|       |      |             | Default value corresponds to 50ns at 533MHz.     |

# DDR\_PHYCTL\_PTR1

Address: Operational Base + offset (0x001c)

PHY Timing Register 1

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:27 | RO   | 0x0         | reserved    |



| Bit   | Attr | Reset Value | Description                                            |
|-------|------|-------------|--------------------------------------------------------|
|       |      |             | tDINIT1                                                |
|       |      |             | DRAM Initialization Time 1: DRAM                       |
|       |      |             | initialization time corresponding to the               |
|       |      |             | following:                                             |
|       |      |             | DDR3 = CKE high time to first command (tRFC            |
|       |      |             | +10 ns or 5 tCK, whichever value is larger)            |
| 26:19 | RW   | 0xc0        | DDR2 = CKE high time to first command (400             |
|       |      |             | ns)                                                    |
|       |      |             | DDR = CKE high time to first command (400 ns or 1 tCK) |
|       |      |             | LPDDR2 = CKE low time with power and clock             |
|       |      |             | stable (100 ns)                                        |
|       |      |             | Default value corresponds to DDR3 360ns at             |
|       |      |             | 533MHz.                                                |
|       |      |             | tDINIT0                                                |
|       |      |             | DRAM Initialization Time 0: DRAM                       |
|       |      |             | initialization time corresponding to the               |
|       |      |             | following:                                             |
|       |      |             | DDR3 = CKE low time with power and clock               |
|       |      |             | stable (500 us)                                        |
|       | RW   | W 0x4111d   | DDR2 = CKE low time with power and clock               |
| 18:0  |      |             | stable (200 us)                                        |
|       |      |             | DDR = CKE low time with power and clock                |
|       |      |             | stable (200 us)                                        |
|       |      | . ()        | LPDDR = CKE high time to first command                 |
|       |      | 1           | (200 us)                                               |
|       |      |             | LPDDR2 = CKE high time to first command                |
|       |      | ()          | (200 us)                                               |
|       | 11   |             | Default value corresponds to DDR3 500 us at            |
|       |      | 7           | 533MHz.                                                |

# DDR\_PHYCTL\_PTR2

Address: Operational Base + offset (0x0020)

PHY Timing Register 2

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:27 | RO   | 0x0         | reserved    |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 26:17 | RW   | 0x216       | tDINIT3 DRAM Initialization Time 3: DRAM initialization time corresponding to the following: LPDDR2 = Time from ZQ initialization command to first command (1 us) Default value corresponds to the LPDDR2 1 us at 533MHz.                                                                                  |
| 16:0  | RW   | 0x1a072     | tDINIT2 DRAM Initialization Time 2: DRAM initialization time corresponding to the following: DDR3 = Reset low time (200 us on power-up or 100 ns after power-up) LPDDR2 = Time from reset command to end of auto initialization (1 us + 10 us = 11 us) Default value corresponds to DDR3 200 us at 533MHz. |

# DDR\_PHYCTL\_ACIOCR

Address: Operational Base + offset (0x0024)

AC I/O Configuration Register

| Bit   | Attr | Reset Value | Description                                      |
|-------|------|-------------|--------------------------------------------------|
|       |      |             | ACSR                                             |
|       |      | . ()        | Address/Command Slew Rate (D3F I/O Only):        |
| 31:30 | RW   | 0x0         | Selects slew rate of the I/O for all address and |
|       |      |             | command pins, as well as the optional DIMM       |
|       |      |             | PAR_IN pin and LPDDR TPD pin.                    |
|       | 11   |             | RSTIOM                                           |
| 29    | RW   | 0×1         | SDRAM Reset I/O Mode: Selects SSTL mode          |
| 29    | RW   |             | (when set to 0) or CMOS mode (when set to 1)     |
|       |      |             | of the I/O for SDRAM Reset.                      |
|       | -    |             | RSTPDR                                           |
| 28    | RW   | RW 0x1      | SDRAM Reset Power Down Receiver: Powers          |
| 20    |      |             | down, when set, the input receiver on the I/O    |
|       |      |             | for SDRAM RST# pin.                              |
|       | RW   | W 0×0       | RSTPDD                                           |
| 27    |      |             | SDRAM Reset Power Down Driver: Powers            |
|       |      |             | down, when set, the output driver on the I/O     |
|       |      |             | for SDRAM RST# pin.                              |



| Bit   | Attr  | Reset Value | Description                                     |
|-------|-------|-------------|-------------------------------------------------|
|       |       |             | RSTODT                                          |
| 26    | DW    | 0.40        | SDRAM Reset On-Die Termination: Enables,        |
| 26    | RW    | 0x0         | when set, the on-die termination on the I/O for |
|       |       |             | SDRAM RST# pin.                                 |
|       |       |             | RANKPDR                                         |
|       |       |             | Rank Power Down Receiver: Powers down,          |
|       |       |             | when set, the input receiver on the I/O         |
| 25.22 | DW    | Ove         | CKE[3:0], ODT[3:0], and CS#[3:0] pins.          |
| 25:22 | RW    | 0xf         | RANKPDR[0] controls the power down for          |
|       |       |             | CKE[0], ODT[0], and CS#[0], RANKPDR[1]          |
|       |       |             | controls the power down for CKE[1], ODT[1],     |
|       |       |             | and CS#[1], and so on.                          |
|       |       |             | CSPDD                                           |
|       |       |             | CS# Power Down Driver: Powers down, when        |
|       |       |             | set, the output driver on the I/O for CS#[3:0]  |
| 21:18 | RW    | 0×0         | pins. PDD[0] controls the power down for        |
|       |       |             | CS#[0], PDD[1] controls the power down for      |
|       |       |             | CS#[1], and so on. CKE and ODT driver power     |
|       |       |             | down is controlled by DSGCR register.           |
|       |       |             | RANKODT                                         |
|       |       |             | Rank On-Die Termination: Enables, when set,     |
|       |       |             | the on-die termination on the I/O for           |
| 17:14 | RW    | 0x0         | CKE[3:0], ODT[3:0], and CS#[3:0] pins.          |
| 17.14 |       |             | RANKODT[0] controls the on-die termination      |
|       |       |             | for CKE[0], ODT[0], and CS#[0], RANKODT[1]      |
|       |       |             | controls the on-die termination for CKE[1],     |
|       |       | N Y         | ODT[1], and CS#[1], and so on.                  |
|       |       |             | CKPDR                                           |
| 13:11 | RW    | 0v7         | CK Power Down Receiver: Powers down, when       |
| 13.11 | KW    | 0x7         | set, the input receiver on the I/O for CK[0],   |
|       |       |             | CK[1], and CK[2] pins, respectively             |
|       |       |             | CKPDD                                           |
| 10:8  | RW    | 00          | CK Power Down Driver: Powers down, when         |
|       | IK VV | 0x0         | set, the output driver on the I/O for CK[0],    |
|       |       |             | CK[1], and CK[2] pins, respectively.            |
|       |       |             | CKODT                                           |
| 7.5   | RW    | 0×0         | CK On-Die Termination: Enables, when set,       |
| 7:5   |       |             | the on-die termination on the I/O for CK[0],    |
|       |       |             | CK[1], and CK[2] pins, respectively             |



| Bit | Attr       | Reset Value | Description                                    |
|-----|------------|-------------|------------------------------------------------|
|     |            |             | ACPDR                                          |
|     |            |             | AC Power Down Receiver: Powers down, when      |
| 4   | RW         | 0×1         | set, the input receiver on the I/O for RAS#,   |
| 4   | KVV        | UXI         | CAS#, WE#, BA[2:0], and A[15:0] pins, as       |
|     |            |             | well as the optional DIMM PAR_IN pin and       |
|     |            |             | LPDDR TPD pin.                                 |
|     |            |             | ACPDD                                          |
|     |            |             | AC Power Down Driver: Powers down, when        |
| 3   | RW         | 0×0         | set, the output driver on the I/O for RAS#,    |
|     |            |             | CAS#, WE#, BA[2:0], and A[15:0] pins, as       |
|     |            |             | well as the optional DIMM PAR_IN pin and       |
|     |            |             | LPDDR TPD pin.                                 |
|     | RW         | 0×0         | ACODT                                          |
|     |            |             | Address/Command On-Die Termination:            |
| 2   |            |             | Enables, when set, the on-die termination      |
|     |            |             | on the I/O for RAS#, CAS#, WE#, BA[2:0],       |
|     |            |             | and A[15:0] pins, as well as the optional DIMM |
|     |            |             | PAR_IN pin and LPDDR TPD pin.  ACOE            |
|     |            |             | Address/Command Output Enable: Enables,        |
| 1   | RW         | 0×1         | when set, the output driver on the I/O for all |
| 1   | PC V V     | OXI         | address and command pins, as well as the       |
|     |            |             | optional DIMM PAR_IN pin and LPDDR TPD pin.    |
|     |            |             | ACIOM                                          |
| 0   |            |             | Address/Command I/O Mode: Selects SSTL         |
|     | RW         | 0x0         | mode (when set to 0) or CMOS mode (when        |
|     |            |             | set to 1) of the I/O for all address and       |
|     |            |             | command pins, as well as the optional DIMM     |
|     | <b>A</b> 1 | U'          | PAR_IN pin and LPDDR TPD pin.                  |

# DDR\_PHYCTL\_DXCCR

Address: Operational Base + offset (0x0028) DATX8 Common Configuration Register

| Bit   | Attr | Reset Value | Description                                 |
|-------|------|-------------|---------------------------------------------|
| 31:14 | RO   | 0x0         | reserved                                    |
| 13:12 | RW   | 0×0         | DXSR                                        |
|       |      |             | Data Slew Rate (D3F I/O Only): Selects slew |
|       |      |             | rate of the I/O for DQ, DM, and DQS/DQS#    |
|       |      |             | pins of all DATX8 macros.                   |



| Bit      | Attr | Reset Value | Description                                     |
|----------|------|-------------|-------------------------------------------------|
|          |      |             | DQSNRES                                         |
|          |      |             | DQS# Resistor: Selects the on-die               |
| 11:8     | RW   | 0x8         | pull-up/pull-down resistor for DQS# pins.       |
| 11.0     | IKVV | 0.00        | Same encoding as DQSRES.                        |
|          |      |             | Note: DQS# resistor must be connected for       |
|          |      |             | LPDDR2                                          |
|          |      |             | DQSRES                                          |
|          |      |             | DQS Resistor: Selects the on-die                |
|          |      |             | pull-down/pull-up resistor for DQS pins.        |
|          |      |             | DQSRES[3] selects pull-down (when set to 0)     |
|          |      |             | or pull-up (when set to 1).                     |
|          |      |             | DQSRES[2:0] selects the resistor value as       |
|          |      |             | follows:                                        |
|          |      |             | 000 = Open: On-die resistor disconnected        |
| 7:4      | RW   | 0x0         | 001 = 688 ohms                                  |
|          |      |             | 010 = 611 ohms                                  |
|          |      |             | 011 = 550 ohms                                  |
|          |      |             | 100 = 500 ohms                                  |
|          |      |             | 101 = 458 ohms                                  |
|          |      |             | 110 = 393 ohms                                  |
|          |      |             | 111 = 344 ohms                                  |
|          |      |             | Note: DQS resistor must be connected for        |
|          |      |             | LPDDR2                                          |
|          |      |             | DXPDR                                           |
|          | RW   | 0x0         | Data Power Down Receiver: Powers down,          |
| 2        |      |             | when set, the input receiver on I/O for DQ,     |
| 3        |      |             | DM, and DQS/DQS# pins of all DATX8 macros.      |
|          |      |             | This bit is ORed with the PDR configuration bit |
|          |      |             | of the individual DATX8.                        |
|          |      | 7           | DXPDD                                           |
|          |      |             | Data Power Down Driver: Powers down, when       |
| 2        | RW   | 0×0         | set, the output driver on I/O for DQ, DM, and   |
| 2        | IXVV | 000         | DQS/DQS# pins of all DATX8 macros. This bit     |
| <b>*</b> |      |             | is ORed with the PDD configuration bit of the   |
|          |      |             | individual DATX8.                               |
|          |      |             | DXIOM                                           |
| 1        | RW   | 0x0         | Data I/O Mode: Selects SSTL mode (when set      |
|          |      |             | to 0) or CMOS mode (when set to 1) of the I/O   |
| 1        |      |             | for DQ, DM, and DQS/DQS# pins of all DATX8      |
|          |      |             | macros. This bit is ORed with the IOM           |
|          |      |             | configuration bit of the individual DATX8.      |



| Bit | Attr | Reset Value | Description                                   |
|-----|------|-------------|-----------------------------------------------|
|     | RW   | 0x0         | DXODT                                         |
|     |      |             | Data On-Die Termination: Enables, when set,   |
|     |      |             | the on-die termination on the I/O for DQ, DM, |
| U   |      |             | and DQS/DQS# pins of all DATX8 macros. This   |
|     |      |             | bit is ORed with the ODT configuration bit of |
|     |      |             | the individual DATX8.                         |

# DDR\_PHYCTL\_DSGCR

Address: Operational Base + offset (0x002c)
DDR System General Configuration Register

| Bit | Attr   | Reset Value | Description                                 |
|-----|--------|-------------|---------------------------------------------|
|     |        |             | CKEOE                                       |
| 21  | DW     | 01          | SDRAM CKE Output Enable: Enables, when      |
| 31  | RW     | 0x1         | set, the output driver on the I/O for SDRAM |
|     |        |             | CKE pins.                                   |
|     |        |             | RSTOE                                       |
| 30  | RW     | 0×1         | SDRAM Reset Output Enable: Enables, when    |
| 30  | KVV    | OXI         | set, the output driver on the I/O for SDRAM |
|     |        |             | RST# pin.                                   |
|     |        |             | ODTOE                                       |
| 29  | RW     | 0×1         | SDRAM ODT Output Enable: Enables, when      |
| 29  | I V V  | UXI         | set, the output driver on the I/O for SDRAM |
|     |        |             | ODT pins.                                   |
|     |        |             | CKOE                                        |
| 28  | RW     | 0x1         | SDRAM CK Output Enable: Enables, when set,  |
| 20  | KVV    |             | the output driver on the I/O for SDRAM      |
|     |        |             | CK/CK# pins.                                |
|     | RW     | 0x1         | TPDOE                                       |
| 27  |        |             | SDRAM TPD Output Enable (LPDDR Only):       |
| 2,  |        |             | Enables, when set, the output driver on the |
| (   |        |             | I/O for SDRAM TPD pin.                      |
| 0   | $\cup$ |             | TPDPD                                       |
|     |        |             | DRAM TPD Power Down Driver (LPDDR Only):    |
| 7   | RW     |             | Powers down, when set, the output driver on |
| 26  |        | 0x0         | the I/O for SDRAM TPD pin. Note that the    |
|     |        |             | power down of the receiver on the I/O for   |
|     |        |             | SDRAM TPD pin is controlled by              |
|     |        |             | ACIOCR[ACPDR] register bit.                 |



| Bit   | Attr | Reset Value | Description                                      |
|-------|------|-------------|--------------------------------------------------|
|       |      |             | NL2OE                                            |
|       |      |             | Non-LPDDR2 Output Enable: Enables, when          |
|       |      |             | set, the output driver on the I/O for            |
|       |      |             | non-LPDDR2 (ODT, RAS#, CAS#, WE#, and            |
| 25    | RW   | 0×1         | BA) pins. This may be used when a chip that is   |
| 23    | KVV  | OXI         | designed for both LPDDR2 and other DDR           |
|       |      |             | modes is being used in LPDDR2 mode. For          |
|       |      |             | these pins, the I/O output enable signal (OE) is |
|       |      |             | an AND of this bit and the respective output     |
|       |      |             | enable bit in ACIOCR or DSGCR registers.         |
|       |      |             | NL2PD                                            |
|       |      |             | Non-LPDDR2 Power Down: Powers down,              |
|       |      |             | when set, the output driver and the input        |
|       |      | 0×0         | receiver on the I/O for non-LPDDR2 (ODT,         |
|       |      |             | RAS#, CAS#, WE#, and BA) pins. This may be       |
| 24    | RW   |             | used when a chip that is designed for both       |
|       |      |             | LPDDR2 and other DDR modes is being used in      |
|       |      |             | LPDDR2 mode. For these pins, the I/O power       |
|       |      |             | down signal (PDD or PDR) is an OR of this bit    |
|       |      |             | and the respective power-down bit in ACIOCR      |
|       |      |             | register.                                        |
|       |      |             | ODTPDD                                           |
|       | RW   | 0×0         | ODT Power Down Driver: Powers down, when         |
| 23:20 |      |             | set, the output driver on the I/O for            |
|       |      | • ()        | ODT[3:0] pins. ODTPDD[0] controls the power      |
|       |      |             | down for ODT[0], ODTPDD[1] controls the          |
|       |      | 10/         | power down for ODT[1], and so on.                |
|       |      | C           | CKEPDD                                           |
| 19:16 | 11   |             | CKE Power Down Driver: Powers down, when         |
|       | RW   | 0x0         | set, the output driver on the I/O for CKE[3:0]   |
|       |      |             | pins. CKEPDD[0] controls the power down for      |
| 0     |      |             | CKE[0], CKEPDD[1] controls the power down        |
| 15.   | -    |             | for CKE[1], and so on.                           |
| 15:11 | RO   | 0x0         | reserved                                         |



| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:8 | RW   | 0×0         | DQSGE DQS Gate Early: Specifies the number of clock cycles for which the DQS gating must be enabled earlier than its normal position. Only applicable when using PDQSR I/O cell, passive DQS gating and no drift compensation. This field is recommended to be set to zero for all DDR types other than LPDDR2. For LPDDR2 it should be set to (tDQSCKmax - tDQSCK) divide by clock period and rounded up.          |
| 7:5  | RW   | 0×0         | DQSGX DQS Gate Extension: Specifies the number of clock cycles for which the DQS gating must be extended beyond the normal burst length width. Only applicable when using PDQSR I/O cell, passive DQS gating and no drift compensation. This field is recommended to be set to zero for all DDR types other than LPDDR2. For LPDDR2 it should be set to (tDQSCKmax - tDQSCK) divide by clock period and rounded up. |
| 4    | RW   | 0x1         | LPDLLPD Low Power DLL Power Down: Specifies if set that the PHY should respond to the DFI low power opportunity request and power down the DLL of the byte if the wakeup time request satisfies the DLL lock time.                                                                                                                                                                                                  |
| 3    | RW   | 0x1         | LPIOPD Low Power I/O Power Down: Specifies if set that the PHY should respond to the DFI low power opportunity request and power down the I/Os of the byte.                                                                                                                                                                                                                                                         |
| 2    | RW   | 0x1         | ZUEN Impedance Update Enable: Specifies if set that the PHY should perform impedance calibration (update) whenever there is a controller initiated DFI update request. Otherwise the PHY will ignore an update request from the controller.                                                                                                                                                                         |



| Bit | Attr | Reset Value | Description                                       |
|-----|------|-------------|---------------------------------------------------|
|     |      |             | BDISEN                                            |
|     |      |             | Byte Disable Enable: Specifies if set that the    |
| 1   | RW   | 0×1         | PHY should respond to DFI byte disable            |
| 1   | KVV  | UXI         | request. Otherwise the byte disable from the      |
|     |      |             | DFI is ignored in which case bytes can only be    |
|     |      |             | disabled using the DXnGCR register.               |
|     |      | 0×1         | PUREN                                             |
|     |      |             | PHY Update Request Enable: Specifies if set,      |
|     |      |             | that the PHY should issue PHY-initiated DFI       |
|     | RW   |             | update request when there is DQS drift of         |
|     |      |             | more than 3/4 of a clock cycle within one         |
| 0   |      |             | continuous (back-to-back) read burst. By          |
|     |      |             | default the PHY issues PHY-initiated update       |
|     |      |             | requests and the controller should respond        |
|     |      |             | otherwise the PHY may return erroneous            |
|     |      |             | values. The option to disable it is provided only |
|     |      |             | for silicon evaluation and testing                |

## DDR\_PHYCTL\_DCR

Address: Operational Base + offset (0x0030)

DRAM Configuration Register

| Bit      | Attr | Reset Value | Description                                     |
|----------|------|-------------|-------------------------------------------------|
|          |      |             | TPD                                             |
| 31       | RW   | 0x0         | Test Power Down (LPDDR Only): If set will       |
|          |      | . ()        | place the DRAM in deep power down mode.         |
|          |      |             | RDIMM                                           |
|          |      |             | Registered DIMM: Indicates if set that a        |
|          |      | ()          | registered DIMM is used. In this case, the PUB  |
|          | 11   |             | increases the SDRAM write and read latencies    |
| 30       | RW   | 0x0         | (WL/RL) by 1. This only applies to PUB internal |
| /        |      |             | SDRAM transactions. Transactions generated      |
|          |      |             | by the controller must make its own             |
|          | /    |             | adjustments to WL/RL when using a               |
| <b>Y</b> |      |             | registered DIMM.                                |



| Bit   | Attr | Reset Value | Description                                      |
|-------|------|-------------|--------------------------------------------------|
|       |      |             | UDIMM                                            |
|       |      |             | Un-buffered DIMM Address Mirroring:              |
|       |      |             | Indicates if set that there is address mirroring |
|       |      |             | on the second rank of an un-buffered DIMM        |
|       |      |             | (the rank connected to CS#[1]). In this case,    |
|       |      |             | the PUB re-scrambles the bank and address        |
| 29    | RW   | 0x0         | when sending mode register commands to the       |
|       |      |             | second rank. This only applies to PUB internal   |
|       |      |             | SDRAM transactions. Transactions generated       |
|       |      |             | by the controller must make its own              |
|       |      |             | adjustments when using an un-buffered            |
|       |      |             | DIMM. DCR[NOSRA] must be set if address          |
|       |      |             | mirroring is enabled.                            |
|       |      |             | DDR2T                                            |
| 20    | DVA  |             | DDR 2T Timing: Indicates if set that 2T timing   |
| 28    | RW   | 0x0         | should be used by PUB internally generated       |
|       |      |             | SDRAM transactions.                              |
|       |      |             | NOSRA                                            |
|       |      |             | No Simultaneous Rank Access: Specifies if set    |
|       |      |             | that simultaneous rank access on the same        |
| 27    | RW   | 0x0         | clock cycle is not allowed. This means that      |
|       |      |             | multiple chip select signals should not be       |
|       |      |             | asserted at the same time. This may be           |
|       |      |             | required on some DIMM systems.                   |
| 26:10 | RO   | 0x0         | reserved                                         |
|       |      | 1           | DDRTYPE                                          |
|       |      | V Y         | DDR Type: Selects the DDR type for the           |
|       |      |             | specified DDR mode.                              |
| 9:8   | RW   | 0×0         | Valid values for LPDDR2 are:                     |
| 9.0   | KVV  | UXU         | 00 = LPDDR2-S4                                   |
|       |      |             | 01 = LPDDR2-S2                                   |
|       |      |             | 10 = LPDDR2-NVM                                  |
|       |      |             | 11 = Reserved                                    |
| 7     |      |             | MPRDQ                                            |
|       |      |             | Multi-Purpose Register (MPR) DQ (DDR3            |
| 7     |      |             | Only): Specifies the value that is driven on     |
|       |      |             | non-primary DQ pins during MPR reads. Valid      |
|       | RW   | 0x0         | values are:                                      |
|       |      |             | 0 = Primary DQ drives out the data from MPR      |
|       |      |             | (0-1-0-1); non-primary DQs drive '0'             |
|       |      |             | 1 = Primary DQ and non-primary DQs all drive     |
|       |      |             | the same data from MPR (0-1-0-1)                 |



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                  |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:4 | RW   | 0x0         | PDQ Primary DQ (DDR3 Only): Specifies the DQ pin in a byte that is designated as a primary pin for Multi-Purpose Register (MPR) reads. Valid values are 0 to 7 for DQ[0] to DQ[7], respectively.                                                                                                                                             |
| 3   | RW   | 0x1         | DDR8BNK DDR 8-Bank: Indicates if set that the SDRAM used has 8 banks. tRPA = tRP+1 and tFAW are used for 8-bank DRAMs, other tRPA = tRP and no tFAW is used. Note that a setting of 1 for DRAMs that have fewer than 8 banks still results in correct functionality but less tighter DRAM command spacing for the parameters described here. |
| 2:0 | RW   | 0x3         | DDRMD DDR Mode: SDRAM DDR mode. Valid values are: 000 = LPDDR (Mobile DDR) 001 = DDR 010 = DDR2 011 = DDR3 100 = LPDDR2 (Mobile DDR2) 101 = Reserved                                                                                                                                                                                         |

# DDR\_PHYCTL\_DTPR0

Address: Operational Base + offset (0x0034)

DRAM Timing Parameters Register 0

| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
|       |      | 7           | tCCD                                          |
|       |      |             | Read to read and write to write command       |
| 31    | RW   | 0x0         | delay. Valid values are:                      |
|       | ·    |             | 0 = BL/2 for DDR2 and 4 for DDR3              |
|       |      |             | 1 = BL/2 + 1 for DDR2 and 5 for DDR3          |
| 30:25 |      |             | tRC                                           |
|       | RW   | 0x18        | Activate to activate command delay (same      |
|       |      |             | bank). Valid values are 2 to 42.              |
| 24:21 |      |             | tRRD                                          |
|       | RW   | 0x4         | Activate to activate command delay (different |
|       |      |             | banks). Valid values are 1 to 8.              |
| 20:16 |      |             | tras                                          |
|       | RW   | 0x12        | Activate to precharge command delay. Valid    |
|       |      |             | values are 2 to 31.                           |

| Bit   | Attr   | Reset Value | Description                                        |
|-------|--------|-------------|----------------------------------------------------|
|       |        |             | tRCD                                               |
|       |        |             | Activate to read or write delay. Minimum time      |
| 15:12 | RW     | 0x6         | from when an activate command is issued to         |
|       |        |             | when a read or write to the activated row can      |
|       |        |             | be issued. Valid values are 2 to 11.               |
|       |        |             | tRP                                                |
|       |        |             | Precharge command period: The minimum              |
|       |        |             | time between a precharge command and any           |
| 11:8  | RW     | 0x6         | other command. Note that the Controller            |
|       |        |             | automatically derives tRPA for 8-bank DDR2         |
|       |        |             | devices by adding 1 to tRP . Valid values are 2 $$ |
|       |        |             | to 11.                                             |
|       |        |             | tWTR                                               |
| 7:5   | RW     | 0x3         | Internal write to read command delay. Valid        |
|       |        |             | values are 1 to 6.                                 |
|       |        |             | trtp                                               |
|       |        |             | Internal read to precharge command delay.          |
|       |        |             | Valid values are 2 to 6. Note that even though     |
|       |        |             | RTP does not apply to JEDEC DDR devices, this      |
| 4:2   | RW     | 0x3         | parameter must still be set to a minimum           |
|       |        |             | value of 2 for DDR because the Controller          |
|       |        |             | always uses the DDR2 equation, AL + BL/2 +         |
|       |        |             | max(RTP,2) - 2, to compute the read to             |
|       |        |             | precharge timing (which is BL/2 for JEDEC          |
|       |        |             | DDR).                                              |
|       |        |             | tMRD                                               |
|       |        |             | Load mode cycle time: The minimum time             |
|       |        |             | between a load mode register command and           |
| 1.0   | DW     | 0.42        | any other command. For DDR3 this is the            |
| 1:0   | RW     | 0x2         | minimum time between two load mode                 |
|       |        |             | register commands. Valid values for DDR2 are       |
|       | $\cup$ |             | 2 to 3. For DDR3, the value used for tMRD is 4     |
|       |        |             | plus the value programmed in these bits, i.e.      |

#### DDR\_PHYCTL\_DTPR1

Address: Operational Base + offset (0x0038)

DRAM Timing Parameters Register 1

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:30 | RO   | 0x0         | reserved    |

tMRD value for DDR3 ranges from 4 to 7.



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:27 | RW   | 0x1         | tDQSCKmax  Maximum DQS output access time from  CK/CK# (LPDDR2 only). This value is used for implementing read-to-write spacing. Valid values are 1 to 7.                                                                                                                                                                                                                                                                                                                                                                                              |
| 26:24 | RW   | 0x1         | tDQSCK DQS output access time from CK/CK# (LPDDR2 only). This value is used for computing the read latency. Valid values are 1 to 7 This value is derived from the corresponding parameter in the SDRAM datasheet divided by the clock cycle time without rounding up. The fractional remainder is automatically adjusted for by data training in quarter clock cycle units. If data training is not performed then this fractional remainder must be converted to quarter clock cycle units and the gating registers (DXnDQSTR) adjusted accordingly. |
| 23:16 | RW   | 0x83        | tRFC Refresh-to-Refresh: Indicates the minimum time, in clock cycles, between two refresh commands or between a refresh and an active command. This is derived from the minimum refresh interval from the datasheet, tRFC(min), divided by the clock cycle time. The default number of clock cycles is for the largest JEDEC tRFC(min) parameter value supported.                                                                                                                                                                                      |
| 15:12 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 11    | RW   | 0×0         | tRTODT Read to ODT delay (DDR3 only). Specifies whether ODT can be enabled immediately after the read post-amble or one clock delay has to be added. Valid values are: 0 = ODT may be turned on immediately after read post-amble 1 = ODT may not be turned on until one clock after the read post-amble If tRTODT is set to 1, then the read-to-write latency is increased by 1 if ODT is enabled.                                                                                                                                                    |



| Bit  | Attr | Reset Value | Description                                      |
|------|------|-------------|--------------------------------------------------|
|      |      |             | tMOD                                             |
|      |      |             | Load mode update delay (DDR3 only). The          |
|      |      |             | minimum time between a load mode register        |
|      |      |             | command and a non-load mode register             |
| 10:9 | RW   | 0x0         | command. Valid values are:                       |
|      |      |             | 00 = 12                                          |
|      |      |             | 01 = 13                                          |
|      |      |             | 10 = 14                                          |
|      |      |             | 11 = 15                                          |
|      |      |             | tFAW                                             |
|      |      |             | 4-bank activate period. No more than 4-bank      |
| 8:3  | RW   | 0x12        | activate commands may be issued in a given       |
|      |      |             | tFAW period. Only applies to 8-bank devices.     |
|      |      |             | Valid values are 2 to 31.                        |
|      |      |             | tRTW                                             |
|      |      |             | Read to Write command delay. Valid values        |
|      |      |             | are:                                             |
|      |      |             | 0 = standard bus turn around delay               |
|      |      |             | 1 = add 1 clock to standard bus turn around      |
| 2    | RW   | 0×0         | delay                                            |
|      |      | OXO         | This parameter allows the user to increase the   |
|      |      |             | delay between issuing Write commands to the      |
|      |      |             | SDRAM when preceded by Read commands.            |
|      |      |             | This provides an option to increase bus          |
|      |      | . ()        | turn-around margin for high frequency            |
|      |      |             | systems.                                         |
|      |      |             | tAOND_tAOFD                                      |
|      |      |             | ODT turn-on/turn-off delays (DDR2 only). The     |
|      | 1    |             | delays are in clock cycles. Valid values are:    |
|      |      | ·           | 00 = 2/2.5                                       |
|      |      |             | 01 = 3/3.5                                       |
|      |      |             | 10 = 4/4.5                                       |
|      | ·    |             | 11 = 5/5.5                                       |
| 1:0  | RW   | 0x0         | Most DDR2 devices utilize a fixed value of       |
|      |      |             | 2/2.5. For non-standard SDRAMs, the user         |
|      |      |             | must ensure that the operational Write           |
|      |      |             | Latency is always greater than or equal to the   |
|      |      |             | ODT turn-on delay. For example, a DDR2           |
|      |      |             | SDRAM with CAS latency set to 3 and CAS          |
|      |      |             | additive latency set to 0 has a Write Latency of |
|      |      |             | 2. Thus 2/2.5 can be used, but not 3/3.5 or      |
|      |      |             | higher.                                          |



Address: Operational Base + offset (0x003c)

DRAM Timing Parameters Register 2

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                             |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                |
| 28:19 | RW   | 0×200       | tDLLK                                                                                                                                                                                                                                                                                                                                   |
| 20.19 | KVV  | 0.00        | DLL locking time. Valid values are 2 to 1023.                                                                                                                                                                                                                                                                                           |
| 18:15 | RW   | 0x3         | tCKE CKE minimum pulse width. Also specifies the minimum time that the SDRAM must remain in power down or self refresh mode. For DDR3 this parameter must be set to the value of tCKESR which is usually bigger than the value of tCKE. Valid values are 2 to 15.                                                                       |
| 14:10 | RW   | 0x08        | tXP Power down exit delay. The minimum time between a power down exit command and any other command. This parameter must be set to the maximum of the various minimum power down exit delay parameters specified in the SDRAM datasheet, i.e. max(tXP, tXARD, tXARDS) for DDR2 and max(tXP, tXPDLL) for DDR3. Valid values are 2 to 31. |
| 9:0   | RW   | 0x0c8       | Self refresh exit delay. The minimum time between a self refresh exit command and any other command. This parameter must be set to the maximum of the various minimum self refresh exit delay parameters specified in the SDRAM datasheet, i.e. max(tXSNR, tXSRD) for DDR2 and max(tXS, tXSDLL) for DDR3. Valid values are 2 to 1023.   |

#### DDR\_PHYCTL\_MR0

Address: Operational Base + offset (0x0040)

Mode Register 0

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:13 | RO   | 0x0         | reserved    |



| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12   | RW   | 0x0         | PD Power-Down Control: Controls the exit time for power-down modes. Refer to SDRAM datasheet for details on power-down modes. Valid values are: 0 = Slow exit (DLL off) 1 = Fast exit (DLL on)                                                                                                                                                                                                                                                                                                                                                                  |
| 11:9 | RW   | 0x5         | WR Write Recovery: This is the value of the write recovery in clock cycles. It is calculated by dividing the datasheet write recovery time, tWR (ns) by the datasheet clock cycle time, tCK (ns) and rounding up a non-integer value to the next integer. Valid values are:  001 = 5 010 = 6 011 = 7 100 = 8 101 = 10 110 = 12 All other settings are reserved and should not be used.  NOTE: tWR (ns) is the time from the first SDRAM positive clock edge after the last data-in pair of a write command, to when a precharge of the same bank can be issued. |
| 8    | RW   | 0x0         | DR DLL Reset: Writing a '1' to this bit will reset the SDRAM DLL. This bit is self-clearing, i.e. it returns back to '0' after the DLL reset has been issued.                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7    | RW   | 0x0         | TM Operating Mode: Selects either normal operating mode (0) or test mode (1). Test mode is reserved for the manufacturer and should not be used.                                                                                                                                                                                                                                                                                                                                                                                                                |



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                       |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:4 | RW   | 0x5         | CL_1 CAS Latency: The delay, in clock cycles, between when the SDRAM registers a read command to when data is available. Valid values are: $0010 = 5$ $0100 = 6$ $0110 = 7$ $1000 = 8$ $1010 = 9$ $1100 = 10$ $1110 = 11$ All other settings are reserved and should not be used. |
| 3   | RW   | 0x0         | BT Burst Type: Indicates whether a burst is sequential (0) or interleaved (1).                                                                                                                                                                                                    |
| 2   | RW   | 0x0         | CL_0 CAS Latency: merged with bit6-4                                                                                                                                                                                                                                              |
| 1:0 | RW   | 0x2         | BL Burst Length: Determines the maximum number of column locations that can be accessed during a given read or write command. Valid values are: Valid values for DDR3 are: 00 = 8 (Fixed) 01 = 4 or 8 (On the fly) 10 = 4 (Fixed) 11 = Reserved                                   |

## DDR\_PHYCTL\_MR1

Address: Operational Base + offset (0x0044)

Mode Register 1

| Bit   | Attr | <b>Reset Value</b> | Description                                  |
|-------|------|--------------------|----------------------------------------------|
| 31:13 | RO   | 0x0                | reserved                                     |
|       |      |                    | QOFF                                         |
|       |      |                    | Output Enable/Disable: When '0' all outputs  |
|       |      |                    | function normal; when '1' all SDRAM outputs  |
| 12    | RW   | 0x0                | are disabled removing output buffer current. |
|       |      |                    | This feature is intended to be used for IDD  |
|       |      |                    | characterization of read current and should  |
|       |      |                    | not be used in normal operation.             |



11 = Reserved



| Bit | Attr | Reset Value | Description                                   |
|-----|------|-------------|-----------------------------------------------|
| 2   | RW   | 0x0         | RTT_0                                         |
| 2   | KVV  |             | On Die Termination: merged with bit9.         |
|     |      | 0x0         | DIC_0                                         |
| 1   | RW   |             | Output Driver Impedance Control: Controls     |
|     |      |             | the output drive strength. Merged with bit5.  |
|     |      |             | DE                                            |
| 0   | RW   | 0×0         | DLL Enable/Disable: Enable (0) or disable (1) |
|     |      |             | the DLL. DLL must be enabled for normal       |
|     |      |             | operation.                                    |

## DDR\_PHYCTL\_MR2

Address: Operational Base + offset (0x0048)

Mode Register 2

| Bit   | Attr   | Reset Value | Description                                     |
|-------|--------|-------------|-------------------------------------------------|
| 31:11 | RO     | 0x0         | reserved                                        |
|       |        |             | RTTWR                                           |
|       |        |             | Dynamic ODT: Selects RTT for dynamic ODT.       |
|       |        |             | Valid values are:                               |
| 10:9  | RW     | 0x0         | 00 = Dynamic ODT off                            |
|       |        |             | 01 = RZQ/4                                      |
|       |        |             | 10 = RZQ/2                                      |
|       |        |             | 11 = Reserved                                   |
| 8     | RO     | 0x0         | reserved                                        |
|       |        |             | SRT                                             |
| 7     | RW     | 0x0         | Self-Refresh Temperature Range: Selects         |
| ,     | IXVV   |             | either normal ('0') or extended ('1') operating |
|       |        |             | temperature range during self-refresh.          |
|       |        |             | ASR                                             |
|       |        |             | Auto Self-Refresh: When enabled ('1'),          |
|       |        | Y           | SDRAM automatically provide self-refresh        |
| 6     | RW     | 0x0         | power management functions for all              |
| 0     | $\cup$ |             | supported operating temperature values.         |
|       | 1      |             | Otherwise the SRT bit must be programmed to     |
| ,     |        |             | indicate the temperature range.                 |



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:3 | RW   | 0x0         | CWL  CAS Write Latency: The delay, in clock cycles, between when the SDRAM registers a write command to when write data is available.  Valid values are:  000 = 5 (tCK = 2.5ns)  001 = 6 (2.5ns > tCK = 1.875ns)  010 = 7 (1.875ns > tCK = 1.5ns)                                                                                                                                                                                                |
|     |      |             | 011 = 8 (1.5ns > tCK = 1.25ns) All other settings are reserved and should not be used                                                                                                                                                                                                                                                                                                                                                            |
| 2:0 | RW   | 0x0         | PASR Partial Array Self Refresh: Specifies that data located in areas of the array beyond the specified location will be lost if self refresh is entered.  Valid settings for 4 banks are:  000 = Full Array  001 = Half Array (BA[1:0] = 00 & 01)  010 = Quarter Array (BA[1:0] = 00)  011 = Not defined  100 = 3/4 Array (BA[1:0] = 01, 10, & 11)  101 = Half Array (BA[1:0] = 10 & 11)  110 = Quarter Array (BA[1:0] = 11)  111 = Not defined |
| R   | 504  |             | Valid settings for 8 banks are:  000 = Full Array  001 = Half Array (BA[2:0] = 000, 001, 010 &  011)  010 = Quarter Array (BA[2:0] = 000, 001)  011 = 1/8 Array (BA[2:0] = 000)  100 = 3/4 Array (BA[2:0] = 010, 011, 100,  101, 110 & 111)  101 = Half Array (BA[2:0] = 100, 101, 110 &  111)  110 = Quarter Array (BA[2:0] = 110 & 111)  111 = 1/8 Array (BA[2:0] 111)                                                                         |

#### DDR\_PHYCTL\_MR3

Address: Operational Base + offset (0x004c)

Mode Register 3

|     | . ious regions |             |             |  |  |
|-----|----------------|-------------|-------------|--|--|
| Bit | Attr           | Reset Value | Description |  |  |



| Bit  | Attr | Reset Value | Description                                     |
|------|------|-------------|-------------------------------------------------|
| 31:3 | RO   | 0x0         | reserved                                        |
|      |      |             | MPR                                             |
|      |      |             | Multi-Purpose Register Enable: Enables, if set, |
| 2    | RW   |             | that read data should come from the             |
|      |      |             | Multi-Purpose Register. Otherwise read data     |
|      |      |             | come from the DRAM array.                       |
| 1:0  | RW   | 0x0         | MPRLOC                                          |
|      |      |             | Multi-Purpose Register (MPR) Location:          |
|      |      |             | Selects MPR data location: Valid value are:     |
|      |      |             | 00 = Predefined pattern for system calibration  |
|      |      |             | All other settings are reserved and should not  |
|      |      |             | be used.                                        |

#### DDR\_PHYCTL\_ODTCR

Address: Operational Base + offset (0x0050)

ODT Configuration Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                |
| 23:20 | RW   | 0x2         | WRODT1 Write ODT: Specifies whether ODT should be enabled ('1') or disabled ('0') on each of the up to four ranks when a write command is sent to rank 0. WRODT0, WRODT1 specify ODT settings when a write is to rank 0, rank 1 respectively. The four bits of each field each represent a rank, the LSB being rank 0 and the MSB being rank 1. Default is to enable ODT only on rank being written to. |
| 19:16 | RW   | 0x1         | WRODTO Write ODT: Specifies whether ODT should be enabled ('1') or disabled ('0') on each of the up to four ranks when a write command is sent to rank 0. WRODTO, WRODT1 specify ODT settings when a write is to rank 0, rank 1 respectively. The four bits of each field each represent a rank, the LSB being rank 0 and the MSB being rank 1. Default is to enable ODT only on rank being written to. |
| 15:8  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                |



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4 | RW   | 0×0         | RDODT1 Read ODT: Specifies whether ODT should be enabled ('1') or disabled ('0') on each of the up to four ranks when a read command is sent to rank 1. RDODT0, RDODT1 specify ODT settings when a read is to rank 0, and rank 1, respectively. The two bits of each field each represent a rank, the LSB being rank 0 and the MSB being rank 1. Default is to disable ODT during reads. |
| 3:0 | RW   | 0×0         | RDODTO Read ODT: Specifies whether ODT should be enabled ('1') or disabled ('0') on each of the up to four ranks when a read command is sent to rank 0. RDODTO, RDODT1 specify ODT settings when a read is to rank 0, and rank 1, respectively. The two bits of each field each represent a rank, the LSB being rank 0 and the MSB being rank 1. Default is to disable ODT during reads. |

## DDR\_PHYCTL\_DTAR

Address: Operational Base + offset (0x0054)

Data Training Address Register

| Bit   | Attr | Reset Value | Description                                    |
|-------|------|-------------|------------------------------------------------|
|       |      | 17          | DTMPR                                          |
|       |      |             | Data Training Using MPR (DDR3 Only):           |
|       |      |             | Specifies, if set, that data-training should   |
| 31    | RW   | 0x0         | use the SDRAM Multi-Purpose Register (MPR)     |
|       |      | ,           | register. Otherwise data-training is performed |
|       |      |             | by first writing to some locations in the      |
|       |      |             | SDRAM and then reading them back.              |
|       | ,    |             | DTBANK                                         |
| 30:28 | RW   | 0×0         | Data Training Bank Address: Selects the        |
| 30.20 | KVV  | UXU         | SDRAM bank address to be used during data      |
|       |      |             | training.                                      |
|       |      |             | DTROW                                          |
| 27:12 | RW   | 0×0000      | Data Training Row Address: Selects the         |
| 2/.12 |      |             | SDRAM row address to be used during data       |
|       |      |             | training.                                      |



| Bit  | Attr | Reset Value | Description                                |
|------|------|-------------|--------------------------------------------|
|      |      |             | DTCOL                                      |
|      |      |             | Data Training Column Address: Selects the  |
| 11:0 | RW   | 0x000       | SDRAM column address to be used during     |
|      |      |             | data training. The lower four bits of this |
|      |      |             | address must always be '0000'              |

#### DDR\_PHYCTL\_DTDR0

Address: Operational Base + offset (0x0058)

Data Training Data Register 0

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                             |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | RW   | 0xdd        | DTBYTE3 Data Training Data: The fourth 4 bytes of data used during data training. This same data byte is used for each Byte Lane. Default sequence is a walking 1 while toggling data every data cycle. |
| 23:16 | RW   | 0x22        | DTBYTE2 Data Training Data: The third 4 bytes of data used during data training. This same data byte is used for each Byte Lane. Default sequence is a walking 1 while toggling data every data cycle.  |
| 15:8  | RW   | 0xee        | DTBYTE1 Data Training Data: The second 4 bytes of data used during data training. This same data byte is used for each Byte Lane. Default sequence is a walking 1 while toggling data every data cycle. |
| 7:0   | RW   | 0x11        | DTBYTE0 Data Training Data: The first 4 bytes of data used during data training. This same data byte is used for each Byte Lane. Default sequence is a walking 1 while toggling data every data cycle.  |

#### DDR\_PHYCTL\_DTDR1

Address: Operational Base + offset (0x005c)

Data Training Data Register 1

| Bit Attr Re | eset Value | Description |
|-------------|------------|-------------|
|-------------|------------|-------------|



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                              |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | RW   | 0x77        | DTBYTE7 Data Training Data: The eighth4 bytes of data used during data training. This same data byte is used for each Byte Lane. Default sequence is a walking 1 while toggling data every data cycle.   |
| 23:16 | RW   | 0x88        | DTBYTE6 Data Training Data: The seventh 4 bytes of data used during data training. This same data byte is used for each Byte Lane. Default sequence is a walking 1 while toggling data every data cycle. |
| 15:8  | RW   | 0xbb        | DTBYTE5 Data Training Data: The sixth 4 bytes of data used during data training. This same data byte is used for each Byte Lane. Default sequence is a walking 1 while toggling data every data cycle.   |
| 7:0   | RW   | 0x44        | DTBYTE4 Data Training Data: The fifth 4 bytes of data used during data training. This same data byte is used for each Byte Lane. Default sequence is a walking 1 while toggling data every data cycle.   |

## DDR\_PHYCTL\_DCUAR

Address: Operational Base + offset (0x00c0)

DCU Address Register

| Bit   | Attr   | Reset Value | Description                                                                                |
|-------|--------|-------------|--------------------------------------------------------------------------------------------|
| 31:12 | RO     | 0x0         | reserved                                                                                   |
|       |        |             | ATYPE                                                                                      |
| 11    | RW     | 0×0         | Access Type: Specifies the type of access to be performed using this address. Valid values |
|       | IK V V |             | are:                                                                                       |
|       |        |             | 0 = Write access                                                                           |
|       |        |             | 1 = Read access                                                                            |



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                     |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10  | RW   | 0×0         | INCA Increment Address: Specifies, if set, that the cache address specified in WADDR and SADDR should be automatically incremented after each access of the cache. The increment happens in such a way that all the slices of a selected word are first accessed before going to the next word. |
| 9:8 | RW   | 0x0         | CSEL Cache Select: Selects the cache to be accessed. Valid values are: 00 = Command cache 01 = Expected data cache 10 = Read data cache 11 = Reserved                                                                                                                                           |
| 7:4 | RW   | 0×0         | CSADDR Cache Slice Address: Address of the cache slice to be accessed.                                                                                                                                                                                                                          |
| 3:0 | RW   | 0x0         | CWADDR Cache Word Address: Address of the cache word to be accessed.                                                                                                                                                                                                                            |

## DDR\_PHYCTL\_DCUDR

Address: Operational Base + offset (0x00c4)

. 1

DCU Data Register

| Bit  | Attr | Reset Value | Description                                |
|------|------|-------------|--------------------------------------------|
|      |      |             | CDATA                                      |
|      |      |             | Cache Data: Data to be written to or read  |
| 31:0 | RW   | 0x00000000  | from a cache. This data corresponds to the |
|      |      | · ·         | cache word slice specified by the DCU      |
|      |      |             | Address Register.                          |

#### DDR\_PHYCTL\_DCURR

Address: Operational Base + offset (0x00c8)

DCU Run Register

| Bit   | Attr | Reset Value | Description                               |
|-------|------|-------------|-------------------------------------------|
| 31:24 | RO   | 0x0         | reserved                                  |
|       |      |             | XCEN                                      |
|       |      |             | Expected Compare Enable: Indicates if set |
| 23    | RW   | 0x0         | that read data coming back from the SDRAM |
|       |      |             | should be should be compared with the     |
|       |      |             | expected data.                            |



| Bit      | Attr | Reset Value | Description                                     |
|----------|------|-------------|-------------------------------------------------|
|          |      |             | RCEN                                            |
| 22       | DVA  | 00          | Read Capture Enable: Indicates if set that      |
| 22       | RW   | 0x0         | read data coming back from the SDRAM            |
|          |      |             | should be captured into the read data cache.    |
|          |      |             | SCOF                                            |
| 21       | DVA  | 00          | Stop Capture On Full: Specifies if set that the |
| 21       | RW   | 0x0         | capture of read data should stop when the       |
|          |      |             | capture cache is full.                          |
|          |      |             | SONF                                            |
|          |      |             | Stop On Nth Fail: Specifies if set that the     |
|          |      |             | execution of commands and the capture of        |
| 20       | DW   | 0.40        | read data should stop when there are N read     |
| 20       | RW   | 0×0         | data failures. The number of failures is        |
|          |      |             | specified by NFAIL. Otherwise commands          |
|          |      |             | execute until the end of the program or until   |
|          |      |             | manually stopped using a STOP command.          |
|          |      |             | NFAIL                                           |
|          |      |             | Number of Failures: Specifies the number of     |
|          |      |             | failures after which the execution of           |
| 19:12    | RW   | 0×00        | commands and the capture of read data           |
| 19:12    | KVV  |             | should stop if SONF bit of this register is     |
|          |      |             | set. Execution of commands and the capture      |
|          |      |             | of read data will stop after (NFAIL+1)          |
|          |      |             | failures if SONF is set.                        |
|          |      | . ()        | EADDR                                           |
| 11:8     | RW   | 0x0         | End Address: Cache word address where the       |
|          |      | 10 y        | execution of command should end.                |
|          |      | C           | SADDR                                           |
| 7:4      | RW   | 0x0         | Start Address: Cache word address where the     |
|          | CV   | 7           | execution of commands should begin.             |
|          |      |             | DINST                                           |
|          |      |             | DCU Instruction: Selects the DCU command to     |
|          |      |             | be executed: Valid values are:                  |
| <b>Y</b> |      |             | 0000 = NOP: No operation                        |
|          |      |             | 0001 = Run: Triggers the execution of           |
|          |      |             | commands in the command cache.                  |
| 3:0      | RW   | 0x0         | 0010 = Stop: Stops the execution of             |
|          |      |             | commands in the command cache.                  |
|          |      |             | 0011 = Stop Loop: Stops the execution of an     |
|          |      |             | infinite loop in the command cache.             |
|          |      |             | 0100 = Reset: Resets all DCU run time           |
|          |      |             | registers.                                      |
|          |      |             | 0101 - 1111 Reserved                            |



### DDR\_PHYCTL\_DCULR

Address: Operational Base + offset (0x00cc)

DCU Loop Register

| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
|       |      |             | XLEADDR                                       |
|       |      |             | Expected Data Loop End Address: The last      |
| 31:28 | RW   | 0x0         | expected data cache word address that         |
|       |      |             | contains valid expected data. Expected data   |
|       |      |             | should looped between 0 and this address.     |
| 27:18 | RO   | 0x0         | reserved                                      |
|       |      |             | IDA                                           |
|       |      |             | Increment DRAM Address: Indicates if set that |
| 17    | RW   | 0x0         | DRAM addresses should be incremented every    |
|       |      |             | time a DRAM read/write command inside the     |
|       |      |             | loop is executed.                             |
|       |      |             | LINF                                          |
|       |      |             | Loop Infinite: Indicates if set that the loop |
| 16    | RW   | 0x0         | should be executed indefinitely until stopped |
|       |      |             | by the STOP command. Otherwise the loop is    |
|       |      |             | execute LCNT times.                           |
|       |      |             | LCNT                                          |
| 15:8  | RW   | 0x00        | Loop Count: The number of times that the      |
|       |      |             | loop should be executed if LINF is not set.   |
|       |      |             | LEADDR                                        |
| 7:4   | RW   | 0x0         | Loop End Address: Command cache word          |
|       |      | 1           | address where the loop should end.            |
|       |      |             | LSADDR                                        |
| 3:0   | RW   | 0x0         | Loop Start Address: Command cache word        |
|       | 1    |             | address where the loop should start.          |

#### DDR\_PHYCTL\_DCUGCR

Address: Operational Base + offset (0x00d0)

DCU General Configuration Register

| Bit   | Attr | Reset Value | Description                                     |
|-------|------|-------------|-------------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                        |
|       |      |             | RCSW                                            |
|       |      |             | Read Capture Start Word: The capture and        |
| 15:0  | RW   | 0x0000      | compare of read data should start after Nth     |
|       |      |             | word. For example setting this value to 12 will |
|       |      |             | skip the first 12 read data.                    |

#### DDR\_PHYCTL\_DCUTPR



Address: Operational Base + offset (0x00d4)

DCU Timing Parameters Registers

| Bit   | Attr | Reset Value | Description                     |
|-------|------|-------------|---------------------------------|
| 21.24 | DW   | 0,400       | tDCUT3                          |
| 31:24 | RW   | 0x00        | DCU Generic Timing Parameter 3. |
| 22.46 | DVV  | 0x00        | tDCUT2                          |
| 23:16 | RW   |             | DCU Generic Timing Parameter 2. |
| 1 . 0 | DVV  | 000         | tDCUT1                          |
| 15:8  | RW   | RW 0x00     | DCU Generic Timing Parameter 1. |
| 7:0   | DM   | 0.00        | tDCUT0                          |
|       | KW   | RW 0x00     | DCU Generic Timing Parameter 0. |

#### DDR\_PHYCTL\_DCUSR0

Address: Operational Base + offset (0x00d8)

DCU Status Register 0

| DCO Status Register 0 |      |             |                                                  |
|-----------------------|------|-------------|--------------------------------------------------|
| Bit                   | Attr | Reset Value | Description                                      |
| 31:3                  | RO   | 0x0         | reserved                                         |
|                       |      |             | CFULL                                            |
| 2                     | RO   | 0x0         | Capture Full: Indicates if set that the capture  |
|                       |      |             | cache is full.                                   |
|                       |      |             | CFAIL                                            |
| 1                     | RO   | 0x0         | Capture Fail: Indicates if set that at least one |
|                       |      |             | read data word has failed.                       |
|                       |      |             | RDONE                                            |
|                       |      |             | Run Done: Indicates if set that the DCU has      |
|                       |      | . (         | finished executing the commands in the           |
| 0                     | RO   | 0x0         | command cache. This bit is also set to indicate  |
|                       |      | 10 y        | that a STOP command has successfully been        |
|                       |      |             | executed and command execution has               |
|                       | 1    |             | stopped.                                         |

#### DDR PHYCTL DCUSR1

Address: Operational Base + offset (0x00dc)

DCU Status Register 1

| Bit   | Attr | Reset Value | Description                                 |
|-------|------|-------------|---------------------------------------------|
|       |      |             | LPCNT                                       |
|       |      |             | Loop Count: Indicates the value of the loop |
| 31:24 | RO   | 0x00        | count. This is useful when the program has  |
|       |      |             | stooped because of failures to assess how   |
|       |      |             | many reads were executed before first fail. |
|       |      |             | FLCND                                       |
| 23:16 | RO   | 0x00        | Fail Count: Number of read words that have  |
|       |      |             | failed.                                     |



| Bit  | Attr | Reset Value | Description                               |
|------|------|-------------|-------------------------------------------|
|      |      |             | RDCNT                                     |
| 15:0 | RO   | 0x0000      | Read Count: Number of read words returned |
|      |      |             | from the SDRAM.                           |

#### DDR\_PHYCTL\_BISTRR

Address: Operational Base + offset (0x0100)
BIST Run Register

| BIST Run Register |      |             |                                                       |
|-------------------|------|-------------|-------------------------------------------------------|
| Bit               | Attr | Reset Value | Description                                           |
| 31:26             | RO   | 0x0         | reserved                                              |
|                   |      |             | BCKSEL  BIST CK Selects Selects the CK to be used for |
|                   |      |             | BIST CK Select: Selects the CK to be used for         |
|                   |      |             | capturing loopback data on the                        |
|                   |      |             | address/command lane. Valid values are:               |
|                   |      |             | 000 = CK[0]                                           |
| 25:23             | RW   | 0x0         | 001 = CK[1]                                           |
|                   |      |             | 010 = CK[2]                                           |
|                   |      |             | 011 = Reserved                                        |
|                   |      |             | 100 = CK#[0]                                          |
|                   |      |             | 101 = CK#[1]                                          |
|                   |      |             | 110 = CK#[2]                                          |
|                   |      |             | 111 = Reserved                                        |
|                   |      |             | BDXSEL                                                |
| 22:19             | RW   | 0x0         | BIST DATX8 Select: Select the byte lane for           |
| 22113             | IXVV |             | comparison of loopback/read data. Valid               |
|                   |      | • 1         | values are 0 to 8.                                    |
|                   |      |             | BDPAT                                                 |
|                   |      |             | BIST Data Pattern: Selects the data pattern           |
|                   |      | ()          | used during BIST. Valid values are:                   |
| 18:17             | RW   | 0x0         | 00 = Walking 0                                        |
|                   |      | 7           | 01 = Walking 1                                        |
|                   |      |             | 10 = LFSR-based pseudo-random                         |
|                   |      |             | 11 = User programmable                                |
|                   | ·    |             | BDMEN                                                 |
| <b>y</b>          |      |             | BIST Data Mask Enable: Enables if set that the        |
| 16                | RW   | 0×0         | data mask BIST should be included in the BIST         |
|                   | IXVV | 0.00        | run, i.e. data pattern generated and loopback         |
|                   |      |             | data compared. This is valid only for loopback        |
|                   |      |             | mode.                                                 |
|                   |      |             | BACEN                                                 |
|                   |      |             | BIST AC Enable: Enables the running of BIST           |
| 15                | RW   | 0x0         | on the address/command lane PHY. This bit is          |
|                   |      |             | exclusive with BDXEN, i.e. both cannot be set         |
|                   |      |             | to '1' at the same time.                              |



| Bit  | Attr   | Reset Value | Description                                        |
|------|--------|-------------|----------------------------------------------------|
|      |        |             | BDXEN                                              |
|      |        |             | BIST DATX8 Enable: Enables the running of          |
| 14   | RW     | 0x0         | BIST on the data byte lane PHYs. This bit is       |
|      |        |             | exclusive with BACEN, i.e. both cannot be set      |
|      |        |             | to '1' at the same time.                           |
|      |        |             | BSONF                                              |
|      |        |             | BIST Stop On Nth Fail: Specifies if set that the   |
| 13   | RW     | 0x0         | BIST should stop when an nth data word or          |
|      |        |             | address/command comparison error has been          |
|      |        |             | encountered.                                       |
|      |        |             | NFAIL                                              |
|      |        |             | Number of Failures: Specifies the number of        |
|      |        |             | failures after which the execution of              |
| 12:5 | RW     | 0×00        | commands and the capture of read data              |
| 12.5 | IXVV   | 000         | should stop if BSONF bit of this register is set.  |
|      |        |             | Execution of commands and the capture of           |
|      |        |             | read data will stop after (NFAIL+1) failures if    |
|      |        |             | BSONF is set.                                      |
|      |        |             | BINF                                               |
|      |        |             | BIST Infinite Run: Specifies if set that the BIST  |
|      |        |             | should be run indefinitely until when it is either |
| 4    | RW     | 0x0         | stopped or a failure has been encountered.         |
|      |        |             | Otherwise BIST is run until number of BIST         |
|      |        |             | words specified in the BISTWCR register has        |
|      |        | • (         | been generated.                                    |
|      |        |             | BMODE                                              |
|      |        |             | BIST Mode: Selects the mode in which BIST is       |
|      | 5.44   |             | run. Valid values are:                             |
| 3    | RW     | 0x0         | 0 = Loopback mode: Address, commands and           |
|      |        | 7           | data loop back at the PHY I/Os.                    |
|      |        |             | 1 = DRAM mode: Address, commands and               |
| 0    | $\cup$ |             | data go to DRAM for normal memory accesses.        |
|      | ·      |             | BINST                                              |
| 7    |        |             | BIST Instruction: Selects the BIST instruction     |
|      | RW     |             | to be executed: Valid values are:                  |
| 2:0  |        | 0.40        | 000 = NOP: No operation                            |
|      |        | 0x0         | 001 = Run: Triggers the running of the BIST.       |
|      |        |             | 010 = Stop: Stops the running of the BIST.         |
|      |        |             | 011 = Reset: Resets all BIST run-time              |
|      |        |             | registers, such as error counters.                 |
|      |        |             | 100 - 111 Reserved                                 |



#### DDR\_PHYCTL\_BISTMSKR0

Address: Operational Base + offset (0x0104)

BIST Mask Register 0

| Bit   | Attr | Reset Value | Description                                     |
|-------|------|-------------|-------------------------------------------------|
| 31:28 | RW   | 0x0         | ODTMSK                                          |
| 31.20 | KVV  | UXU         | Mask bit for each of the up to 4 ODT bits.      |
| 27:24 | RW   | 0×0         | CSMSK                                           |
| 27.24 | KVV  | UXU         | Mask bit for each of the up to 4 CS# bits.      |
| 23:20 | RW   | 0x0         | CKEMSK                                          |
| 23.20 |      |             | Mask bit for each of the up to 4 CKE bits.      |
| 19    | RW   | V 0x0       | WEMSK                                           |
| 19    |      |             | Mask bit for the WE#.                           |
|       |      |             | BAMSK                                           |
| 18:16 | RW   | 0x0         | Mask bit for each of the up to 3 bank address   |
|       |      |             | bits.                                           |
| 15:0  | RW   | 0x0000      | AMSK                                            |
|       | KVV  |             | Mask bit for each of the up to 16 address bits. |

#### DDR\_PHYCTL\_BISTMSKR1

Address: Operational Base + offset (0x0108)

BIST Mask Register 1

| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
| 31    | DW   | 0x0         | TPDMSK                                        |
| 31    | RW   | UXU         | Mask bit for the TPD. LPDDR Only              |
|       |      |             | PARMSK                                        |
| 30    | RW   | 0x0         | Mask bit for the PAR_IN. Only for DIMM parity |
|       |      |             | support.                                      |
| 29:20 | RO   | 0x0         | reserved                                      |
| 19    | RW   | 0x0         | CASMSK                                        |
| 19    |      |             | Mask bit for the CAS.                         |
| 10    | RW   | 0x0         | RASMSK                                        |
| 18    |      |             | Mask bit for the RAS.                         |
| 17:16 | RW   | RW 0x0      | DMMSK                                         |
| 17:16 |      |             | Mask bit for the data mask (DM) bit.          |
| 15:0  | RW   | W 0x0000    | DQMSK                                         |
| 15.0  |      |             | Mask bit for each of the 8 data (DQ) bits.    |

#### DDR\_PHYCTL\_BISTWCR

Address: Operational Base + offset (0x010c)

BIST Word Count Register

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



| Bit  | Attr | Reset Value | Description                                      |
|------|------|-------------|--------------------------------------------------|
|      | RW   | 0x0020      | BWCNT                                            |
| 15:0 |      |             | BIST Word Count: Indicates the number of         |
|      |      |             | words to generate during BIST. This must be a    |
| 13.0 |      |             | multiple of DRAM burst length (BL) divided by    |
|      |      |             | 2, e.g. for BL=8, valid values are 4, 8, 12, 16, |
|      |      |             | and so on.                                       |

#### DDR\_PHYCTL\_BISTLSR

Address: Operational Base + offset (0x0110)

BIST LFSR Seed Register

| Bit  | Attr | Reset Value | Description                                |
|------|------|-------------|--------------------------------------------|
| 21.0 | RW   | 0,1224-6-4  | SEED                                       |
| 31:0 | KVV  | 0x1234abcd  | LFSR seed for pseudo-random BIST patterns. |

## DDR\_PHYCTL\_BISTAR0

Address: Operational Base + offset (0x0114)

BIST Address Register 0

| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
| 31    | RO   | 0x0         | reserved                                      |
|       |      |             | BBANK                                         |
| 30:28 | RW   | 0x0         | BIST Bank Address: Selects the SDRAM bank     |
|       |      |             | address to be used during BIST.               |
|       |      |             | BROW                                          |
| 27:12 | RW   | 0x0000      | BIST Row Address: Selects the SDRAM row       |
|       |      |             | address to be used during BIST.               |
|       | RW ( | 0×000       | BCOL                                          |
|       |      |             | BIST Column Address: Selects the SDRAM        |
| 11:0  |      |             | column address to be used during BIST. The    |
| 11:0  |      |             | lower bits of this address must be "0000" for |
|       |      | Y           | BL16, "000" for BL8, "00" for BL4 and "0"     |
|       |      |             | for BL2.                                      |

#### DDR\_PHYCTL\_BISTAR1

Address: Operational Base + offset (0x0118)

BIST Address Register 1

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



| Bit  | Attr | Reset Value | Description                                    |
|------|------|-------------|------------------------------------------------|
|      |      |             | BAINC                                          |
|      |      |             | BIST Address Increment: Selects the value by   |
|      |      |             | which the SDRAM address is incremented for     |
| 15:4 | RW   | 0x000       | each write/read access. This value must be at  |
|      |      |             | the beginning of a burst boundary, i.e. the    |
|      |      |             | lower bits must be "0000" for BL16, "00"       |
|      |      |             | for BL8, "00" for BL4 and "0" for BL2.         |
|      | RW   | / 0x3       | BMRANK                                         |
|      |      |             | BIST Maximum Rank: Specifies the maximum       |
| 3:2  |      |             | SDRAM rank to be used during BIST. The         |
| 3.2  |      |             | default value is set to maximum ranks minus    |
|      |      |             | 1. Example default shown here is for a 4-rank  |
|      |      |             | system                                         |
|      |      | 0x0         | BRANK                                          |
| 1:0  | RW   |             | BIST Rank: Selects the SDRAM rank to be        |
|      |      |             | used during BIST. Valid values range from 0 to |
|      |      |             | maximum ranks minus 1.                         |

#### DDR\_PHYCTL\_BISTAR2

Address: Operational Base + offset (0x011c)

BIST Address Register 2

| Bit      | Attr | Reset Value | Description                                  |
|----------|------|-------------|----------------------------------------------|
| 31       | RO   | 0x0         | reserved                                     |
|          |      |             | BMBANK                                       |
|          |      | • 1         | BIST Maximum Bank Address: Specifies the     |
| 30:28    | RW   | 0x7         | maximum SDRAM bank address to be used        |
|          |      |             | during BIST before the address increments to |
|          |      |             | the next rank.                               |
|          | 11   |             | BMROW                                        |
|          |      | ,           | BIST Maximum Row Address: Specifies the      |
| 27:12    | RW   | 0xffff      | maximum SDRAM row address to be              |
| 0        |      |             | used during BIST before the address          |
|          | V    |             | increments to the next bank.                 |
| <b>y</b> |      |             | BMCOL                                        |
|          |      |             | BIST Maximum Column Address: Specifies the   |
| 11:0     | RW   | 0xfff       | maximum SDRAM column address to be used      |
|          |      |             | during BIST before the address increments to |
|          |      |             | the next row.                                |

#### DDR\_PHYCTL\_BISTUDPR

Address: Operational Base + offset (0x0120)

BIST User Data Pattern Register



| Bit   | Attr | Reset Value | Description                                  |
|-------|------|-------------|----------------------------------------------|
|       |      |             | BUDP1                                        |
| 31:16 | RW   | 0xffff      | BIST User Data Pattern 1: Data to be applied |
|       |      |             | on odd DQ pins during BIST.                  |
|       |      |             | BUDP0                                        |
| 15:0  | RW   | 0x0000      | BIST User Data Pattern 0: Data to be applied |
|       |      |             | on even DQ pins during BIST.                 |

#### DDR\_PHYCTL\_BISTGSR

Address: Operational Base + offset (0x0124)

BIST General Status Register

| Bit   | Attr | Reset Value | Description                                       |
|-------|------|-------------|---------------------------------------------------|
|       |      |             | CASBER                                            |
| 31:30 | RO   | 0x0         | CAS Bit Error: Indicates the number of bit        |
|       |      |             | errors on CAS.                                    |
|       |      |             | RASBER                                            |
| 29:28 | RO   | 0x0         | RAS Bit Error: Indicates the number of bit        |
|       |      |             | errors on RAS.                                    |
|       |      |             | DMBER                                             |
|       |      |             | DM Bit Error: Indicates the number of bit         |
| 27:24 | RO   | 0x0         | errors on data mask (DM) bit. DMBER[1:0] are      |
|       |      |             | for the first DM beat, and DMBER[3:2] are for     |
|       |      |             | the second DM beat.                               |
|       |      |             | TPDBER                                            |
| 23:22 | RO   | 0x0         | TPD Bit Error (LPDDR Only): Indicates the         |
|       |      | • 1         | number of bit errors on TPD.                      |
|       |      |             | PARBER                                            |
| 21:20 | RO   | 0x0         | PAR_IN Bit Error (DIMM Only): Indicates the       |
|       |      | C           | number of bit errors on PAR_IN.                   |
| 19:3  | RO   | 0x0         | reserved                                          |
|       | C    | 7           | BDXERR                                            |
| 2     | RO   | 0×0         | BIST Data Error: indicates if set that there is a |
|       |      | 0.00        | data comparison error in the byte                 |
|       | V    |             | lane.                                             |
|       |      |             | BACERR                                            |
| 1     | RO   | 0×0         | BIST Address/Command Error: indicates if set      |
|       |      | OXO         | that there is a data comparison error in the      |
|       |      |             | address/command lane.                             |
|       |      |             | BDONE                                             |
| 0     | RO   | 0×0         | BIST Done: Indicates if set that the BIST has     |
| U     |      |             | finished executing. This bit is reset to zero     |
|       |      |             | when BIST is triggered.                           |



## DDR\_PHYCTL\_BISTWER

Address: Operational Base + offset (0x0128)

BIST Word Error Register

| Bit   | Attr | Reset Value | Description                                     |
|-------|------|-------------|-------------------------------------------------|
|       |      |             | DXWER                                           |
|       |      |             | Byte Word Error: Indicates the number of        |
| 31:16 | RO   | 0x0000      | word errors on the byte lane. An error on any   |
|       |      |             | bit of the data bus including the data mask bit |
|       |      |             | increments the error count.                     |
|       | RO   | 0×0000      | ACWER                                           |
|       |      |             | Address/Command Word Error: Indicates the       |
| 15:0  |      |             | number of word errors on the                    |
|       |      |             | address/command lane. An error on any bit of    |
|       |      |             | the address/command bus increments the          |
|       |      |             | error count.                                    |

#### DDR\_PHYCTL\_BISTBER0

Address: Operational Base + offset (0x012c)

BIST Bit Error Register 0

| Bit  | Attr | Reset Value | Description                                      |
|------|------|-------------|--------------------------------------------------|
|      |      |             | ABER                                             |
|      |      |             | Address Bit Error: Each group of two bits        |
| 31:0 | RO   | 0x00000000  | indicate the bit error count on each of the up   |
|      |      |             | to 16 address bits. [1:0] is the error count for |
|      |      |             | A[0], [3:2] for A[1], and so on.                 |

#### DDR\_PHYCTL\_BISTBER1

Address: Operational Base + offset (0x0130)

BIST Bit Error Register 1

| Bit   | Attr | <b>Reset Value</b> | Description                                      |
|-------|------|--------------------|--------------------------------------------------|
|       |      | 7                  | ODTBER                                           |
|       |      | Y                  | ODT Bit Error: Each group of two bits indicates  |
| 31:24 | RO   | 0x00               | the bit error count on each of the up to 4 ODT   |
|       |      |                    | bits. [1:0] is the error count for ODT[0], [3:2] |
|       |      |                    | for ODT[1], and so on.                           |
|       |      |                    | CSBER                                            |
|       |      |                    | CS# Bit Error: Each group of two bits indicates  |
| 23:16 | RO   | 0x00               | the bit error count on each of the up to 4 CS#   |
|       |      |                    | bits. [1:0] is the error count for CS#[0], [3:2] |
|       |      |                    | for CS#[1], and so on.                           |



| Bit  | Attr | Reset Value | Description                                      |
|------|------|-------------|--------------------------------------------------|
|      |      |             | CKEBER                                           |
|      |      |             | CKE Bit Error: Each group of two bits indicates  |
| 15:8 | RO   | 0x00        | the bit error count on each of the up to 4 CKE   |
|      |      |             | bits. [1:0] is the error count for CKE[0], [3:2] |
|      |      |             | for CKE[1], and so on.                           |
|      |      |             | WEBER                                            |
| 7:6  | RO   | 0x0         | WE# Bit Error: Indicates the number of bit       |
|      |      |             | errors on WE#.                                   |
|      |      |             | BABER                                            |
|      |      |             | Bank Address Bit Error: Each group of two bits   |
| 5:0  | RO   | 0x00        | indicates the bit error count on each of the up  |
|      |      |             | to 3 bank address bits. [1:0] is the error count |
|      |      |             | for BA[0], [3:2] for BA[1], and so on.           |

#### DDR\_PHYCTL\_BISTBER2

Address: Operational Base + offset (0x0134)

BIST Bit Error Register 2

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                  |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x0000000   | Description  DQBER  Data Bit Error: The first 16 bits indicate the error count for the first data beat (i.e. the data driven out on DQ[7:0] on the rising edge of DQS). The second 16 bits indicate the error on the second data beat (i.e. the error count of the data driven out on DQ[7:0] on the falling edge of DQS). For each of the 16-bit group, the first 2 bits are for DQ[0], the |
|      |      |             | second for DQ[1], and so on.                                                                                                                                                                                                                                                                                                                                                                 |

### DDR\_PHYCTL\_BISTWCSR

Address: Operational Base + offset (0x0138)

BIST Word Count Status Register

| Bit   | Attr                                 | Reset Value                       | Description                               |
|-------|--------------------------------------|-----------------------------------|-------------------------------------------|
| y     |                                      |                                   | DXWCNT                                    |
| 31:16 | RO                                   | 0x0000                            | Byte Word Count: Indicates the number of  |
|       |                                      |                                   | words received from the byte lane.        |
| 15:0  |                                      |                                   | ACWCNT                                    |
|       | DO.                                  | 0,0000                            | Address/Command Word Count: Indicates the |
|       | RO 0x0000 number of words received f | number of words received from the |                                           |
|       |                                      |                                   | address/command lane.                     |

#### DDR\_PHYCTL\_BISTFWR0



Address: Operational Base + offset (0x013c)

BIST Fail Word Register 0

| Bit   | Attr | Reset Value                               | Description                                    |
|-------|------|-------------------------------------------|------------------------------------------------|
| 31:29 | RO   | 0x0                                       | reserved                                       |
|       |      |                                           | ODTWEBS                                        |
| 28    | RO   | 0x0                                       | Bit status during a word error for each of the |
|       |      |                                           | up to 4 ODT bits.                              |
|       |      |                                           | CSWEBS                                         |
| 27:24 | RO   | 0x0                                       | Bit status during a word error for each of the |
|       |      |                                           | up to 4 CS# bits.                              |
|       |      |                                           | CKEWEBS                                        |
| 23:20 | RO   | 0x0                                       | Bit status during a word error for each of the |
|       |      |                                           | up to 4 CKE bits.                              |
| 19    | RO   | 0 0x0<br>0 0x0<br>0 0x0<br>0 0x0<br>0 0x0 | WEWEBS                                         |
| 19    | KO   | 0.00                                      | Bit status during a word error for the WE#.    |
|       |      |                                           | BAWEBS                                         |
| 18:16 | RO   | 0x0                                       | Bit status during a word error for each of the |
|       |      |                                           | up to 3 bank address bits.                     |
|       |      |                                           | AWEBS                                          |
| 15:0  | RO   | 0x0000                                    | Bit status during a word error for each of the |
|       |      |                                           | up to 16 address bits.                         |

#### DDR\_PHYCTL\_BISTFWR1

Address: Operational Base + offset (0x0140)

BIST Fail Word Register 1

| Bit   | Attr      | Reset Value                               | Description                                    |
|-------|-----------|-------------------------------------------|------------------------------------------------|
|       |           |                                           | TPDWEBS                                        |
| 31    | RO        | 0x0                                       | Bit status during a word error for the TPD.    |
|       |           |                                           | LPDDR Only                                     |
|       | <b>\1</b> |                                           | PARWEBS                                        |
| 30    | RO        | 0×0                                       | Bit status during a word error for the PAR_IN. |
|       |           |                                           | Only for DIMM parity support.                  |
| 29:20 | RO        | 0x0                                       | reserved                                       |
| 19    | RO        | 0×0                                       | CASWEBS                                        |
| 19    | RO        | UXU                                       | Bit status during a word error for the CAS.    |
| 18    | DO.       | $\begin{array}{c c} RO & 0x0 \end{array}$ | RASWEBS                                        |
| 10    | RO        | UXU                                       | Bit status during a word error for the RAS.    |
|       |           |                                           | DMWEBS                                         |
|       |           |                                           | Bit status during a word error for the data    |
| 17:16 | RO        | 0x0                                       | mask (DM) bit. DMWEBS [0] is for the first DM  |
|       |           |                                           | beat, and DMWEBS [1] is for the second DM      |
|       |           |                                           | beat.                                          |



| Bit  | Attr | Reset Value                                     | Description                                       |
|------|------|-------------------------------------------------|---------------------------------------------------|
|      |      |                                                 | DQWEBS                                            |
|      |      |                                                 | Bit status during a word error for each of the 8  |
|      |      |                                                 | data (DQ) bits. The first 8 bits indicate the     |
|      |      |                                                 | status of the first data beat (i.e. the status of |
|      |      |                                                 | the data driven out on DQ[7:0] on the rising      |
| 15:0 | RO   | 0x0000                                          | edge of DQS). The second 8 bits indicate the      |
|      |      | status of the second data beat (i.e. the status |                                                   |
|      |      | falling edge of DQS). For each of the           | of the data driven out on DQ[7:0] on the          |
|      |      |                                                 | falling edge of DQS). For each of the 8-bit       |
|      |      |                                                 | group, the first bit is for DQ[0], the second bit |
|      |      |                                                 | is for DQ[1], and so on.                          |

**DDR\_PHYCTL\_ZQ0CR0**Address: Operational Base + offset (0x0180)

ZQ 0 Impedance Control Register 0

| Bit      | Attr   | Reset Value | Description                                      |
|----------|--------|-------------|--------------------------------------------------|
|          |        |             | ZQPD                                             |
| 31       | RW     | 0x0         | ZQ Power Down: Powers down, if set, the PZQ      |
|          |        |             | cell.                                            |
|          |        |             | ZCAL                                             |
|          |        |             | Impedance Calibration Trigger: A write of '1'    |
|          |        |             | to this bit triggers impedance calibration to be |
| 30       | RW     | 0x0         | performed by the impedance control logic.        |
|          |        |             | The impedance calibration trigger bit is         |
|          |        | . ()        | self-clearing and returns back to '0' when the   |
|          |        | 1.5         | calibration is complete.                         |
|          |        |             | ZCALBYP                                          |
|          |        |             | Impedance Calibration Bypass: Disables, if       |
|          | 1      |             | set, impedance calibration of this ZQ control    |
| 29       | RW     | 0x0         | block when impedance calibration is triggered    |
| ,        |        |             | globally using the ZCAL bit of PIR. Impedance    |
|          | $\cup$ |             | calibration of this ZQ block may be triggered    |
|          | ~      |             | manually using ZCAL.                             |
| <i>y</i> |        |             | ZDEN                                             |
|          |        |             | Impedance Over-ride Enable: When this bit is     |
|          |        |             | set, it allows users to directly drive the       |
| 28       | RW     | 0x0         | impedance control using the                      |
|          |        |             | dataprogrammed in the ZQDATA field.              |
|          |        |             | Otherwise, the control is generated              |
|          |        |             | automatically by the impedance control logic     |



| 75 4 7 4                                                                                                                                                                                                                                                                                                                                                                                              |                                               |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|
| Impedance Over-Ride Data: Data directly drive the impedance control    ZDATA field mapping for D3R I/Os follows:  ZDATA[27:20] is reserved and retron reads  ZDATA[19:15] is used to select the on-die termination impedance  ZDATA[14:10] is used to select the on-die termination impedance  ZDATA[9:5] is used to select the poutput impedance  ZDATA[4:0] is used to select the poutput impedance | ol. s is as curns zeros e pull-up e pull-down |

## DDR\_PHYCTL\_ZQ0CR1

Address: Operational Base + offset (0x0184)

ZQ 0 Impedance Control Register 1

| Bit   | Attr | Reset Value | Description                                  |
|-------|------|-------------|----------------------------------------------|
| 31:8  | RO   | 0x0         | reserved                                     |
|       |      |             | ZPROG                                        |
|       |      |             | Impedance Divide Ratio: Selects the external |
|       |      | . ()        | resistor divide ratio to be used to set the  |
| 7:0 R | RW   | 0x7b        | output impedance and the on-die termination  |
| 7.0   | IXVV | OX/D        | as follows:                                  |
|       |      |             | ZPROG[7:4] = On-die termination divide       |
|       | 1    |             | select                                       |
|       |      |             | ZPROG[3:0] = Output impedance divide select  |

## DDR\_PHYCTL\_ZQ0SR0

Address: Operational Base + offset (0x0188)

ZQ 0 Impedance Status Register 0

| Bit | Attr             | Reset Value                              | Description                                    |
|-----|------------------|------------------------------------------|------------------------------------------------|
|     |                  |                                          | ZDONE                                          |
| 31  | RO               | 0x0                                      | Impedance Calibration Done: Indicates that     |
|     |                  |                                          | impedance calibration has completed.           |
| 30  |                  |                                          | ZERR                                           |
|     | RO               | 0×0                                      | Impedance Calibration Error: If set, indicates |
|     | that there was a | that there was an error during impedance |                                                |
|     |                  |                                          | calibration.                                   |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:28 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                          |
| 27:0  | RO   | 0x0000000   | ZCTRL Impedance Control: Current value of impedance control.  ZCTRL field mapping for D3R I/Os is as follows:  ZCTRL[27:20] is reserved and returns zeros on reads  ZCTRL[19:15] is used to select the pull-up on-die termination impedance  ZCTRL[14:10] is used to select the pull-down on-die termination impedance  ZCTRL[9:5] is used to select the pull-up output impedance |
|       |      |             | ZCTRL[4:0] is used to select the pull-down output impedance                                                                                                                                                                                                                                                                                                                       |

### DDR\_PHYCTL\_ZQ0SR1

Address: Operational Base + offset (0x018c)

ZQ 0 Impedance Status Register 1

| Bit  | Attr | Reset Value | Description                                     |
|------|------|-------------|-------------------------------------------------|
| 31:8 | RO   | 0x0         | reserved                                        |
|      |      |             | OPU                                             |
| 7:6  | RO   | 0x0         | On-die termination (ODT) pull-up calibration    |
|      |      | 1,5         | status. Similar status encodings as ZPD.        |
|      |      |             | OPD                                             |
| 5:4  | RO   | 0×0         | On-die termination (ODT) pull-down              |
| 3.4  | KO 1 | UXU         | calibration status. Similar status encodings as |
|      |      | 7           | ZPD.                                            |
|      |      |             | ZPU                                             |
| 3:2  | RO   | 0x0         | Output impedance pull-up calibration status.    |
|      | V    |             | Similar status encodings as ZPD.                |
| 7    |      |             | ZPD                                             |
|      |      | 0x0         | Output impedance pull-down calibration          |
|      |      |             | status. Valid status encodings are:             |
| 1:0  | RO   |             | 00 = Completed with no errors                   |
|      |      |             | 01 = Overflow error                             |
|      |      |             | 10 = Underflow error                            |
|      |      |             | 11 = Calibration in progress                    |

#### DDR\_PHYCTL\_ZQ1CR0



Address: Operational Base + offset (0x0190) ZQ 1 Impedance Control Register 0

| Bit  | Attr | Reset Value | Description                                      |
|------|------|-------------|--------------------------------------------------|
|      |      |             | ZQPD                                             |
| 31   | RW   | 0x0         | ZQ Power Down: Powers down, if set, the PZQ      |
|      |      |             | cell.                                            |
|      |      |             | ZCAL                                             |
|      |      |             | Impedance Calibration Trigger: A write of '1'    |
|      |      |             | to this bit triggers impedance calibration to be |
| 30   | RW   | 0x0         | performed by the impedance control logic.        |
|      |      |             | The impedance calibration trigger bit is         |
|      |      |             | self-clearing and returns back to '0' when the   |
|      |      |             | calibration is complete.                         |
|      |      |             | ZCALBYP                                          |
|      |      |             | Impedance Calibration Bypass: Disables, if       |
|      |      |             | set, impedance calibration of this ZQ control    |
| 29   | RW   | 0x0         | block when impedance calibration is triggered    |
|      |      |             | globally using the ZCAL bit of PIR. Impedance    |
|      |      |             | calibration of this ZQ block may be triggered    |
|      |      |             | manually using ZCAL.                             |
|      |      |             | ZDEN                                             |
|      |      |             | Impedance Over-ride Enable: When this bit is     |
|      |      |             | set, it allows users to directly drive           |
| 28   | RW   | 0x0         | the impedance control using the data             |
|      |      |             | programmed in the ZQDATA field. Otherwise,       |
|      |      |             | the control is generated automatically by the    |
|      |      | `~~         | impedance control logic                          |
|      |      | 10 Y        | ZDATA                                            |
|      |      |             | Impedance Over-Ride Data: Data used to           |
|      | A 4  |             | directly drive the impedance control.            |
|      |      | -           |                                                  |
|      |      | <i>Y</i>    | ZDATA field mapping for D3R I/Os is as           |
|      |      |             | follows:                                         |
|      |      |             | ZDATA[27:20] is reserved and returns zeros       |
| 27:0 | RW   | 0x000014a   | on reads                                         |
|      |      | 5,100001 Tu | ZDATA[19:15] is used to select the pull-up       |
|      |      |             | on-die termination impedance                     |
|      |      |             | ZDATA[14:10] is used to select the pull-down     |
|      |      |             | on-die termination impedance                     |
|      |      |             | ZDATA[9:5] is used to select the pull-up         |
|      |      |             | output impedance                                 |
|      |      |             | ZDATA[4:0] is used to select the pull-down       |
|      |      |             | output impedance                                 |



## DDR\_PHYCTL\_ZQ1CR1

Address: Operational Base + offset (0x0194)

ZQ 1 Impedance Control Register 1

| Bit  | Attr | Reset Value | Description                                  |
|------|------|-------------|----------------------------------------------|
| 31:8 | RO   | 0x0         | reserved                                     |
|      |      |             | ZPROG                                        |
|      |      | 0x7b        | Impedance Divide Ratio: Selects the external |
| 7:0  | RW   |             | resistor divide ratio to be used to set the  |
|      |      |             | output impedance and the on-die termination  |
|      | IXVV |             | as follows:                                  |
|      |      |             | ZPROG[7:4] = On-die termination divide       |
|      |      |             | select                                       |
|      |      |             | ZPROG[3:0] = Output impedance divide select  |

## DDR\_PHYCTL\_ZQ1SR0

Address: Operational Base + offset (0x0198)

ZQ 1 Impedance Status Register 0

| Bit   | Attr | Reset Value | Description                                    |
|-------|------|-------------|------------------------------------------------|
|       |      |             | ZDONE                                          |
| 31    | RO   | 0x0         | Impedance Calibration Done: Indicates that     |
|       |      |             | impedance calibration has completed.           |
|       |      |             | ZERR                                           |
| 30    | RO   | 0x0         | Impedance Calibration Error: If set, indicates |
| 30    | KO   | 0.00        | that there was an error during                 |
|       |      |             | impedance calibration.                         |
| 29:28 | RO   | 0x0         | reserved                                       |
|       |      | * \         | ZCTRL                                          |
|       |      | O 0x0000000 | Impedance Control: Current value of            |
|       | RO   |             | impedance control.                             |
|       |      |             |                                                |
|       |      |             | ZCTRL field mapping for D3R I/Os is as         |
|       |      |             | follows:                                       |
|       |      |             | ZCTRL[27:20] is reserved and returns zeros     |
| 27:0  |      |             | on reads                                       |
| 27.0  |      |             | ZCTRL[19:15] is used to select the pull-up     |
|       |      |             | on-die termination impedance                   |
|       |      |             | ZCTRL[14:10] is used to select the pull-down   |
|       |      |             | on-die termination impedance                   |
|       |      |             | ZCTRL[9:5] is used to select the pull-up       |
|       |      |             | output impedance                               |
|       |      |             | ZCTRL[4:0] is used to select the pull-down     |
|       |      |             | output impedance                               |

#### DDR\_PHYCTL\_ZQ1SR1



Address: Operational Base + offset (0x019c)

ZQ 1 Impedance Status Register 1

| Bit  | Attr | Reset Value | Description                                     |
|------|------|-------------|-------------------------------------------------|
| 31:8 | RO   | 0x0         | reserved                                        |
|      |      |             | OPU                                             |
| 7:6  | RO   | 0x0         | On-die termination (ODT) pull-up calibration    |
| 7.0  | KO   | UXU         | status. Similar status encodings as             |
|      |      |             | ZPD.                                            |
|      |      |             | OPD                                             |
| 5:4  | RO   | 0×0         | On-die termination (ODT) pull-down              |
| 5.4  | IKO  | 0.00        | calibration status. Similar status encodings as |
|      |      |             | ZPD.                                            |
|      |      |             | ZPU                                             |
| 3:2  | RO   | 0x0         | Output impedance pull-up calibration status.    |
|      |      |             | Similar status encodings as ZPD.                |
|      |      |             | ZPD                                             |
|      |      |             | Output impedance pull-down calibration          |
|      |      |             | status. Valid status encodings are:             |
| 1:0  | RO   | 0×0         | 00 = Completed with no errors                   |
|      |      |             | 01 = Overflow error                             |
|      |      |             | 10 = Underflow error                            |
|      |      |             | 11 = Calibration in progress                    |

#### DDR\_PHYCTL\_ZQ2CR0

Address: Operational Base + offset (0x01a0)

ZQ 2 Impedance Control Register 0

| Bit | Attr | Reset Value | Description                                      |
|-----|------|-------------|--------------------------------------------------|
|     |      | V A         | ZQPD                                             |
| 31  | RW   | 0x0         | ZQ Power Down: Powers down, if set, the PZQ      |
|     | A 1  |             | cell.                                            |
|     |      |             | ZCAL                                             |
|     |      |             | Impedance Calibration Trigger: A write of '1'    |
|     |      |             | to this bit triggers impedance calibration to be |
| 30  | RW   | 0x0         | performed by the impedance control logic.        |
|     |      |             | The impedance calibration trigger bit is         |
|     |      |             | self-clearing and returns back to '0' when the   |
|     |      |             | calibration is complete.                         |
|     |      |             | ZCALBYP                                          |
|     |      |             | Impedance Calibration Bypass: Disables, if       |
|     |      |             | set, impedance calibration of this ZQ control    |
| 29  | RW   | 0x0         | block when impedance calibration is triggered    |
|     |      |             | globally using the ZCAL bit of PIR. Impedance    |
|     |      |             | calibration of this ZQ block may be triggered    |
|     |      |             | manually using ZCAL.                             |



| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28   | RW   | 0×0         | ZDEN Impedance Over-ride Enable: When this bit is set, it allows users to directly drive the impedance control using the data programmed in the ZQDATA field. Otherwise, the control is generated automatically by the impedance control logic                                                                                                                                                                                                                 |
| 27:0 | RW   | 0x000014a   | Impedance Over-Ride Data: Data used to directly drive the impedance control.  ZDATA field mapping for D3R I/Os is as follows:  ZDATA[27:20] is reserved and returns zeros on reads  ZDATA[19:15] is used to select the pull-up on-die termination impedance  ZDATA[14:10] is used to select the pull-down on-die termination impedance  ZDATA[9:5] is used to select the pull-up output impedance  ZDATA[4:0] is used to select the pull-down output impedance |

#### DDR\_PHYCTL\_ZQ2CR1

Address: Operational Base + offset (0x01a4)

70.2 Impedance Control Register 1

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                  |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0         | reserved                                                                                                                                                                                                                                     |
|      |      | 7           | ZPROG                                                                                                                                                                                                                                        |
| 7:0  | RW   | 0x7b        | Impedance Divide Ratio: Selects the external resistor divide ratio to be used to set the output impedance and the on-die termination as follows:  ZPROG[7:4] = On-die termination divide select  ZPROG[3:0] = Output impedance divide select |

#### DDR\_PHYCTL\_ZQ2SR0

Address: Operational Base + offset (0x01a8)

ZQ 2 Impedance Status Register 0

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|



| Bit   | Attr | Reset Value | Description                                         |
|-------|------|-------------|-----------------------------------------------------|
|       |      |             | ZDONE                                               |
| 31    | RO   | 0x0         | Impedance Calibration Done: Indicates that          |
|       |      |             | impedance calibration has completed.                |
|       |      |             | ZERR                                                |
| 30    | RO   | 0x0         | Impedance Calibration Error: If set, indicates      |
| 30    | KO   | OXO         | that there was an error during                      |
|       |      |             | impedance calibration.                              |
| 29:28 | RO   | 0x0         | reserved                                            |
|       |      |             | ZCTRL                                               |
|       |      |             | Impedance Control: Current value of                 |
|       |      |             | impedance control.                                  |
|       |      |             | ZCTRL field mapping for D3R I/Os is as              |
|       | RO   | 0x000000    | follows:                                            |
|       |      |             | ZCTRL[27:20] is reserved and returns zeros on reads |
| 27:0  |      |             | ZCTRL[19:15] is used to select the pull-up          |
|       |      |             | on-die termination impedance                        |
|       |      |             | ZCTRL[14:10] is used to select the pull-down        |
|       |      |             | on-die termination impedance                        |
|       |      |             | ZCTRL[9:5] is used to select the pull-up            |
|       |      |             | output impedance                                    |
|       |      |             | ZCTRL[4:0] is used to select the pull-down          |
|       |      |             | output impedance                                    |

# DDR\_PHYCTL\_ZQ2SR1

Address: Operational Base + offset (0x01ac)

ZQ 2 Impedance Status Register 1

| Bit  | Attr | Reset Value | Description                                     |
|------|------|-------------|-------------------------------------------------|
| 31:8 | RO   | 0x0         | reserved                                        |
|      |      |             | OPU                                             |
| 7:6  | RO   | 0×0         | On-die termination (ODT) pull-up calibration    |
| 7.0  | KU   | UXU         | status. Similar status encodings as             |
| 7    |      |             | ZPD.                                            |
|      |      |             | OPD                                             |
| 5:4  | RO   | 0×0         | On-die termination (ODT) pull-down              |
| 3.4  | KO   | 0.00        | calibration status. Similar status encodings as |
|      |      |             | ZPD.                                            |
|      |      |             | ZPU                                             |
| 3:2  | RO   | 0x0         | Output impedance pull-up calibration status.    |
|      |      |             | Similar status encodings as ZPD.                |



| Bit | Attr | Reset Value | Description                            |
|-----|------|-------------|----------------------------------------|
|     |      |             | ZPD                                    |
|     |      |             | Output impedance pull-down calibration |
|     |      |             | status. Valid status encodings are:    |
| 1:0 | RO   | 0x0         | 00 = Completed with no errors          |
|     |      |             | 01 = Overflow error                    |
|     |      |             | 10 = Underflow error                   |
|     |      |             | 11 = Calibration in progress           |

## DDR\_PHYCTL\_ZQ3CR0

Address: Operational Base + offset (0x01b0)

ZQ 3 Impedance Control Register 0

| Bit | Attr | Reset Value    | Description                                      |
|-----|------|----------------|--------------------------------------------------|
|     |      |                | ZQPD                                             |
| 31  | RW   | 0x0            | ZQ Power Down: Powers down, if set, the PZQ      |
|     |      |                | cell.                                            |
|     |      |                | ZCAL                                             |
|     |      |                | Impedance Calibration Trigger: A write of '1'    |
|     |      |                | to this bit triggers impedance calibration to be |
| 30  | RW   | 0x0            | performed by the impedance control logic.        |
|     |      |                | The impedance calibration trigger bit is         |
|     |      |                | self-clearing and returns back to '0' when the   |
|     |      |                | calibration is complete.                         |
|     |      |                | ZCALBYP                                          |
|     | RW   |                | Impedance Calibration Bypass: Disables, if       |
|     |      | • 1            | set, impedance calibration of this ZQ control    |
| 29  |      | 0x0            | block when impedance calibration is triggered    |
|     |      |                | globally using the ZCAL bit of PIR. Impedance    |
|     |      | $(C)^{\gamma}$ | calibration of this ZQ block may be triggered    |
|     |      | 7              | manually using ZCAL.                             |
|     |      | ·              | ZDEN                                             |
| 28  |      |                | Impedance Over-ride Enable: When this bit is     |
|     | RW   |                | set, it allows users to directly drive the       |
|     |      | 0x0            | impedance control using the data                 |
|     |      |                | programmed in the ZQDATA field. Otherwise,       |
|     |      |                | the control is generated automatically by the    |
|     |      |                | impedance control logic                          |



| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27:0 | RW   | 0x000014a   | ZDATA Impedance Over-Ride Data: Data used to directly drive the impedance control.  ZDATA field mapping for D3R I/Os is as follows: ZDATA[27:20] is reserved and returns zeros on reads ZDATA[19:15] is used to select the pull-up on-die termination impedance ZDATA[14:10] is used to select the pull-down on-die termination impedance ZDATA[9:5] is used to select the pull-up output impedance ZDATA[4:0] is used to select the pull-down |
|      |      |             | output impedance                                                                                                                                                                                                                                                                                                                                                                                                                               |

## DDR\_PHYCTL\_ZQ3CR1

Address: Operational Base + offset (0x01b4)

ZQ 3 Impedance Control Register 1

| Bit  | Attr | Reset Value | Description                                  |
|------|------|-------------|----------------------------------------------|
| 31:8 | RO   | 0x0         | reserved                                     |
| 7:0  |      |             | ZPROG                                        |
|      |      |             | Impedance Divide Ratio: Selects the external |
|      | RW   |             | resistor divide ratio to be used to set the  |
|      |      |             | output impedance and the on-die termination  |
|      |      |             | as follows:                                  |
|      |      |             | ZPROG[7:4] = On-die termination divide       |
|      | 1    |             | select                                       |
|      |      |             | ZPROG[3:0] = Output impedance divide select  |

## DDR\_PHYCTL\_ZQ3SR0

Address: Operational Base + offset (0x01b8)

ZQ 3 Impedance Status Register 0

| Bit | Attr | Reset Value | Description                                    |
|-----|------|-------------|------------------------------------------------|
| 31  | RO   | 0x0         | ZDONE                                          |
|     |      |             | Impedance Calibration Done: Indicates that     |
|     |      |             | impedance calibration has completed.           |
| 30  | RO   | 0x0         | ZERR                                           |
|     |      |             | Impedance Calibration Error: If set, indicates |
|     |      |             | that there was an error during                 |
|     |      |             | impedance calibration.                         |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:28 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                          |
| 27:0  | RO   | 0×0000000   | ZCTRL Impedance Control: Current value of impedance control.  ZCTRL field mapping for D3R I/Os is as follows:  ZCTRL[27:20] is reserved and returns zeros on reads  ZCTRL[19:15] is used to select the pull-up on-die termination impedance  ZCTRL[14:10] is used to select the pull-down on-die termination impedance  ZCTRL[9:5] is used to select the pull-up output impedance |
|       |      |             | ZCTRL[4:0] is used to select the pull-down output impedance                                                                                                                                                                                                                                                                                                                       |

#### DDR\_PHYCTL\_ZQ3SR1

Address: Operational Base + offset (0x01bc)

ZQ 3 Impedance Status Register 1

| Bit  | Attr | Reset Value | Description                                                                                                                                                                        |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0         | reserved                                                                                                                                                                           |
| 7:6  | RO   | 0x0         | OPU On-die termination (ODT) pull-up calibration status. Similar status encodings as ZPD.                                                                                          |
| 5:4  | RO   | 0×0         | OPD On-die termination (ODT) pull-down calibration status. Similar status encodings as ZPD.                                                                                        |
| 3:2  | RO   | 0x0         | ZPU Output impedance pull-up calibration status. Similar status encodings as ZPD.                                                                                                  |
| 1:0  | RO   | 0x0         | ZPD Output impedance pull-down calibration status. Valid status encodings are: 00 = Completed with no errors 01 = Overflow error 10 = Underflow error 11 = Calibration in progress |



# DDR\_PHYCTL\_DX0GCR

Address: Operational Base + offset (0x01c0) DATX8 0 General Configuration Register

| Bit   | Attr     | Reset Value | Description                                        |
|-------|----------|-------------|----------------------------------------------------|
| 31:14 | RO       | 0x0         | reserved                                           |
|       |          |             | RTTOAL                                             |
|       |          |             | RTT On Additive Latency: Indicates when the        |
|       |          |             | ODT control of DQ/DQS SSTL I/Os is set to the      |
|       |          |             | value in DQODT/DQSODT during read cycles.          |
| 13    | RW       | 0x0         | Valid values are:                                  |
|       |          |             | 0 = ODT control is set to DQSODT/DQODT             |
|       |          |             | almost two cycles before read data preamble        |
|       |          |             | 1 = ODT control is set to DQSODT/DQODT             |
|       |          |             | almost one cycle before read data preamble         |
|       |          |             | RTTOH                                              |
|       |          |             | RTT Output Hold: Indicates the number of           |
|       |          |             | clock cycles (from 0 to 3) after the read data     |
|       |          |             | postamble for which ODT control should             |
| 12:11 | RW       | 0x0         | remain set to DQSODT for DQS or DQODT for          |
|       |          |             | DQ/DM before disabling it (setting it to '0'       |
|       |          |             | when using dynamic ODT control. ODT is             |
|       |          |             | disabled almost RTTOH clock cycles after the       |
|       |          |             | read postamble                                     |
|       |          |             | DQRTT                                              |
|       |          |             | DQ Dynamic RTT Control: Indicates, if set,         |
|       |          |             | that the ODT control of DQ/DM SSTL I/Os be         |
| 10    | RW       | 0x1         | dynamically controlled by setting it to the        |
|       | IXVV     | OXI         | value in DQODT during reads and disabling it       |
|       |          |             | (setting it to '0' during any other cycle. If this |
|       | <b>.</b> | ( ) ,       | bit is not set, then the ODT control of DQ SSTL    |
|       |          |             | I/Os is always set to the value in DQODT.          |
|       |          | 7           | DQSRTT                                             |
|       |          |             | DQS Dynamic RTT Control: Indicates, if set,        |
|       |          |             | that the ODT control of DQS SSTL I/Os be           |
|       |          |             | dynamically controlled by setting it to the        |
| 9     | RW       | 0x1         | value in DQSODT during reads and disabling it      |
|       |          |             | (setting it to 0 during any other cycle. If this   |
|       |          |             | bit is not set, then the ODT control of DQS        |
|       |          |             | SSTL I/Os is always set to the value in            |
|       |          |             | DQSODT field.                                      |



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:7 | RW   | 0x1         | DSEN Write DQS Enable: Controls whether the write DQS going to the SDRAM is enabled (toggling) or disabled (static value) and whether the DQS is inverted. DQS# is always the inversion of DQS. These values are valid only when DQS/DQS# output enable is on, otherwise the DQS/DQS# is tristated. Valid settings are: 00 = DQS disabled (Driven to constant 0) 01 = DQS toggling with inverted polarity 10 = DQS toggling with normal polarity (This should be the default setting) 11 = DQS disabled (Driven to constant 1) |
| 6   | RW   | 0×0         | DQSRPD DQSR Power Down: Powers down, if set, the PDQSR cell. This bit is ORed with the common PDR configuration bit                                                                                                                                                                                                                                                                                                                                                                                                            |
| 5   | RW   | 0x0         | DXPDR Data Power Down Receiver: Powers down, when set, the input receiver on I/O for DQ, DM, and DQS/DQS# pins of the byte. This bit is ORed with the common PDR configuration bit                                                                                                                                                                                                                                                                                                                                             |
| 4   | RW   | 0x0         | DXPDD Data Power Down Driver: Powers down, when set, the output driver on I/O for DQ, DM, and DQS/DQS# pins of the byte. This bit is ORed with the common PDD configuration bit                                                                                                                                                                                                                                                                                                                                                |
| 3   | RW   | 0×0         | DXIOM Data I/O Mode: Selects SSTL mode (when set to 0) or CMOS mode (when set to 1) of the I/O for DQ, DM, and DQS/DQS# pins of the byte. This bit is ORed with the IOM configuration bit of the individual DATX8                                                                                                                                                                                                                                                                                                              |
| 2   | RW   | 0x0         | DQODT Data On-Die Termination: Enables, when set, the on-die termination on the I/O for DQ and DM pins of the byte. This bit is ORed with the common DATX8 ODT configuration bit                                                                                                                                                                                                                                                                                                                                               |



| Bit | Attr | Reset Value | Description                                      |
|-----|------|-------------|--------------------------------------------------|
|     |      |             | DQSODT                                           |
|     |      |             | DQS On-Die Termination: Enables, when set,       |
| 1   | RW   | 0×0         | the on-die termination on the I/O for            |
|     |      |             | DQS/DQS# pin of the byte. This bit is ORed       |
|     |      |             | with the common DATX8 ODT configuration bit      |
|     |      | 0x1         | DXEN                                             |
|     | RW   |             | Data Byte Enable: Enables if set the DATX8       |
| 0   |      |             | and SSTL I/Os used on the data byte. Setting     |
|     |      |             | this bit to '0' disables the byte, i.e. the byte |
|     |      |             | SSTL I/Os are put in power-down mode and         |
|     |      |             | the DLL in the DATX8 is put in bypass mode.      |

## DDR\_PHYCTL\_DX0GSR0

Address: Operational Base + offset (0x01c4)

DATX8 0 General Status Register 0

| Bit                                   | Attr | Reset Value | Description                                        |
|---------------------------------------|------|-------------|----------------------------------------------------|
| 31:25                                 | RO   | 0x0         | reserved                                           |
|                                       |      |             | DTPASS                                             |
|                                       |      |             | Data Training Pass Count: The number of            |
| 24:13                                 | RO   | 0x000       | passing configurations during DQS gate             |
|                                       |      |             | training. Bits [2:0] are for rank 0, bits [5:3]    |
|                                       |      |             | for rank 1, and so on.                             |
| 12                                    | RO   | 0x0         | reserved                                           |
|                                       |      |             | DTIERR                                             |
|                                       |      | • 0         | Data Training Intermittent Error: If set,          |
|                                       |      |             | indicates that there was an intermittent error     |
| 11:8                                  | RO   | 0x0         | during data training of the byte, such as a pass   |
|                                       |      |             | was followed by a fail then followed by another    |
|                                       | 1    |             | pass. Bit [0] is for rank 0, bit 1 for rank 1, and |
|                                       |      | 7           | so on.                                             |
|                                       |      |             | DTERR                                              |
| 0                                     |      |             | Data Training Error: If set, indicates that a      |
| 7:4                                   | RO   | 0x0         | valid DQS gating window could not be found         |
| , , , , , , , , , , , , , , , , , , , |      |             | during data training of the byte. Bit [0] is for   |
|                                       |      |             | rank 0, bit 1 for rank 1, and so on.               |
|                                       |      |             | DTDONE                                             |
| 3:0                                   | RO   | 0×0         | Data Training Done: Indicates, if set, that the    |
| 3.0                                   | INO  |             | byte has finished doing data training. Bit [0] is  |
|                                       |      |             | for rank 0, bit 1 for rank 1, and so on.           |

### DDR\_PHYCTL\_DX0GSR1

Address: Operational Base + offset (0x01c8)



DATX8 0 General Status Register 1

| Bit   | Attr | Reset Value | Description                                       |
|-------|------|-------------|---------------------------------------------------|
| 31:12 | RO   | 0x0         | reserved                                          |
|       |      |             | DQSDFT                                            |
|       |      |             | DQS Drift: Used to report the drift on the read   |
|       |      |             | data strobe of the data byte. Valid settings      |
|       |      |             | are:                                              |
| 11:4  | RO   | 0×00        | 00 = No drift                                     |
| 11.4  | RO   | UXUU        | 01 = 90 deg drift                                 |
|       |      |             | 10 = 180 deg drift                                |
|       |      |             | 11 = 270 deg drift or more                        |
|       |      |             | Bits [1:0] are for rank 0, bits [3:2] for rank 1, |
|       |      |             | and so on.                                        |
|       |      | 0×0         | DFTERR                                            |
|       |      |             | DQS Drift Error: If set, indicates that the byte  |
| 3:0   | RO   |             | read data strobe has drifted by more than or      |
|       | RO   |             | equal to the drift limit set in the PHY General   |
|       |      |             | Configuration Register (PGCR). Bit [0] is for     |
|       |      |             | rank 0, bit 1 for rank 1, and so on.              |

### DDR\_PHYCTL\_DX0DLLCR

Address: Operational Base + offset (0x01cc)

DATX8 0 DLL Control Register

| Bit   | Attr | Reset Value | Description                                      |
|-------|------|-------------|--------------------------------------------------|
|       |      |             | DLLDIS                                           |
| 31    | RW   | 0x0         | DLL Disable: A disabled DLL is bypassed.         |
|       |      |             | Default ('0') is DLL enabled.                    |
|       |      | N, Y        | DLLSRST                                          |
| 30    | RW   | 0x1         | DLL Soft Rest: Soft resets the byte DLL by       |
|       | 41   |             | driving the DLL soft reset pin.                  |
| 29:20 | RO   | 0x0         | reserved                                         |
|       |      |             | SDLBMODE                                         |
|       |      |             | Slave DLL Loopback Mode: If this bit is set, the |
|       |      |             | slave DLL is put in loopback mode in which       |
|       |      |             | there is no 90 degrees phase shift on read       |
| 19    | RW   | 0x0         | DQS/DQS#. This bit must be set when              |
|       |      |             | operating the byte PHYs in loopback mode         |
|       |      |             | such as during BIST loopback. Applicable only    |
|       |      |             | to PHYs that have this feature. Refer to PHY     |
|       |      |             | databook.                                        |



| Bit   | Attr | Reset Value | Description                                    |
|-------|------|-------------|------------------------------------------------|
|       |      |             | ATESTEN                                        |
|       |      |             | Analog Test Enable: Enables the analog test    |
| 18    | RW   | 0x0         | signal to be output on the DLL analog test     |
|       |      |             | output (test_out_a). The DLL analog test       |
|       |      |             | output is tri-stated when this bit is '0'.     |
|       |      |             | SDPHASE                                        |
|       |      |             | Slave DLL Phase Trim: Selects the phase        |
|       |      |             | difference between the input clock and the     |
|       |      |             | corresponding output clock of the slave DLL.   |
|       |      |             | Valid settings:                                |
|       |      |             | 0000 = 90                                      |
|       |      |             | 0001 = 72                                      |
|       |      |             | 0010 = 54                                      |
|       |      |             | 0011 = 36                                      |
|       |      |             | 0100 = 108                                     |
| 17:14 | RW   | 0x0         | 0101 = 90                                      |
|       |      |             | 0110 = 72                                      |
|       |      |             | 0111 = 54                                      |
|       |      |             | 1000 = 126                                     |
|       |      |             | 1001 = 108                                     |
|       |      |             | 1010 = 90                                      |
|       |      |             | 1011 = 72                                      |
|       |      |             | 1100 = 144                                     |
|       |      |             | 1101 = 126                                     |
|       |      |             | 1110 = 108                                     |
|       |      |             | 1111 = 90                                      |
|       |      | V Y         | SSTART                                         |
|       |      |             | Slave Auto Start-Up: Used to control how the   |
|       | 1    |             | slave DLL starts up relative to the master DLL |
|       |      | 7           | locking:                                       |
| 13:12 | RW   | 0×0         | 0X = Slave DLL automatically starts up once    |
| 15.12 |      | OXO         | the master DLL has achieved lock.              |
|       |      |             | 10 = The automatic startup of the slave DLL is |
|       |      |             | disabled; the phase detector is disabled.      |
|       |      |             | 11 = The automatic startup of the slave DLL is |
|       |      |             | disabled; the phase detector is enabled.       |
|       |      |             | MFWDLY                                         |
|       | RW   |             | Master Feed-Forward Delay Trim: Used to trim   |
| 11:9  |      | 0×0         | the delay in the master DLL feed-forward       |
| 11.5  |      |             | path:                                          |
|       |      |             | 000 = minimum delay                            |
|       |      |             | 111 = maximum delay                            |



| Bit | Attr | Reset Value | Description                                   |
|-----|------|-------------|-----------------------------------------------|
|     |      |             | MFBDLY                                        |
|     |      |             | Master Feed-Back Delay Trim: Used to trim     |
| 8:6 | RW   | 0x0         | the delay in the master DLL feedback path:    |
|     |      |             | 000 = minimum delay                           |
|     |      |             | 111 = maximum delay                           |
|     |      |             | SFWDLY                                        |
|     |      |             | Slave Feed-Forward Delay Trim: Used to trim   |
| 5:3 | RW   | 0x0         | the delay in the slave DLL feed-forward path: |
|     |      |             | 000 = minimum delay                           |
|     |      |             | 111 = maximum delay                           |
|     |      |             | SFBDLY                                        |
|     |      |             | Slave Feed-Back Delay Trim: Used to trim the  |
| 2:0 | RW   | 0x0         | delay in the slave DLL feedback path:         |
|     |      |             | 000 = minimum delay                           |
|     |      |             | 111 = maximum delay                           |

# DDR\_PHYCTL\_DX0DQTR

Address: Operational Base + offset (0x01d0)

DATX8 0 DQ Timing Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | RW   | 0xf         | DQDLY7 DQ Delay: Used to adjust the delay of the data relative to the nominal delay that is matched to the delay of the data strobes through the slave DLL and clock tree. Every four bits of this register control the delay of a different data bit in the byte. DQDLY0 controls the delay of data bit [0], DQDLY1 controls data bit [1], and so on. The lower two bits of the DQDLY for each DQ bit controls the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS_b. Valid settings for each 2-bit control field are:  00 = nominal delay 01 = nominal delay + 1 step 10 = nominal delay + 2 steps 11 = nominal delay + 3 steps |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      |             | DQDLY6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 27:24 | RW   | 0xf         | DQ Delay: Used to adjust the delay of the data relative to the nominal delay that is matched to the delay of the data strobes through the slave DLL and clock tree. Every four bits of this register control the delay of a different data bit in the byte. DQDLY0 controls the delay of data bit [0], DQDLY1 controls data bit [1], and so on. The lower two bits of the DQDLY for each DQ bit controls the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS_b. Valid settings for each 2-bit control field are:  00 = nominal delay 01 = nominal delay + 1 step 10 = nominal delay + 2 steps                                                                                                              |
| 23:20 | RW   | 0xf         | DQDLY5 DQ Delay: Used to adjust the delay of the data relative to the nominal delay that is matched to the delay of the data strobes through the slave DLL and clock tree. Every four bits of this register control the delay of a different data bit in the byte. DQDLY0 controls the delay of data bit [0], DQDLY1 controls data bit [1], and so on. The lower two bits of the DQDLY for each DQ bit controls the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS_b. Valid settings for each 2-bit control field are:  00 = nominal delay 01 = nominal delay + 1 step 10 = nominal delay + 2 steps 11 = nominal delay + 3 steps |



00 = nominal delay

01 = nominal delay + 1 step 10 = nominal delay + 2 steps 11 = nominal delay + 3 steps

DQ bit controls the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS\_b. Valid settings for each 2-bit control field are:



| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |             | DQDLY2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 11:8 | RW   | 0xf         | DQ Delay: Used to adjust the delay of the data relative to the nominal delay that is matched to the delay of the data strobes through the slave DLL and clock tree. Every four bits of this register control the delay of a different data bit in the byte. DQDLY0 controls the delay of data bit [0], DQDLY1 controls data bit [1], and so on. The lower two bits of the DQDLY for each DQ bit controls the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS_b. Valid settings for each 2-bit control field are:  00 = nominal delay 01 = nominal delay + 1 step 10 = nominal delay + 2 steps                                                                                                              |
| 7:4  | RW   | 0xf         | DQDLY1 DQ Delay: Used to adjust the delay of the data relative to the nominal delay that is matched to the delay of the data strobes through the slave DLL and clock tree. Every four bits of this register control the delay of a different data bit in the byte. DQDLY0 controls the delay of data bit [0], DQDLY1 controls data bit [1], and so on. The lower two bits of the DQDLY for each DQ bit controls the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS_b. Valid settings for each 2-bit control field are:  00 = nominal delay 01 = nominal delay + 1 step 10 = nominal delay + 2 steps 11 = nominal delay + 3 steps |



| Bit | Attr | Reset Value | Description                                        |
|-----|------|-------------|----------------------------------------------------|
|     |      |             | DQDLY0                                             |
|     |      |             | DQ Delay: Used to adjust the delay of the data     |
|     |      |             | relative to the nominal delay that is matched      |
|     |      |             | to the delay of the data strobes through the       |
|     |      |             | slave DLL and clock tree. Every four bits of this  |
|     |      |             | register control the delay of a different data bit |
|     |      |             | in the byte. DQDLY0 controls the delay of data     |
|     |      |             | bit [0], DQDLY1 controls data bit [1], and so      |
| 3:0 | RW   | 0xf         | on. The lower two bits of the DQDLY for each       |
|     |      |             | DQ bit controls the delay for the data clocked     |
|     |      |             | by DQS, while the higher two bits control the      |
|     |      |             | delay for the data clocked by DQS_b. Valid         |
|     |      |             | settings for each 2-bit control field are:         |
|     |      |             | 00 = nominal delay                                 |
|     |      |             | 01 = nominal delay + 1 step                        |
|     |      |             | 10 = nominal delay + 2 steps                       |
|     |      |             | 11 = nominal delay + 3 steps                       |

## DDR\_PHYCTL\_DX0DQSTR

Address: Operational Base + offset (0x01d4)
DATX8 0 DQS Timing Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 29:26 | RW   | 0xf         | DMDLY DM Delay: Used to adjust the delay of the data mask relative to the nominal delay that is matched to the delay of the data strobes through the slave DLL and clock tree. The lower two bits of the DQMDLY controls the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS_b. Valid settings for each 2-bit control field are:  00 = nominal delay 01 = nominal delay + 1 step 10 = nominal delay + 2 steps |
|       |      |             | 11 = nominal delay + 3 steps                                                                                                                                                                                                                                                                                                                                                                                                                                             |

011 = nominal delay

100 = nominal delay + 1 step 101 = nominal delay + 2 steps 110 = nominal delay + 3 steps 111 = nominal delay + 4 steps

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19:18 | RW   | 0x1         | R3DGPS Rank n DQS Gating Phase Select: Selects the clock used to enable the data strobes during read so that the value of the data strobes before and after the preamble/postamble are filtered out. The RnDGPS fields are initially set by the PHYCTL during automatic DQS data training and subsequently updated during data strobe drift compensation. However, these values can be overwritten by a direct write to this register, and the automatic update during DQS drift compensation can be disabled using the PHY General Configuration Register (PGCR). Every two bits of this register control the DQS gating for each of the (up to) four ranks. R0DGPS controls the DQS gating for rank 0, R1DGPS controls rank 1, and so on. Valid values for each 2-bit RnDGPS field are: 00 = 90 deg clock (clk90) 01 = 180 deg clock (clk180) 10 = 270 deg clock (clk270) 11 = 360 deg clock (clk0) |

Rockenije

| Bit   | Attr   | Reset Value | Description                                       |
|-------|--------|-------------|---------------------------------------------------|
|       |        |             | R2DGPS                                            |
|       |        |             | Rank n DQS Gating Phase Select: Selects the       |
|       |        |             | clock used to enable the data strobes during      |
|       |        |             | read so that the value of the data strobes        |
|       |        |             | before and after the preamble/postamble are       |
|       |        |             | filtered out. The RnDGPS fields are initially set |
|       |        |             | by the PHYCTL during automatic DQS data           |
|       |        | 0x1         | training and subsequently updated during data     |
|       |        |             | strobe drift compensation. However, these         |
|       |        |             | values can be overwritten by a direct write to    |
| 17:16 | RW     |             | this register, and the automatic update during    |
| 17.10 | IX V V | OXI         | DQS drift compensation can be disabled using      |
|       |        |             | the PHY General Configuration Register            |
|       |        |             | (PGCR). Every two bits of this register control   |
|       |        |             | the DQS gating for each of the (up to) four       |
|       |        |             | ranks. R0DGPS controls the DQS gating for         |
|       |        |             | rank 0, R1DGPS controls rank 1, and so on.        |
|       |        |             | Valid values for each 2-bit RnDGPS field are:     |
|       |        |             | 00 = 90 deg clock (clk90)                         |
|       |        |             | 01 = 180 deg clock (clk180)                       |
|       |        |             | 10 = 270 deg clock (clk270)                       |
|       |        |             | 11 = 360 deg clock (clk0)                         |

Rockenin



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:14 | RW   | 0x1         | R1DGPS Rank n DQS Gating Phase Select: Selects the clock used to enable the data strobes during read so that the value of the data strobes before and after the preamble/postamble are filtered out. The RnDGPS fields are initially set by the PHYCTL during automatic DQS data training and subsequently updated during data strobe drift compensation. However, these values can be overwritten by a direct write to this register, and the automatic update during DQS drift compensation can be disabled using the PHY General Configuration Register (PGCR). Every two bits of this register control the DQS gating for each of the (up to) four ranks. R0DGPS controls the DQS gating for rank 0, R1DGPS controls rank 1, and so on. Valid values for each 2-bit RnDGPS field are: 00 = 90 deg clock (clk90) 01 = 180 deg clock (clk180) 10 = 270 deg clock (clk270) 11 = 360 deg clock (clk0) |

Rockening

| Bit   | Attr | Reset Value | Description                                       |
|-------|------|-------------|---------------------------------------------------|
|       |      |             | RODGPS                                            |
|       |      |             | Rank n DQS Gating Phase Select: Selects the       |
|       |      |             | clock used to enable the data strobes during      |
|       |      |             | read so that the value of the data strobes        |
|       |      |             | before and after the preamble/postamble are       |
|       |      |             | filtered out. The RnDGPS fields are initially set |
|       |      |             | by the PHYCTL during automatic DQS data           |
|       |      |             | training and subsequently updated during data     |
|       |      |             | strobe drift compensation. However, these         |
|       |      | (W 0x1      | values can be overwritten by a direct write to    |
| 13:12 | RW   |             | this register, and the automatic update during    |
| 15.12 | IXVV |             | DQS drift compensation can be disabled using      |
|       |      |             | the PHY General Configuration Register            |
|       |      |             | (PGCR). Every two bits of this register control   |
|       |      |             | the DQS gating for each of the (up to) four       |
|       |      |             | ranks. R0DGPS controls the DQS gating for         |
|       |      |             | rank 0, R1DGPS controls rank 1, and so on.        |
|       |      |             | Valid values for each 2-bit RnDGPS field are:     |
|       |      |             | 00 = 90 deg clock (clk90)                         |
|       |      |             | 01 = 180 deg clock (clk180)                       |
|       |      |             | 10 = 270 deg clock (clk270)                       |
|       |      |             | 11 = 360 deg clock (clk0)                         |

Rockenin



| Bit  | Attr | Reset Value | Description                                       |
|------|------|-------------|---------------------------------------------------|
|      |      |             | R3DGSL                                            |
|      |      |             | Rank n DQS Gating System Latency: Used to         |
|      |      |             | increase the number of clock cycles needed to     |
|      |      |             | expect valid DDR read data by up to five extra    |
|      |      |             | clock cycles. This is used to compensate for      |
|      |      |             | board delays and other system delays.             |
|      |      |             | Power-up default is 000 (i.e. no extra clock      |
|      |      |             | cycles required). The SL fields are initially set |
|      |      |             | by the PHYCTL during automatic DQS data           |
|      |      |             | training but these values can be overwritten by   |
|      |      |             | a direct write to this register. Every three bits |
| 11:9 | RW   | 0x0         | of this register control the latency of each of   |
|      |      |             | the (up to) four ranks. R0DGSL controls the       |
|      |      |             | latency of rank 0, R1DGSL controls rank 1, and    |
|      |      |             | so on. Valid values are:                          |
|      |      |             | 000 = No extra clock cycles                       |
|      |      |             | 001 = 1 extra clock cycle                         |
|      |      |             | 010 = 2 extra clock cycles                        |
|      |      |             | 011 = 3 extra clock cycles                        |
|      |      |             | 100 = 4 extra clock cycles                        |
|      |      |             | 101 = 5 extra clock cycles                        |
|      |      |             | 110 = Reserved                                    |
|      |      |             | 111 = Reserved                                    |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit | Attr | Reset Value | R2DGSL Rank n DQS Gating System Latency: Used to increase the number of clock cycles needed to expect valid DDR read data by up to five extra clock cycles. This is used to compensate for board delays and other system delays.                                                                                                                                                                             |
| 8:6 | RW   | 0×0         | Power-up default is 000 (i.e. no extra clock cycles required). The SL fields are initially set by the PHYCTL during automatic DQS data training but these values can be overwritten by a direct write to this register. Every three bits of this register control the latency of each of the (up to) four ranks. R0DGSL controls the latency of rank 0, R1DGSL controls rank 1, and so on. Valid values are: |
|     |      |             | 000 = No extra clock cycles<br>001 = 1 extra clock cycle<br>010 = 2 extra clock cycles<br>011 = 3 extra clock cycles<br>100 = 4 extra clock cycles<br>101 = 5 extra clock cycles<br>110 = Reserved<br>111 = Reserved                                                                                                                                                                                         |

| Bit | Attr | Reset Value | Description                                       |
|-----|------|-------------|---------------------------------------------------|
|     |      |             | R1DGSL                                            |
|     |      |             | Rank n DQS Gating System Latency: Used to         |
|     |      |             | increase the number of clock cycles needed to     |
|     |      |             | expect valid DDR read data by up to five extra    |
|     |      |             | clock cycles. This is used to compensate for      |
|     |      |             | board delays and other system delays.             |
|     |      |             | Power-up default is 000 (i.e. no extra clock      |
|     |      |             | cycles required). The SL fields are initially set |
|     |      |             | by the PHYCTL during automatic DQS data           |
|     |      |             | training but these values can be overwritten by   |
|     |      |             | a direct write to this register. Every three bits |
| 5:3 | RW   | 0x0         | of this register control the latency of each of   |
|     |      |             | the (up to) four ranks. R0DGSL controls the       |
|     |      |             | latency of rank 0, R1DGSL controls rank 1, and    |
|     |      |             | so on. Valid values are:                          |
|     |      |             | 000 = No extra clock cycles                       |
|     |      |             | 001 = 1 extra clock cycle                         |
|     |      |             | 010 = 2 extra clock cycles                        |
|     |      |             | 011 = 3 extra clock cycles                        |
|     |      |             | 100 = 4 extra clock cycles                        |
|     |      |             | 101 = 5 extra clock cycles                        |
|     |      |             | 110 = Reserved                                    |
|     |      |             | 111 = Reserved                                    |



| Bit | Attr | Reset Value | Description                                       |
|-----|------|-------------|---------------------------------------------------|
|     |      |             | RODGSL                                            |
|     |      |             | Rank n DQS Gating System Latency: Used to         |
|     |      |             | increase the number of clock cycles needed to     |
|     |      |             | expect valid DDR read data by up to five extra    |
|     |      |             | clock cycles. This is used to compensate for      |
|     |      |             | board delays and other system delays.             |
|     |      |             | Power-up default is 000 (i.e. no extra clock      |
|     |      |             | cycles required). The SL fields are initially set |
|     |      |             | by the PHYCTL during automatic DQS data           |
|     |      |             | training but these values can be overwritten by   |
|     |      |             | a direct write to this register. Every three bits |
| 2:0 | RW   | 0x0         | of this register control the latency of each of   |
|     |      |             | the (up to) four ranks. R0DGSL controls the       |
|     |      |             | latency of rank 0, R1DGSL controls rank 1, and    |
|     |      |             | so on. Valid values are:                          |
|     |      |             | 000 = No extra clock cycles                       |
|     |      |             | 001 = 1 extra clock cycle                         |
|     |      |             | 010 = 2 extra clock cycles                        |
|     |      |             | 011 = 3 extra clock cycles                        |
|     |      |             | 100 = 4 extra clock cycles                        |
|     |      |             | 101 = 5 extra clock cycles                        |
|     |      |             | 110 = Reserved                                    |
|     |      |             | 111 = Reserved                                    |

# DDR\_PHYCTL\_DX1GCR

Address: Operational Base + offset (0x0200) DATX8 1 General Configuration Register

| Bit   | Attr | Reset Value | Description                                 |
|-------|------|-------------|---------------------------------------------|
| 31:14 | RO   | 0x0         | reserved                                    |
|       |      |             | RTTOAL                                      |
|       |      |             | RTT On Additive Latency: Indicates when the |
|       |      |             | ODT control of DQ/DQS SSTL I/Os is          |
|       | ,    |             | set to the value in DQODT/DQSODT during     |
| 13    | RW   | 0x0         | read cycles. Valid values are:              |
|       |      |             | 0 = ODT control is set to DQSODT/DQODT      |
|       |      |             | almost two cycles before read data preamble |
|       |      |             | 1 = ODT control is set to DQSODT/DQODT      |
|       |      |             | almost one cycle before read data preamble  |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12:11 | RW   | 0x0         | RTTOH RTT Output Hold: Indicates the number of clock cycles (from 0 to 3) after the read data postamble for which ODT control should remain set to DQSODT for DQS or DQODT for DQ/DM before disabling it (setting it to '0' when using dynamic ODT control. ODT is disabled almost RTTOH clock cycles after the read postamble                                                                                                                                                                                                 |
| 10    | RW   | 0x1         | DQRTT DQ Dynamic RTT Control: Indicates, if set, that the ODT control of DQ/DM SSTL I/Os be dynamically controlled by setting it to the value in DQODT during reads and disabling it (setting it to '0' during any other cycle. If this bit is not set, then the ODT control of DQ SSTL I/Os is always set to the value in DQODT.                                                                                                                                                                                              |
| 9     | RW   | 0x1         | DQSRTT DQS Dynamic RTT Control: Indicates, if set, that the ODT control of DQS SSTL I/Os be dynamically controlled by setting it to the value in DQSODT during reads and disabling it (setting it to 0 during any other cycle. If this bit is not set, then the ODT control of DQS SSTL I/Os is always set to the value in DQSODT field.                                                                                                                                                                                       |
| 8:7   | RW   | 0x1         | DSEN Write DQS Enable: Controls whether the write DQS going to the SDRAM is enabled (toggling) or disabled (static value) and whether the DQS is inverted. DQS# is always the inversion of DQS. These values are valid only when DQS/DQS# output enable is on, otherwise the DQS/DQS# is tristated. Valid settings are: 00 = DQS disabled (Driven to constant 0) 01 = DQS toggling with inverted polarity 10 = DQS toggling with normal polarity (This should be the default setting) 11 = DQS disabled (Driven to constant 1) |
| 6     | RW   | 0x0         | DQSRPD DQSR Power Down: Powers down, if set, the PDQSR cell. This bit is ORed with the common PDR configuration bit                                                                                                                                                                                                                                                                                                                                                                                                            |



#### **DDR PHYCTL DX1GSR0**

Address: Operational Base + offset (0x0204)

DATX8 1 General Status Register 0

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:25 | RO   | 0x0         | reserved    |

the DLL in the DATX8 is put in bypass mode.



| Bit   | Attr | Reset Value | Description                                        |
|-------|------|-------------|----------------------------------------------------|
|       |      |             | DTPASS                                             |
|       |      |             | Data Training Pass Count: The number of            |
| 24:13 | RO   | 0x000       | passing configurations during DQS gate             |
|       |      |             | training. Bits [2:0] are for rank 0, bits [5:3]    |
|       |      |             | for rank 1, and so on.                             |
| 12    | RO   | 0x0         | reserved                                           |
|       |      |             | DTIERR                                             |
|       |      |             | Data Training Intermittent Error: If set,          |
|       |      | 0×0         | indicates that there was an intermittent error     |
| 11:8  | RO   |             | during data training of the byte, such as a pass   |
|       |      |             | was followed by a fail then followed by another    |
|       |      |             | pass. Bit [0] is for rank 0, bit 1 for rank 1, and |
|       |      |             | so on.                                             |
|       |      |             | DTERR                                              |
|       |      |             | Data Training Error: If set, indicates that a      |
| 7:4   | RO   | 0x0         | valid DQS gating window could not be found         |
|       |      |             | during data training of the byte. Bit [0] is for   |
|       |      |             | rank 0, bit 1 for rank 1, and so on.               |
|       |      |             | DTDONE                                             |
| 3:0   | RO   | 0x0         | Data Training Done: Indicates, if set, that the    |
| 3.0   |      |             | byte has finished doing data training. Bit [0] is  |
|       |      |             | for rank 0, bit 1 for rank 1, and so on.           |

### DDR\_PHYCTL\_DX1GSR1

Address: Operational Base + offset (0x0208)

DATX8 1 General Status Register 1

| Bit   | Attr | Reset Value | Description                                       |
|-------|------|-------------|---------------------------------------------------|
| 31:12 | RO   | 0x0         | reserved                                          |
|       | 11   |             | DQSDFT                                            |
|       |      | 7           | DQS Drift: Used to report the drift on the read   |
| /     |      | 0×00        | data strobe of the data byte. Valid settings      |
|       |      |             | are:                                              |
| 11:4  | RO   |             | 00 = No drift                                     |
|       | KO   |             | 01 = 90 deg drift                                 |
|       |      |             | 10 = 180 deg drift                                |
|       |      |             | 11 = 270 deg drift or more                        |
|       |      |             | Bits [1:0] are for rank 0, bits [3:2] for rank 1, |
|       |      |             | and so on.                                        |



| Bit | Attr | Reset Value | Description                                      |
|-----|------|-------------|--------------------------------------------------|
| 2.0 | RO   | 0x0         | DFTERR                                           |
|     |      |             | DQS Drift Error: If set, indicates that the byte |
|     |      |             | read data strobe has drifted by more than or     |
| 3:0 |      |             | equal to the drift limit set in the PHY General  |
|     |      |             | Configuration Register (PGCR). Bit [0] is for    |
|     |      |             | rank 0, bit 1 for rank 1, and so on.             |

# DDR\_PHYCTL\_DX1DLLCR

Address: Operational Base + offset (0x020c)
DATX8 1 DLL Control Register

| Bit   | Attr | Reset Value | Description                                      |
|-------|------|-------------|--------------------------------------------------|
|       |      |             | DLLDIS                                           |
| 31    | RW   | 0x0         | DLL Disable: A disabled DLL is bypassed.         |
|       |      |             | Default ('0') is DLL enabled.                    |
|       |      |             | DLLSRST                                          |
| 30    | RW   | 0x1         | DLL Soft Rest: Soft resets the byte DLL by       |
|       |      |             | driving the DLL soft reset pin.                  |
| 29:20 | RO   | 0x0         | reserved                                         |
|       |      |             | SDLBMODE                                         |
|       |      |             | Slave DLL Loopback Mode: If this bit is set, the |
|       |      |             | slave DLL is put in loopback mode in which       |
|       |      |             | there is no 90 degrees phase shift on read       |
| 19    | RW   | 0x0         | DQS/DQS#. This bit must be set when              |
|       |      |             | operating the byte PHYs in loopback mode         |
|       |      | • 1         | such as during BIST loopback. Applicable only    |
|       |      |             | to PHYs that have this feature. Refer to PHY     |
|       |      |             | databook.                                        |
|       |      |             | ATESTEN                                          |
|       |      |             | Analog Test Enable: Enables the analog test      |
| 18    | RW   | 0x0         | signal to be output on the DLL analog test       |
|       |      |             | output (test_out_a). The DLL analog test         |
|       |      |             | output is tri-stated when this bit is '0'.       |



| Bit   | Attr      | Reset Value | Description                                    |
|-------|-----------|-------------|------------------------------------------------|
|       |           |             | SDPHASE                                        |
|       |           |             | Slave DLL Phase Trim: Selects the phase        |
|       |           |             | difference between the input clock and         |
|       |           |             | the corresponding output clock of the slave    |
|       |           |             | DLL. Valid settings:                           |
|       |           |             | 0000 = 90                                      |
|       |           |             | 0001 = 72                                      |
|       |           |             | 0010 = 54                                      |
|       |           |             | 0011 = 36                                      |
|       |           |             | 0100 = 108                                     |
| 17:14 | RW        | 0x0         | 0101 = 90                                      |
|       |           |             | 0110 = 72                                      |
|       |           |             | 0111 = 54                                      |
|       |           |             | 1000 = 126                                     |
|       |           |             | 1001 = 108                                     |
|       |           |             | 1010 = 90                                      |
|       |           |             | 1011 = 72                                      |
|       |           |             | 1100 = 144                                     |
|       |           |             | 1101 = 126                                     |
|       |           |             | 1110 = 108                                     |
|       |           |             | 1111 = 90                                      |
|       |           |             | SSTART                                         |
|       |           |             | Slave Auto Start-Up: Used to control how the   |
|       |           |             | slave DLL starts up relative to the master DLL |
|       |           | . (         | locking:                                       |
| 13:12 | RW        | 0x0         | 0X = Slave DLL automatically starts up once    |
| 15.12 |           | OXO .       | the master DLL has achieved lock.              |
|       |           |             | 10 = The automatic startup of the slave DLL is |
|       | <b>\1</b> |             | disabled; the phase detector is disabled.      |
|       |           | 7           | 11 = The automatic startup of the slave DLL is |
|       |           |             | disabled; the phase detector is enabled.       |
|       |           |             | MFWDLY                                         |
|       |           |             | Master Feed-Forward Delay Trim: Used to trim   |
| 11:9  | RW        | 0×0         | the delay in the master DLL feed-forward       |
|       |           |             | path:                                          |
|       |           |             | 000 = minimum delay                            |
|       |           |             | 111 = maximum delay                            |
|       |           |             | MFBDLY                                         |
|       |           |             | Master Feed-Back Delay Trim: Used to trim      |
| 8:6   | RW        | 0x0         | the delay in the master DLL feedback path:     |
|       |           |             | 000 = minimum delay                            |
|       |           |             | 111 = maximum delay                            |



| Bit | Attr | Reset Value | Description                                   |
|-----|------|-------------|-----------------------------------------------|
|     |      |             | SFWDLY                                        |
|     |      |             | Slave Feed-Forward Delay Trim: Used to trim   |
| 5:3 | RW   | 0x0         | the delay in the slave DLL feed-forward path: |
|     |      |             | 000 = minimum delay                           |
|     |      |             | 111 = maximum delay                           |
|     |      |             | SFBDLY                                        |
|     |      |             | Slave Feed-Back Delay Trim: Used to trim the  |
| 2:0 | RW   | 0x0         | delay in the slave DLL feedback path:         |
|     |      |             | 000 = minimum delay                           |
|     |      |             | 111 = maximum delay                           |

### DDR\_PHYCTL\_DX1DQTR

Address: Operational Base + offset (0x0210)

DATX8 1 DQ Timing Register

| Bit   | Attr | Reset Value | Description                                        |
|-------|------|-------------|----------------------------------------------------|
|       |      |             | DQDLY7                                             |
|       |      |             | DQ Delay: Used to adjust the delay of the data     |
|       |      |             | relative to the nominal delay that is matched      |
|       |      |             | to the delay of the data strobes through the       |
|       |      |             | slave DLL and clock tree. Every four bits of this  |
|       |      |             | register control the delay of a different data bit |
|       |      |             | in the byte. DQDLY0 controls the delay of data     |
|       |      |             | bit [0], DQDLY1 controls data bit [1], and so      |
| 31:28 | RW   | 0xf         | on. The lower two bits of the DQDLY for each       |
|       |      | . ()        | DQ bit controls the delay for the data clocked     |
|       |      |             | by DQS, while the higher two bits control the      |
|       |      |             | delay for the data clocked by DQS_b. Valid         |
|       |      | C           | settings for each 2-bit control field are:         |
|       | 11   |             | 00 = nominal delay                                 |
|       |      | Y           | 01 = nominal delay + 1 step                        |
|       |      |             | 10 = nominal delay + 2 steps                       |
|       |      |             | 11 = nominal delay + 3 steps                       |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      |             | DQDLY6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 27:24 | RW   | 0xf         | DQ Delay: Used to adjust the delay of the data relative to the nominal delay that is matched to the delay of the data strobes through the slave DLL and clock tree. Every four bits of this register control the delay of a different data bit in the byte. DQDLY0 controls the delay of data bit [0], DQDLY1 controls data bit [1], and so on. The lower two bits of the DQDLY for each DQ bit controls the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS_b. Valid settings for each 2-bit control field are:  00 = nominal delay 01 = nominal delay + 1 step 10 = nominal delay + 2 steps |
|       |      |             | 11 = nominal delay + 3 steps  DQDLY5  DQ Delay: Used to adjust the delay of the data relative to the nominal delay that is matched to the delay of the data strobes through the                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 23:20 | RW   | 0xf         | slave DLL and clock tree. Every four bits of this register control the delay of a different data bit in the byte. DQDLY0 controls the delay of data bit [0], DQDLY1 controls data bit [1], and so on. The lower two bits of the DQDLY for each DQ bit controls the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS_b. Valid settings for each 2-bit control field are: 00 = nominal delay                                                                                                                                                                                                     |
| 3     |      |             | 01 = nominal delay + 1 step<br>10 = nominal delay + 2 steps<br>11 = nominal delay + 3 steps                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |



- 00 = nominal delay
- 01 = nominal delay + 1 step
- 10 = nominal delay + 2 steps

DQ bit controls the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS\_b. Valid settings for each 2-bit control field are:

11 = nominal delay + 3 steps

| Bit      | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 11:8 | RW   | Oxf         | DQDLY2 DQ Delay: Used to adjust the delay of the data relative to the nominal delay that is matched to the delay of the data strobes through the slave DLL and clock tree. Every four bits of this register control the delay of a different data bit in the byte. DQDLY0 controls the delay of data bit [0], DQDLY1 controls data bit [1], and so on. The lower two bits of the DQDLY for each DQ bit controls the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS, b. Valid settings for each 2-bit control field are:  00 = nominal delay 01 = nominal delay + 1 step                                                                                                                     |
| 7:4      | RW   | 0xf         | 10 = nominal delay + 2 steps 11 = nominal delay + 3 steps  DQDLY1  DQ Delay: Used to adjust the delay of the data relative to the nominal delay that is matched to the delay of the data strobes through the slave DLL and clock tree. Every four bits of this register control the delay of a different data bit in the byte. DQDLY0 controls the delay of data bit [0], DQDLY1 controls data bit [1], and so on. The lower two bits of the DQDLY for each DQ bit controls the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS_b. Valid settings for each 2-bit control field are: 00 = nominal delay 01 = nominal delay + 1 step 10 = nominal delay + 2 steps 11 = nominal delay + 3 steps |



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0 | RW   | 0xf         | DQDLY0 DQ Delay: Used to adjust the delay of the data relative to the nominal delay that is matched to the delay of the data strobes through the slave DLL and clock tree. Every four bits of this register control the delay of a different data bit in the byte. DQDLY0 controls the delay of data bit [0], DQDLY1 controls data bit [1], and so on. The lower two bits of the DQDLY for each DQ bit controls the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS_b. Valid settings for each 2-bit control field are:  00 = nominal delay 01 = nominal delay + 1 step 10 = nominal delay + 2 steps 11 = nominal delay + 3 steps |

## DDR\_PHYCTL\_DX1DQSTR

Address: Operational Base + offset (0x0214)
DATX8 1 DQS Timing Register

|       |      | ming Register |                                                 |
|-------|------|---------------|-------------------------------------------------|
| Bit   | Attr | Reset Value   | Description                                     |
| 31:30 | RO   | 0x0           | reserved                                        |
|       | RW   | Oxf           | DMDLY                                           |
|       |      |               | DM Delay: Used to adjust the delay of the data  |
|       |      |               | mask relative to the nominal delay that is      |
|       |      |               | matched to the delay of the data strobes        |
| 29:26 |      |               | through the slave DLL and clock tree. The       |
|       |      |               | lower two bits of the DQMDLY controls the       |
|       |      |               | delay for the data clocked by DQS, while the    |
|       |      |               | higher two bits control the delay for the data  |
|       |      |               | clocked by DQS_b. Valid settings for each 2-bit |
|       |      |               | control field are:                              |
|       |      |               | 00 = nominal delay                              |
|       |      |               | 01 = nominal delay + 1 step                     |
|       |      |               | 10 = nominal delay + 2 steps                    |
|       |      |               | 11 = nominal delay + 3 steps                    |

| Bit   | Attr | Reset Value | Description                                     |
|-------|------|-------------|-------------------------------------------------|
|       |      |             | DQSNDLY                                         |
|       |      |             | DQS# Delay: Used to adjust the delay of the     |
|       |      |             | data strobes relative to the nominal delay that |
|       |      |             | is matched to the delay of the data bit through |
|       |      |             | the slave DLL and clock tree. DQSDLY control    |
|       |      |             | the delay on DQS strobe and DQSNDLY control     |
|       |      |             | the delay on DQS#. Valid values are:            |
| 25:23 | RW   | 0x3         | 000 = nominal delay - 3 steps                   |
|       |      |             | 001 = nominal delay - 2 steps                   |
|       |      |             | 010 = nominal delay - 1 step                    |
|       |      |             | 011 = nominal delay                             |
|       |      |             | 100 = nominal delay + 1 step                    |
|       |      |             | 101 = nominal delay + 2 steps                   |
|       |      |             | 110 = nominal delay + 3 steps                   |
|       |      |             | 111 = nominal delay + 4 steps                   |
|       |      |             | DQSDLY                                          |
|       |      |             | DQS Delay: Used to adjust the delay of the      |
|       |      |             | data strobes relative to the nominal delay that |
|       |      |             | is matched to the delay of the data bit through |
|       |      |             | the slave DLL and clock tree. DQSDLY control    |
|       |      |             | the delay on DQS strobe and DQSNDLY control     |
|       |      |             | the delay on DQS#. Valid values are:            |
| 22:20 | RW   | 0x3         | 000 = nominal delay - 3 steps                   |
|       |      |             | 001 = nominal delay - 2 steps                   |
|       |      | • 1         | 010 = nominal delay - 1 step                    |
|       |      |             | 011 = nominal delay                             |
|       |      |             | 100 = nominal delay + 1 step                    |
|       |      |             | 101 = nominal delay + 2 steps                   |
|       | 1    |             | 110 = nominal delay + 3 steps                   |
|       |      |             | 111 = nominal delay + 4 steps                   |

| Bit   | Attr | Reset Value | Description                                       |
|-------|------|-------------|---------------------------------------------------|
|       |      |             | R3DGPS                                            |
|       |      |             | Rank n DQS Gating Phase Select: Selects the       |
|       |      |             | clock used to enable the data strobes during      |
|       |      | 0×1         | read so that the value of the data strobes        |
|       |      |             | before and after the preamble/postamble are       |
|       |      |             | filtered out. The RnDGPS fields are initially set |
|       |      |             | by the PHYCTL during automatic DQS data           |
|       | RW   |             | training and subsequently updated during data     |
|       |      |             | strobe drift compensation. However, these         |
|       |      |             | values can be overwritten by a direct write to    |
| 19:18 |      |             | this register, and the automatic update during    |
| 19.10 |      |             | DQS drift compensation can be disabled using      |
|       |      |             | the PHY General Configuration Register            |
|       |      |             | (PGCR). Every two bits of this register control   |
|       |      |             | the DQS gating for each of the (up to) four       |
|       |      |             | ranks. R0DGPS controls the DQS gating for         |
|       |      |             | rank 0, R1DGPS controls rank 1, and so on.        |
|       |      |             | Valid values for each 2-bit RnDGPS field are:     |
|       |      |             | 00 = 90 deg clock (clk90)                         |
|       |      |             | 01 = 180 deg clock (clk180)                       |
|       |      |             | 10 = 270 deg clock (clk270)                       |
|       |      |             | 11 = 360 deg clock (clk0)                         |

Rockenin

| Bit          | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit<br>17:16 | RW   | 0x1         | R2DGPS Rank n DQS Gating Phase Select: Selects the clock used to enable the data strobes during read so that the value of the data strobes before and after the preamble/postamble are filtered out. The RnDGPS fields are initially set by the PHYCTL during automatic DQS data training and subsequently updated during data strobe drift compensation. However, these values can be overwritten by a direct write to this register, and the automatic update during DQS drift compensation can be disabled using the PHY General Configuration Register (PGCR). Every two bits of this register control the DQS gating for each of the (up to) four ranks. R0DGPS controls the DQS gating for rank 0, R1DGPS controls rank 1, and so on. Valid values for each 2-bit RnDGPS field are: 00 = 90 deg clock (clk90) 01 = 180 deg clock (clk180) 10 = 270 deg clock (clk270) |

Rockerin

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:14 | RW   | 0x1         | R1DGPS Rank n DQS Gating Phase Select: Selects the clock used to enable the data strobes during read so that the value of the data strobes before and after the preamble/postamble are filtered out. The RnDGPS fields are initially set by the PHYCTL during automatic DQS data training and subsequently updated during data strobe drift compensation. However, these values can be overwritten by a direct write to this register, and the automatic update during DQS drift compensation can be disabled using the PHY General Configuration Register (PGCR). Every two bits of this register control the DQS gating for each of the (up to) four ranks. R0DGPS controls the DQS gating for rank 0, R1DGPS controls rank 1, and so on. Valid values for each 2-bit RnDGPS field are: 00 = 90 deg clock (clk90) 01 = 180 deg clock (clk180) 10 = 270 deg clock (clk270) 11 = 360 deg clock (clk0) |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:12 | RW   | 0x1         | Rodges Rank n DQS Gating Phase Select: Selects the clock used to enable the data strobes during read so that the value of the data strobes before and after the preamble/postamble are filtered out. The RnDGPS fields are initially set by the PHYCTL during automatic DQS data training and subsequently updated during data strobe drift compensation. However, these values can be overwritten by a direct write to this register, and the automatic update during DQS drift compensation can be disabled using the PHY General Configuration Register (PGCR). Every two bits of this register control the DQS gating for each of the (up to) four ranks. R0DGPS controls the DQS gating for rank 0, R1DGPS controls rank 1, and so on. Valid values for each 2-bit RnDGPS field are: 00 = 90 deg clock (clk90) 01 = 180 deg clock (clk180) 10 = 270 deg clock (clk270) 11 = 360 deg clock (clk0) |

Rockenin



| Bit               | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b><br>8:6 | RW   | 0x0         | R2DGSL Rank n DQS Gating System Latency: Used to increase the number of clock cycles needed to expect valid DDR read data by up to five extra clock cycles. This is used to compensate for board delays and other system delays. Power-up default is 000 (i.e. no extra clock cycles required). The SL fields are initially set by the PHYCTL during automatic DQS data training but these values can be overwritten by a direct write to this register. Every three bits of this register control the latency of each of the (up to) four ranks. R0DGSL controls the latency of rank 0, R1DGSL controls rank 1, and so on. Valid values are:  000 = No extra clock cycles  001 = 1 extra clock cycles  011 = 3 extra clock cycles  100 = 4 extra clock cycles  101 = 5 extra clock cycles  101 = 5 extra clock cycles |

| Bit            | Attr        | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|-------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b> 5:3 | <b>Attr</b> | 0x0         | R1DGSL Rank n DQS Gating System Latency: Used to increase the number of clock cycles needed to expect valid DDR read data by up to five extra clock cycles. This is used to compensate for board delays and other system delays. Power-up default is 000 (i.e. no extra clock cycles required). The SL fields are initially set by the PHYCTL during automatic DQS data training but these values can be overwritten by a direct write to this register. Every three bits of this register control the latency of each of the (up to) four ranks. R0DGSL controls the latency of rank 0, R1DGSL controls rank 1, and so on. Valid values are:  000 = No extra clock cycles  001 = 1 extra clock cycles  001 = 2 extra clock cycles  101 = 3 extra clock cycles  101 = 5 extra clock cycles  101 = 5 extra clock cycles |



| Bit | Attr | Reset Value | Description                                       |
|-----|------|-------------|---------------------------------------------------|
|     |      |             | RODGSL                                            |
|     |      |             | Rank n DQS Gating System Latency: Used to         |
|     |      |             | increase the number of clock cycles needed to     |
|     |      |             | expect valid DDR read data by up to five extra    |
|     |      |             | clock cycles. This is used to compensate for      |
|     |      |             | board delays and other system delays.             |
|     |      |             | Power-up default is 000 (i.e. no extra clock      |
|     |      |             | cycles required). The SL fields are initially set |
|     |      |             | by the PHYCTL during automatic DQS data           |
|     |      |             | training but these values can be overwritten by   |
|     |      |             | a direct write to this register. Every three bits |
| 2:0 | RW   | 0x0         | of this register control the latency of each of   |
|     |      |             | the (up to) four ranks. R0DGSL controls the       |
|     |      |             | latency of rank 0, R1DGSL controls rank 1, and    |
|     |      |             | so on. Valid values are:                          |
|     |      |             | 000 = No extra clock cycles                       |
|     |      |             | 001 = 1 extra clock cycle                         |
|     |      |             | 010 = 2 extra clock cycles                        |
|     |      |             | 011 = 3 extra clock cycles                        |
|     |      |             | 100 = 4 extra clock cycles                        |
|     |      |             | 101 = 5 extra clock cycles                        |
|     |      |             | 110 = Reserved                                    |
|     |      |             | 111 = Reserved                                    |

# DDR\_PHYCTL\_DX2GCR

Address: Operational Base + offset (0x0240)DATX8 2 General Configuration Register

| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
| 31:14 | RO   | 0x0         | reserved                                      |
|       |      |             | RTTOAL                                        |
|       |      |             | RTT On Additive Latency: Indicates when the   |
|       |      |             | ODT control of DQ/DQS SSTL I/Os is set to the |
|       | ,    |             | value in DQODT/DQSODT during read cycles.     |
| 13    | RW   | 0x0         | Valid values are:                             |
|       |      |             | 0 = ODT control is set to DQSODT/DQODT        |
|       |      |             | almost two cycles before read data preamble   |
|       |      |             | 1 = ODT control is set to DQSODT/DQODT        |
|       |      |             | almost one cycle before read data preamble    |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12:11 | RW   | 0x0         | RTTOH RTT Output Hold: Indicates the number of clock cycles (from 0 to 3) after the read data postamble for which ODT control should remain set to DQSODT for DQS or DQODT for DQ/DM before disabling it (setting it to '0' when using dynamic ODT control. ODT is disabled almost RTTOH clock cycles after the read postamble                                                                                                                                                                                                 |
| 10    | RW   | 0x1         | DQRTT DQ Dynamic RTT Control: Indicates, if set, that the ODT control of DQ/DM SSTL I/Os be dynamically controlled by setting it to the value in DQODT during reads and disabling it (setting it to '0' during any other cycle. If this bit is not set, then the ODT control of DQ SSTL I/Os is always set to the value in DQODT.                                                                                                                                                                                              |
| 9     | RW   | 0x1         | DQSRTT DQS Dynamic RTT Control: Indicates, if set, that the ODT control of DQS SSTL I/Os be dynamically controlled by setting it to the value in DQSODT during reads and disabling it (setting it to 0 during any other cycle. If this bit is not set, then the ODT control of DQS SSTL I/Os is always set to the value in DQSODT field.                                                                                                                                                                                       |
| 8:7   | RW   | 0x1         | DSEN Write DQS Enable: Controls whether the write DQS going to the SDRAM is enabled (toggling) or disabled (static value) and whether the DQS is inverted. DQS# is always the inversion of DQS. These values are valid only when DQS/DQS# output enable is on, otherwise the DQS/DQS# is tristated. Valid settings are: 00 = DQS disabled (Driven to constant 0) 01 = DQS toggling with inverted polarity 10 = DQS toggling with normal polarity (This should be the default setting) 11 = DQS disabled (Driven to constant 1) |
| 6     | RW   | 0x0         | DQSRPD DQSR Power Down: Powers down, if set, the PDQSR cell. This bit is ORed with the common PDR configuration bit                                                                                                                                                                                                                                                                                                                                                                                                            |



| Bit | Attr   | Reset Value | Description                                      |
|-----|--------|-------------|--------------------------------------------------|
|     |        |             | DXPDR                                            |
|     |        |             | Data Power Down Receiver: Powers down,           |
| 5   | RW     | 0×0         | when set, the input receiver on I/O for DQ,      |
| 5   | KVV    | UXU         | DM, and DQS/DQS# pins of the byte. This bit      |
|     |        |             | is ORed with the common PDR configuration        |
|     |        |             | bit                                              |
|     |        |             | DXPDD                                            |
|     |        |             | Data Power Down Driver: Powers down, when        |
| 4   | RW     | 0x0         | set, the output driver on I/O for DQ, DM, and    |
|     |        |             | DQS/DQS# pins of the byte. This bit is ORed      |
|     |        |             | with the common PDD configuration bit            |
|     |        |             | DXIOM                                            |
|     |        |             | Data I/O Mode: Selects SSTL mode (when set       |
| 3   | RW     | 0x0         | to 0) or CMOS mode (when set to 1) of the I/O    |
|     |        | 0.00        | for DQ, DM, and DQS/DQS# pins of the byte.       |
|     |        |             | This bit is ORed with the IOM configuration bit  |
|     |        |             | of the individual DATX8                          |
|     |        |             | DQODT                                            |
|     |        |             | Data On-Die Termination: Enables, when set,      |
| 2   | RW     | 0x0         | the on-die termination on the I/O for DQ and     |
|     |        |             | DM pins of the byte. This bit is ORed with the   |
|     |        |             | common DATX8 ODT configuration bit               |
|     |        |             | DQSODT                                           |
|     |        |             | DQS On-Die Termination: Enables, when set,       |
| 1   | RW     | 0x0         | the on-die termination on the I/O for            |
|     |        |             | DQS/DQS# pin of the byte. This bit is ORed       |
|     |        | \\\\        | with the common DATX8 ODT configuration bit      |
|     |        |             | DXEN                                             |
|     |        |             | Data Byte Enable: Enables if set the DATX8       |
| 0   | RW     | 0x1         | and SSTL I/Os used on the data byte. Setting     |
|     |        |             | this bit to '0' disables the byte, i.e. the byte |
|     | $\cup$ |             | SSTL I/Os are put in power-down mode and         |
|     | Y      |             | the DLL in the DATX8 is put in bypass mode.      |

#### DDR\_PHYCTL\_DX2GSR0

Address: Operational Base + offset (0x0244)

DATX8 2 General Status Register 0

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:25 | RO   | 0x0         | reserved    |



| Bit   | Attr | Reset Value | Description                                        |
|-------|------|-------------|----------------------------------------------------|
|       |      |             | DTPASS                                             |
|       |      |             | Data Training Pass Count: The number of            |
| 24:13 | RO   | 0x000       | passing configurations during DQS gate             |
|       |      |             | training. Bits [2:0] are for rank 0, bits [5:3]    |
|       |      |             | for rank 1, and so on.                             |
| 12    | RO   | 0x0         | reserved                                           |
|       |      |             | DTIERR                                             |
|       |      |             | Data Training Intermittent Error: If set,          |
|       |      | 0x0         | indicates that there was an intermittent error     |
| 11:8  | RO   |             | during data training of the byte, such as a pass   |
|       |      |             | was followed by a fail then followed by another    |
|       |      |             | pass. Bit [0] is for rank 0, bit 1 for rank 1, and |
|       |      |             | so on.                                             |
|       |      |             | DTERR                                              |
|       |      |             | Data Training Error: If set, indicates that a      |
| 7:4   | RO   | 0x0         | valid DQS gating window could not be found         |
|       |      |             | during data training of the byte. Bit [0] is for   |
|       |      |             | rank 0, bit 1 for rank 1, and so on.               |
|       |      |             | DTDONE                                             |
| 3:0   | RO   | 0x0         | Data Training Done: Indicates, if set, that the    |
| 3.0   |      |             | byte has finished doing data training. Bit [0] is  |
|       |      |             | for rank 0, bit 1 for rank 1, and so on.           |

#### DDR\_PHYCTL\_DX2GSR1

Address: Operational Base + offset (0x0248)

DATX8 2 General Status Register 1

| Bit   | Attr | Reset Value | Description                                       |
|-------|------|-------------|---------------------------------------------------|
| 31:12 | RO   | 0x0         | reserved                                          |
|       | 11   |             | DQSDFT                                            |
|       |      | 7           | DQS Drift: Used to report the drift on the read   |
|       |      | 0×00        | data strobe of the data byte. Valid settings      |
| 11:4  |      |             | are:                                              |
|       | RO   |             | 00 = No drift                                     |
|       | KO   |             | 01 = 90 deg drift                                 |
|       |      |             | 10 = 180 deg drift                                |
|       |      |             | 11 = 270 deg drift or more                        |
|       |      |             | Bits [1:0] are for rank 0, bits [3:2] for rank 1, |
|       |      |             | and so on.                                        |



| Bit | Attr | Reset Value | Description                                      |
|-----|------|-------------|--------------------------------------------------|
|     | RO   | 0x0         | DFTERR                                           |
|     |      |             | DQS Drift Error: If set, indicates that the byte |
| 3:0 |      |             | read data strobe has drifted by more than or     |
| 3:0 |      |             | equal to the drift limit set in the PHY General  |
|     |      |             | Configuration Register (PGCR). Bit [0] is for    |
|     |      |             | rank 0, bit 1 for rank 1, and so on.             |

# DDR\_PHYCTL\_DX2DLLCR

Address: Operational Base + offset (0x024c)
DATX8 2 DLL Control Register

| Bit   | Attr | Reset Value | Description                                      |
|-------|------|-------------|--------------------------------------------------|
|       |      |             | DLLDIS                                           |
| 31    | RW   | 0x0         | DLL Disable: A disabled DLL is bypassed.         |
|       |      |             | Default ('0') is DLL enabled.                    |
|       |      |             | DLLSRST                                          |
| 30    | RW   | 0x1         | DLL Soft Rest: Soft resets the byte DLL by       |
|       |      |             | driving the DLL soft reset pin.                  |
| 29:20 | RO   | 0x0         | reserved                                         |
|       |      |             | SDLBMODE                                         |
|       |      |             | Slave DLL Loopback Mode: If this bit is set, the |
|       |      |             | slave DLL is put in loopback mode in which       |
|       |      |             | there is no 90 degrees phase shift on read       |
| 19    | RW   | 0x0         | DQS/DQS#. This bit must be set when              |
|       |      |             | operating the byte PHYs in loopback mode         |
|       |      | • 0         | such as during BIST loopback. Applicable only    |
|       |      |             | to PHYs that have this feature. Refer to PHY     |
|       |      |             | databook.                                        |
|       |      |             | ATESTEN                                          |
|       |      |             | Analog Test Enable: Enables the analog test      |
| 18    | RW   | 0x0         | signal to be output on the DLL analog test       |
|       |      |             | output (test_out_a). The DLL analog test         |
|       |      |             | output is tri-stated when this bit is '0'.       |





| Bit | Attr | Reset Value | Description                                   |
|-----|------|-------------|-----------------------------------------------|
|     |      |             | SFWDLY                                        |
|     |      |             | Slave Feed-Forward Delay Trim: Used to trim   |
| 5:3 | RW   | 0x0         | the delay in the slave DLL feed-forward path: |
|     |      |             | 000 = minimum delay                           |
|     |      |             | 111 = maximum delay                           |
|     |      |             | SFBDLY                                        |
|     |      |             | Slave Feed-Back Delay Trim: Used to trim the  |
| 2:0 | RW   | 0x0         | delay in the slave DLL feedback path:         |
|     |      |             | 000 = minimum delay                           |
|     |      |             | 111 = maximum delay                           |

#### DDR\_PHYCTL\_DX2DQTR

Address: Operational Base + offset (0x0250)

DATX8 2 DQ Timing Register

| Bit   | Attr | Reset Value | Description                                        |
|-------|------|-------------|----------------------------------------------------|
|       |      |             | DQDLY7                                             |
|       |      |             | DQ Delay: Used to adjust the delay of the data     |
|       |      |             | relative to the nominal delay that is matched      |
|       |      |             | to the delay of the data strobes through the       |
|       |      |             | slave DLL and clock tree. Every four bits of this  |
|       |      |             | register control the delay of a different data bit |
|       |      |             | in the byte. DQDLY0 controls the delay of data     |
|       |      |             | bit [0], DQDLY1 controls data bit [1], and so      |
| 31:28 | RW   | 0xf         | on. The lower two bits of the DQDLY for each       |
|       |      | . ()        | DQ bit controls the delay for the data clocked     |
|       |      |             | by DQS, while the higher two bits control the      |
|       |      |             | delay for the data clocked by DQS_b. Valid         |
|       |      | C           | settings for each 2-bit control field are:         |
|       | 11   |             | 00 = nominal delay                                 |
|       |      | Y           | 01 = nominal delay + 1 step                        |
|       |      |             | 10 = nominal delay + 2 steps                       |
|       |      |             | 11 = nominal delay + 3 steps                       |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      |             | DQDLY6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 27:24 | RW   | 0xf         | DQ Delay: Used to adjust the delay of the data relative to the nominal delay that is matched to the delay of the data strobes through the slave DLL and clock tree. Every four bits of this register control the delay of a different data bit in the byte. DQDLY0 controls the delay of data bit [0], DQDLY1 controls data bit [1], and so on. The lower two bits of the DQDLY for each DQ bit controls the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS_b. Valid settings for each 2-bit control field are:  00 = nominal delay 01 = nominal delay + 1 step 10 = nominal delay + 2 steps                                                                                                              |
| 23:20 | RW   | 0xf         | DQDLY5 DQ Delay: Used to adjust the delay of the data relative to the nominal delay that is matched to the delay of the data strobes through the slave DLL and clock tree. Every four bits of this register control the delay of a different data bit in the byte. DQDLY0 controls the delay of data bit [0], DQDLY1 controls data bit [1], and so on. The lower two bits of the DQDLY for each DQ bit controls the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS_b. Valid settings for each 2-bit control field are:  00 = nominal delay 01 = nominal delay + 1 step 10 = nominal delay + 2 steps 11 = nominal delay + 3 steps |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      |             | DQDLY4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 19:16 | RW   | 0xf         | DQ Delay: Used to adjust the delay of the data relative to the nominal delay that is matched to the delay of the data strobes through the slave DLL and clock tree. Every four bits of this register control the delay of a different data bit in the byte. DQDLY0 controls the delay of data bit [0], DQDLY1 controls data bit [1], and so on. The lower two bits of the DQDLY for each DQ bit controls the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS_b. Valid settings for each 2-bit control field are:  00 = nominal delay  01 = nominal delay + 1 step  10 = nominal delay + 2 steps                                                                     |
| 15:12 | RW   | 0xf         | 11 = nominal delay + 3 steps  DQDLY3  DQ Delay: Used to adjust the delay of the data relative to the nominal delay that is matched to the delay of the data strobes through the slave DLL and clock tree. Every four bits of this register control the delay of a different data bit in the byte. DQDLY0 controls the delay of data bit [0], DQDLY1 controls data bit [1], and so on. The lower two bits of the DQDLY for each DQ bit controls the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS_b. Valid settings for each 2-bit control field are:  00 = nominal delay  01 = nominal delay + 1 step  10 = nominal delay + 2 steps  11 = nominal delay + 3 steps |



| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |             | DQDLY2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 11:8 | RW   | 0xf         | DQ Delay: Used to adjust the delay of the data relative to the nominal delay that is matched to the delay of the data strobes through the slave DLL and clock tree. Every four bits of this register control the delay of a different data bit in the byte. DQDLY0 controls the delay of data bit [0], DQDLY1 controls data bit [1], and so on. The lower two bits of the DQDLY for each DQ bit controls the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS_b. Valid settings for each 2-bit control field are:  00 = nominal delay 01 = nominal delay + 1 step 10 = nominal delay + 2 steps                                                                                                              |
| 7:4  | RW   | 0xf         | DQDLY1 DQ Delay: Used to adjust the delay of the data relative to the nominal delay that is matched to the delay of the data strobes through the slave DLL and clock tree. Every four bits of this register control the delay of a different data bit in the byte. DQDLY0 controls the delay of data bit [0], DQDLY1 controls data bit [1], and so on. The lower two bits of the DQDLY for each DQ bit controls the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS_b. Valid settings for each 2-bit control field are:  00 = nominal delay 01 = nominal delay + 1 step 10 = nominal delay + 2 steps 11 = nominal delay + 3 steps |



| Bit            | Attr | Reset Value      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b> 3:0 | Attr | Reset Value  0xf | DQDLY0 DQ Delay: Used to adjust the delay of the data relative to the nominal delay that is matched to the delay of the data strobes through the slave DLL and clock tree. Every four bits of this register control the delay of a different data bit in the byte. DQDLY0 controls the delay of data bit [0], DQDLY1 controls data bit [1], and so on. The lower two bits of the DQDLY for each DQ bit controls the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS_b. Valid settings for each 2-bit control field are: |
|                |      |                  | 00 = nominal delay                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                |      |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                |      |                  | 01 = nominal delay + 1 step                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                |      |                  | 10 = nominal delay + 2 steps                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                |      |                  | 11 = nominal delay + 3 steps                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

## DDR\_PHYCTL\_DX2DQSTR

Address: Operational Base + offset (0x0254)
DATX8 2 DQS Timing Register

| Bit   | Attr | Reset Value | Description                  |
|-------|------|-------------|------------------------------|
| 31:30 | RO   | 0x0         | reserved                     |
|       |      |             | -                            |
|       |      |             | 10 = nominal delay + 2 steps |
|       |      |             | 11 = nominal delay + 3 steps |

| Bit   | Attr | Reset Value | Description                                     |  |
|-------|------|-------------|-------------------------------------------------|--|
|       |      |             | DQSNDLY                                         |  |
|       |      |             | DQS# Delay: Used to adjust the delay of the     |  |
|       |      |             | data strobes relative to the nominal delay that |  |
|       |      |             | is matched to the delay of the data bit through |  |
|       |      |             | the slave DLL and clock tree. DQSDLY control    |  |
|       |      |             | the delay on DQS strobe and DQSNDLY control     |  |
|       |      |             | the delay on DQS#. Valid values are:            |  |
| 25:23 | RW   | 0x3         | 000 = nominal delay - 3 steps                   |  |
|       |      |             | 001 = nominal delay - 2 steps                   |  |
|       |      |             | 010 = nominal delay - 1 step                    |  |
|       |      |             | 011 = nominal delay                             |  |
|       |      |             | 100 = nominal delay + 1 step                    |  |
|       |      |             | 101 = nominal delay + 2 steps                   |  |
|       |      |             | 110 = nominal delay + 3 steps                   |  |
|       |      |             | 111 = nominal delay + 4 steps                   |  |
|       |      |             | DQSDLY                                          |  |
|       |      |             | DQS Delay: Used to adjust the delay of the      |  |
|       |      |             | data strobes relative to the nominal delay that |  |
|       |      |             | is matched to the delay of the data bit through |  |
|       |      |             | the slave DLL and clock tree. DQSDLY control    |  |
|       |      |             | the delay on DQS strobe and DQSNDLY control     |  |
|       |      |             | the delay on DQS#. Valid values are:            |  |
| 22:20 | RW   | 0x3         | 000 = nominal delay - 3 steps                   |  |
|       |      |             | 001 = nominal delay - 2 steps                   |  |
|       |      | • ()        | 010 = nominal delay - 1 step                    |  |
|       |      |             | 011 = nominal delay                             |  |
|       |      |             | 100 = nominal delay + 1 step                    |  |
|       |      |             | 101 = nominal delay + 2 steps                   |  |
|       | 1    |             | 110 = nominal delay + 3 steps                   |  |
|       |      | 7           | 111 = nominal delay + 4 steps                   |  |
| (     |      |             |                                                 |  |
| 0     |      |             |                                                 |  |



| Bit   | Attr  | Reset Value | Description                                       |
|-------|-------|-------------|---------------------------------------------------|
|       |       |             | R3DGPS                                            |
|       |       |             | Rank n DQS Gating Phase Select: Selects the       |
|       |       |             | clock used to enable the data strobes during      |
|       |       |             | read so that the value of the data strobes        |
|       |       |             | before and after the preamble/postamble are       |
|       |       |             | filtered out. The RnDGPS fields are initially set |
|       |       |             | by the PHYCTL during automatic DQS data           |
|       |       |             | training and subsequently updated during data     |
|       |       |             | strobe drift compensation. However, these         |
|       |       |             | values can be overwritten by a direct write to    |
| 19:18 | RW    | 0×1         | this register, and the automatic update during    |
| 15.10 | I V V |             | DQS drift compensation can be disabled using      |
|       |       |             | the PHY General Configuration Register            |
|       |       |             | (PGCR). Every two bits of this register control   |
|       |       |             | the DQS gating for each of the (up to) four       |
|       |       |             | ranks. R0DGPS controls the DQS gating for         |
|       |       |             | rank 0, R1DGPS controls rank 1, and so on.        |
|       |       |             | Valid values for each 2-bit RnDGPS field are:     |
|       |       |             | 00 = 90 deg clock (clk90)                         |
|       |       |             | 01 = 180 deg clock (clk180)                       |
|       |       |             | 10 = 270 deg clock (clk270)                       |
|       |       |             | 11 = 360 deg clock (clk0)                         |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17:16 | RW   | 0×1         | R2DGPS Rank n DQS Gating Phase Select: Selects the clock used to enable the data strobes during read so that the value of the data strobes before and after the preamble/postamble are filtered out. The RnDGPS fields are initially set by the PHYCTL during automatic DQS data training and subsequently updated during data strobe drift compensation. However, these values can be overwritten by a direct write to this register, and the automatic update during DQS drift compensation can be disabled using the PHY General Configuration Register (PGCR). Every two bits of this register control the DQS gating for each of the (up to) four ranks. R0DGPS controls the DQS gating for rank 0, R1DGPS controls rank 1, and so on. Valid values for each 2-bit RnDGPS field are: 00 = 90 deg clock (clk90) 01 = 180 deg clock (clk180) 10 = 270 deg clock (clk270) 11 = 360 deg clock (clk0) |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:14 | RW   | 0×1         | Rank n DQS Gating Phase Select: Selects the clock used to enable the data strobes during read so that the value of the data strobes before and after the preamble/postamble are filtered out. The RnDGPS fields are initially set by the PHYCTL during automatic DQS data training and subsequently updated during data strobe drift compensation. However, these values can be overwritten by a direct write to this register, and the automatic update during DQS drift compensation can be disabled using the PHY General Configuration Register (PGCR). Every two bits of this register control the DQS gating for each of the (up to) four ranks. R0DGPS controls the DQS gating for rank 0, R1DGPS controls rank 1, and so on. Valid values for each 2-bit RnDGPS field are: 00 = 90 deg clock (clk90) 01 = 180 deg clock (clk180) 10 = 270 deg clock (clk270) 11 = 360 deg clock (clk0) |

| Bit   | Attr | Reset Value | Description                                       |
|-------|------|-------------|---------------------------------------------------|
|       |      |             | RODGPS                                            |
|       |      |             | Rank n DQS Gating Phase Select: Selects the       |
|       |      |             | clock used to enable the data strobes during      |
|       |      |             | read so that the value of the data strobes        |
|       |      |             | before and after the preamble/postamble are       |
|       |      |             | filtered out. The RnDGPS fields are initially set |
|       |      |             | by the PHYCTL during automatic DQS data           |
|       |      |             | training and subsequently updated during data     |
|       |      | RW 0x1      | strobe drift compensation. However, these         |
|       |      |             | values can be overwritten by a direct write to    |
| 12.12 | DW   |             | this register, and the automatic update during    |
| 13:12 | KVV  |             | DQS drift compensation can be disabled using      |
|       |      |             | the PHY General Configuration Register            |
|       |      |             | (PGCR). Every two bits of this register control   |
|       |      |             | the DQS gating for each of the (up to) four       |
|       |      |             | ranks. R0DGPS controls the DQS gating for         |
|       |      |             | rank 0, R1DGPS controls rank 1, and so on.        |
|       |      |             | Valid values for each 2-bit RnDGPS field are:     |
|       |      |             | 00 = 90 deg clock (clk90)                         |
|       |      |             | 01 = 180 deg clock (clk180)                       |
|       |      |             | 10 = 270 deg clock (clk270)                       |
|       |      |             | 11 = 360 deg clock (clk0)                         |

| Bit Attr | Reset Value      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit Attr | Reset Value  0x0 | R3DGSL Rank n DQS Gating System Latency: Used to increase the number of clock cycles needed to expect valid DDR read data by up to five extra clock cycles. This is used to compensate for board delays and other system delays. Power-up default is 000 (i.e. no extra clock cycles required). The SL fields are initially set by the PHYCTL during automatic DQS data training but these values can be overwritten by a direct write to this register. Every three bits of this register control the latency of each of the (up to) four ranks. R0DGSL controls the latency of rank 0, R1DGSL controls rank 1, and so on. Valid values are:  000 = No extra clock cycles  001 = 1 extra clock cycles  010 = 2 extra clock cycles  101 = 3 extra clock cycles  100 = 4 extra clock cycles |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit | Attr | Reset Value | R2DGSL Rank n DQS Gating System Latency: Used to increase the number of clock cycles needed to expect valid DDR read data by up to five extra clock cycles. This is used to compensate for board delays and other system delays.                                                                                                                                                                             |
| 8:6 | RW   | 0×0         | Power-up default is 000 (i.e. no extra clock cycles required). The SL fields are initially set by the PHYCTL during automatic DQS data training but these values can be overwritten by a direct write to this register. Every three bits of this register control the latency of each of the (up to) four ranks. R0DGSL controls the latency of rank 0, R1DGSL controls rank 1, and so on. Valid values are: |
|     |      |             | 000 = No extra clock cycles<br>001 = 1 extra clock cycle<br>010 = 2 extra clock cycles<br>011 = 3 extra clock cycles<br>100 = 4 extra clock cycles<br>101 = 5 extra clock cycles<br>110 = Reserved<br>111 = Reserved                                                                                                                                                                                         |

| Bit Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit Attr | 0x0         | R1DGSL Rank n DQS Gating System Latency: Used to increase the number of clock cycles needed to expect valid DDR read data by up to five extra clock cycles. This is used to compensate for board delays and other system delays. Power-up default is 000 (i.e. no extra clock cycles required). The SL fields are initially set by the PHYCTL during automatic DQS data training but these values can be overwritten by a direct write to this register. Every three bits of this register control the latency of each of the (up to) four ranks. R0DGSL controls the latency of rank 0, R1DGSL controls rank 1, and so on. Valid values are:  000 = No extra clock cycles  001 = 1 extra clock cycles  001 = 2 extra clock cycles  101 = 3 extra clock cycles  101 = 5 extra clock cycles  101 = 5 extra clock cycles |



| Bit            | Attr | Reset Value      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b> 2:0 | Attr | Reset Value  0x0 | RODGSL Rank n DQS Gating System Latency: Used to increase the number of clock cycles needed to expect valid DDR read data by up to five extra clock cycles. This is used to compensate for board delays and other system delays.  Power-up default is 000 (i.e. no extra clock cycles required). The SL fields are initially set by the PHYCTL during automatic DQS data training but these values can be overwritten by a direct write to this register. Every three bits of this register control the latency of each of the (up to) four ranks. R0DGSL controls the latency of rank 0, R1DGSL controls rank 1, and so on. Valid values are: |
|                |      |                  | latency of rank 0, R1DGSL controls rank 1, and so on. Valid values are:  000 = No extra clock cycles                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                |      |                  | 001 = 1 extra clock cycle<br>010 = 2 extra clock cycles<br>011 = 3 extra clock cycles                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                |      |                  | 100 = 4 extra clock cycles<br>101 = 5 extra clock cycles<br>110 = Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                |      |                  | 111 = Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

# DDR\_PHYCTL\_DX3GCR

Address: Operational Base + offset (0x0280) DATX8 3 General Configuration Register

| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
| 31:14 | RO   | 0x0         | reserved                                      |
|       |      |             | RTTOAL                                        |
|       |      |             | RTT On Additive Latency: Indicates when the   |
|       |      |             | ODT control of DQ/DQS SSTL I/Os is set to the |
|       | ,    |             | value in DQODT/DQSODT during read cycles.     |
| 13    | RW   | 0x0         | Valid values are:                             |
|       |      |             | 0 = ODT control is set to DQSODT/DQODT        |
|       |      |             | almost two cycles before read data preamble   |
|       |      |             | 1 = ODT control is set to DQSODT/DQODT        |
|       |      |             | almost one cycle before read data preamble    |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12:11 | RW   | 0x0         | RTTOH RTT Output Hold: Indicates the number of clock cycles (from 0 to 3) after the read data postamble for which ODT control should remain set to DQSODT for DQS or DQODT for DQ/DM before disabling it (setting it to '0' when using dynamic ODT control. ODT is disabled almost RTTOH clock cycles after the read postamble                                                                                                                                                                                                 |
| 10    | RW   | 0x1         | DQRTT DQ Dynamic RTT Control: Indicates, if set, that the ODT control of DQ/DM SSTL I/Os be dynamically controlled by setting it to the value in DQODT during reads and disabling it (setting it to '0' during any other cycle. If this bit is not set, then the ODT control of DQ SSTL I/Os is always set to the value in DQODT.                                                                                                                                                                                              |
| 9     | RW   | 0x1         | DQSRTT DQS Dynamic RTT Control: Indicates, if set, that the ODT control of DQS SSTL I/Os be dynamically controlled by setting it to the value in DQSODT during reads and disabling it (setting it to 0 during any other cycle. If this bit is not set, then the ODT control of DQS SSTL I/Os is always set to the value in DQSODT field.                                                                                                                                                                                       |
| 8:7   | RW   | 0x1         | DSEN Write DQS Enable: Controls whether the write DQS going to the SDRAM is enabled (toggling) or disabled (static value) and whether the DQS is inverted. DQS# is always the inversion of DQS. These values are valid only when DQS/DQS# output enable is on, otherwise the DQS/DQS# is tristated. Valid settings are: 00 = DQS disabled (Driven to constant 0) 01 = DQS toggling with inverted polarity 10 = DQS toggling with normal polarity (This should be the default setting) 11 = DQS disabled (Driven to constant 1) |
| 6     | RW   | 0x0         | DQSRPD DQSR Power Down: Powers down, if set, the PDQSR cell. This bit is ORed with the common PDR configuration bit                                                                                                                                                                                                                                                                                                                                                                                                            |



| Bit | Attr | Reset Value | Description                                         |
|-----|------|-------------|-----------------------------------------------------|
|     |      |             | DXPDR                                               |
|     |      |             | Data Power Down Receiver: Powers down,              |
| _   | DW   | 00          | when set, the input receiver on I/O for DQ,         |
| 5   | RW   | 0x0         | DM, and DQS/DQS# pins of the byte. This bit         |
|     |      |             | is ORed with the common PDR configuration           |
|     |      |             | bit                                                 |
|     |      |             | DXPDD                                               |
|     |      |             | Data Power Down Driver: Powers down, when           |
| 4   | RW   | 0x0         | set, the output driver on I/O for DQ, DM, and       |
|     |      |             | DQS/DQS# pins of the byte. This bit is ORed         |
|     |      |             | with the common PDD configuration bit               |
|     |      |             | DXIOM                                               |
|     |      |             | Data I/O Mode: Selects SSTL mode (when set          |
| 3   | RW   | 0×0         | to 0) or CMOS mode (when set to 1) of the I/O       |
| 3   | INVV | 0.00        | for DQ, DM, and DQS/DQS# pins of the byte.          |
|     |      |             | This bit is ORed with the IOM configuration bit     |
|     |      |             | of the individual DATX8                             |
|     |      |             | DQODT                                               |
|     |      |             | Data On-Die Termination: Enables, when set,         |
| 2   | RW   | 0×0         | the on-die termination on the I/O for DQ and        |
|     |      |             | DM pins of the byte. This bit is ORed with the      |
|     |      |             | common DATX8 ODT                                    |
|     |      |             | configuration bit                                   |
|     |      |             | DQSODT                                              |
|     |      | • 1         | DQS On-Die Termination: Enables, when set,          |
| 1   | RW   | 0x0         | the on-die termination on the I/O for               |
|     |      |             | DQS/DQS# pin of the byte. This bit is ORed          |
|     |      |             | with the common DATX8 ODT                           |
|     | 1    |             | configuration bit                                   |
|     | CN   | 7           | DXEN                                                |
|     |      |             | Data Byte Enable: Enables if set the DATX8          |
| .0  |      |             | and SSTL I/Os used on the data byte.                |
| 0   | RW   | 0x1         | Setting this bit to '0' disables the byte, i.e. the |
| 7   |      |             | byte SSTL I/Os are put in power-down mode           |
|     |      |             | and the DLL in the DATX8 is put in bypass           |
|     |      |             | mode.                                               |

## DDR\_PHYCTL\_DX3GSR0

Address: Operational Base + offset (0x0284)

DATX8 3 General Status Register 0

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:25 | RO   | 0x0         | reserved    |



| Bit   | Attr | Reset Value | Description                                        |
|-------|------|-------------|----------------------------------------------------|
|       |      |             | DTPASS                                             |
|       |      |             | Data Training Pass Count: The number of            |
| 24:13 | RO   | 0x000       | passing configurations during DQS gate             |
|       |      |             | training. Bits [2:0] are for rank 0, bits [5:3]    |
|       |      |             | for rank 1, and so on.                             |
| 12    | RO   | 0x0         | reserved                                           |
|       |      |             | DTIERR                                             |
|       |      |             | Data Training Intermittent Error: If set,          |
|       |      |             | indicates that there was an intermittent error     |
| 11:8  | RO   | 0x0         | during data training of the byte, such as a pass   |
|       |      |             | was followed by a fail then followed by another    |
|       |      |             | pass. Bit [0] is for rank 0, bit 1 for rank 1, and |
|       |      |             | so on.                                             |
|       |      |             | DTERR                                              |
|       |      |             | Data Training Error: If set, indicates that a      |
| 7:4   | RO   | 0x0         | valid DQS gating window could not be found         |
|       |      |             | during data training of the byte. Bit [0] is for   |
|       |      |             | rank 0, bit 1 for rank 1, and so on.               |
|       | RO   | 0×0         | DTDONE                                             |
| 3:0   |      |             | Data Training Done: Indicates, if set, that the    |
| 3.0   |      |             | byte has finished doing data training. Bit [0] is  |
|       |      |             | for rank 0, bit 1 for rank 1, and so on.           |

#### DDR\_PHYCTL\_DX3GSR1

Address: Operational Base + offset (0x0288)

DATX8 3 General Status Register 1

| Bit   | Attr | Reset Value | Description                                       |
|-------|------|-------------|---------------------------------------------------|
| 31:12 | RO   | 0x0         | reserved                                          |
|       | 11   |             | DQSDFT                                            |
|       |      | ·           | DQS Drift: Used to report the drift on the read   |
| /     |      | 0×00        | data strobe of the data byte. Valid settings      |
|       | RO   |             | are:                                              |
| 11:4  |      |             | 00 = No drift                                     |
|       | KO   |             | 01 = 90 deg drift                                 |
|       |      |             | 10 = 180 deg drift                                |
|       |      |             | 11 = 270 deg drift or more                        |
|       |      |             | Bits [1:0] are for rank 0, bits [3:2] for rank 1, |
|       |      |             | and so on.                                        |



| Bit | Attr | Reset Value | Description                                      |
|-----|------|-------------|--------------------------------------------------|
|     |      |             | DFTERR                                           |
|     |      |             | DQS Drift Error: If set, indicates that the byte |
| 3:0 | RO   |             | read data strobe has drifted by more than or     |
| 3.0 |      |             | equal to the drift limit set in the PHY General  |
|     |      |             | Configuration Register (PGCR). Bit [0] is for    |
|     |      |             | rank 0, bit 1 for rank 1, and so on.             |

# DDR\_PHYCTL\_DX3DLLCR

Address: Operational Base + offset (0x028c)

DATX8 3 DLL Control Register

| Bit   | Attr                 | Reset Value   | Description                                      |
|-------|----------------------|---------------|--------------------------------------------------|
|       |                      |               | DLLDIS                                           |
| 31    | RW                   | 0x0           | DLL Disable: A disabled DLL is bypassed.         |
|       |                      |               | Default ('0') is DLL enabled.                    |
|       |                      |               | DLLSRST                                          |
| 30    | RW                   | 0x1           | DLL Soft Rest: Soft resets the byte DLL by       |
|       |                      |               | driving the DLL soft reset pin.                  |
| 29:20 | RO                   | 0x0           | reserved                                         |
|       |                      |               | SDLBMODE                                         |
|       |                      |               | Slave DLL Loopback Mode: If this bit is set, the |
|       |                      |               | slave DLL is put in loopback mode in which       |
|       |                      |               | there is no 90 degrees phase shift on read       |
| 19    | RW                   | 0x0           | DQS/DQS#. This bit must be set when              |
|       |                      |               | operating the byte PHYs in loopback mode         |
|       |                      | • 0           | such as during BIST loopback. Applicable only    |
|       |                      |               | to PHYs that have this feature. Refer to PHY     |
|       |                      |               | databook.                                        |
|       |                      | $C_{\lambda}$ | ATESTEN                                          |
|       |                      |               | Analog Test Enable: Enables the analog test      |
| 18    | RW                   | 0x0           | signal to be output on the DLL analog test       |
|       | $\mathcal{A}^{\vee}$ |               | output (test_out_a). The DLL analog test         |
|       |                      |               | output is tri-stated when this bit is '0'.       |



| Bit   | Attr  | Reset Value | Description                                    |
|-------|-------|-------------|------------------------------------------------|
|       |       |             | SDPHASE                                        |
|       |       |             | Slave DLL Phase Trim: Selects the phase        |
|       |       |             | difference between the input clock and the     |
|       |       |             | corresponding output clock of the slave DLL.   |
|       |       |             | Valid settings:                                |
|       |       |             | 0000 = 90                                      |
|       |       |             | 0001 = 72                                      |
|       |       |             | 0010 = 54                                      |
|       |       |             | 0011 = 36                                      |
|       |       |             | 0100 = 108                                     |
| 17:14 | RW    | 0x0         | 0101 = 90                                      |
|       |       |             | 0110 = 72                                      |
|       |       |             | 0111 = 54                                      |
|       |       |             | 1000 = 126                                     |
|       |       |             | 1001 = 108                                     |
|       |       |             | 1010 = 90                                      |
|       |       |             | 1011 = 72                                      |
|       |       |             | 1100 = 144                                     |
|       |       |             | 1101 = 126                                     |
|       |       |             | 1110 = 108                                     |
|       |       |             | 1111 = 90                                      |
|       |       |             | SSTART                                         |
|       |       |             | Slave Auto Start-Up: Used to control how the   |
|       |       |             | slave DLL starts up relative to the master DLL |
|       |       |             | locking:                                       |
| 13:12 | RW    | 0×0         | 0X = Slave DLL automatically starts up once    |
| 13.12 | KVV   | UXU         | the master DLL has achieved lock.              |
|       |       |             | 10 = The automatic startup of the slave DLL is |
|       | ~ 1   |             | disabled; the phase detector isdisabled.       |
|       |       | . ~         | 11 = The automatic startup of the slave DLL is |
|       |       |             | disabled; the phase detector is enabled.       |
|       |       |             | MFWDLY                                         |
|       |       |             | Master Feed-Forward Delay Trim: Used to trim   |
| 11.0  | RW    | 0×0         | the delay in the master DLL feed-forward       |
| 11:9  | IK VV |             | path:                                          |
|       |       |             | 000 = minimum delay                            |
|       |       |             | 111 = maximum delay                            |
|       |       |             | MFBDLY                                         |
|       | RW    | 0×0         | Master Feed-Back Delay Trim: Used to trim      |
| 8:6   |       |             | the delay in the master DLL feedback path:     |
|       |       |             | 000 = minimum delay                            |
|       |       |             | 111 = maximum delay                            |



| Bit | Attr | Reset Value | Description                                   |
|-----|------|-------------|-----------------------------------------------|
|     |      |             | SFWDLY                                        |
|     |      |             | Slave Feed-Forward Delay Trim: Used to trim   |
| 5:3 | RW   | 0×0         | the delay in the slave DLL feed-forward path: |
|     |      |             | 000 = minimum delay                           |
|     |      |             | 111 = maximum delay                           |
| 2:0 | RW   | 0×0         | SFBDLY                                        |
|     |      |             | Slave Feed-Back Delay Trim: Used to trim the  |
|     |      |             | delay in the slave DLL feedback path:         |
|     |      |             | 000 = minimum delay                           |
|     |      |             | 111 = maximum delay                           |

### DDR\_PHYCTL\_DX3DQTR

Address: Operational Base + offset (0x0290)

DATX8 3 DQ Timing Register

| Bit   | Attr | Reset Value | Description                                        |
|-------|------|-------------|----------------------------------------------------|
|       |      |             | DQDLY7                                             |
|       |      |             | DQ Delay: Used to adjust the delay of the data     |
|       |      |             | relative to the nominal delay that is matched      |
|       |      |             | to the delay of the data strobes through the       |
|       |      |             | slave DLL and clock tree. Every four bits of this  |
|       |      |             | register control the delay of a different data bit |
|       |      |             | in the byte. DQDLY0 controls the delay of data     |
|       |      |             | bit [0], DQDLY1 controls data bit [1], and so      |
| 31:28 | RW   | 0xf         | on. The lower two bits of the DQDLY for each       |
|       |      | . ()        | DQ bit controls the delay for the data clocked     |
|       |      |             | by DQS, while the higher two bits control the      |
|       |      |             | delay for the data clocked by DQS_b. Valid         |
|       |      |             | settings for each 2-bit control field are:         |
|       | 1    |             | 00 = nominal delay                                 |
|       | CN   | Y           | 01 = nominal delay + 1 step                        |
|       |      |             | 10 = nominal delay + 2 steps                       |
|       |      |             | 11 = nominal delay + 3 steps                       |



| Bit   | Attr | Reset Value | Description                                           |
|-------|------|-------------|-------------------------------------------------------|
|       |      |             | DQDLY6                                                |
|       |      |             | DQ Delay: Used to adjust the delay of the data        |
|       |      |             | relative to the nominal delay that is matched         |
|       |      |             | to the delay of the data strobes through the          |
|       |      |             | slave DLL and clock tree. Every four bits of this     |
|       |      |             | register control the delay of a different data bit    |
|       |      |             | in the byte. DQDLY0 controls the delay of data        |
|       |      |             | bit [0], DQDLY1 controls data bit [1], and so         |
| 27:24 | RW   | 0xf         | on. The lower two bits of the DQDLY for each          |
|       |      |             | DQ bit controls the delay for the data clocked        |
|       |      |             | by DQS, while the higher two bits control the         |
|       |      |             | delay for the data clocked by DQS_b. Valid            |
|       |      |             | settings for each 2-bit control field are:            |
|       |      |             | 00 = nominal delay                                    |
|       |      |             | 01 = nominal delay + 1 step                           |
|       |      |             | 10 = nominal delay + 2 steps                          |
|       |      |             | 11 = nominal delay + 3 steps                          |
|       |      |             | DQDLY5 DQ Delay: Used to adjust the delay of the data |
|       |      |             | relative to the nominal delay that is matched         |
|       |      |             | to the delay of the data strobes through the          |
|       |      |             | slave DLL and clock tree. Every four bits of this     |
|       |      |             | register control the delay of a different data bit    |
|       |      |             | in the byte. DQDLY0 controls the delay of data        |
|       |      |             | bit [0], DQDLY1 controls data bit [1], and so         |
| 23:20 | RW   | 0xf         | on. The lower two bits of the DQDLY for each          |
|       |      | AAY'        | DQ bit controls the delay for the data clocked        |
|       |      |             | by DQS, while the higher two bits control the         |
|       | A 1  | 0           | delay for the data clocked by DQS_b. Valid            |
|       |      | 7           | settings for each 2-bit control field are:            |
|       |      | Y           | 00 = nominal delay                                    |
|       |      |             | 01 = nominal delay + 1 step                           |
|       |      |             | 10 = nominal delay + 2 steps                          |
|       |      |             | 11 = nominal delay + 3 steps                          |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      |             | DQDLY4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 19:16 | RW   | 0xf         | DQ Delay: Used to adjust the delay of the data relative to the nominal delay that is matched to the delay of the data strobes through the slave DLL and clock tree. Every four bits of this register control the delay of a different data bit in the byte. DQDLY0 controls the delay of data bit [0], DQDLY1 controls data bit [1], and so on. The lower two bits of the DQDLY for each DQ bit controls the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS_b. Valid settings for each 2-bit control field are:  00 = nominal delay 01 = nominal delay + 1 step 10 = nominal delay + 2 steps                                                                                                              |
| 15:12 | RW   | 0xf         | DQDLY3 DQ Delay: Used to adjust the delay of the data relative to the nominal delay that is matched to the delay of the data strobes through the slave DLL and clock tree. Every four bits of this register control the delay of a different data bit in the byte. DQDLY0 controls the delay of data bit [0], DQDLY1 controls data bit [1], and so on. The lower two bits of the DQDLY for each DQ bit controls the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS_b. Valid settings for each 2-bit control field are:  00 = nominal delay 01 = nominal delay + 1 step 10 = nominal delay + 2 steps 11 = nominal delay + 3 steps |



| Bit  | Attr | Reset Value | Description                                                                                       |
|------|------|-------------|---------------------------------------------------------------------------------------------------|
|      |      |             | DQDLY2                                                                                            |
|      |      |             | DQ Delay: Used to adjust the delay of the data                                                    |
|      |      |             | relative to the nominal delay that is matched                                                     |
|      |      |             | to the delay of the data strobes through the                                                      |
|      |      |             | slave DLL and clock tree. Every four bits of this                                                 |
|      |      |             | register control the delay of a different data bit                                                |
|      |      |             | in the byte. DQDLY0 controls the delay of data                                                    |
|      |      |             | bit [0], DQDLY1 controls data bit [1], and so                                                     |
| 11:8 | RW   | 0xf         | on. The lower two bits of the DQDLY for each                                                      |
|      |      |             | DQ bit controls the delay for the data clocked                                                    |
|      |      |             | by DQS, while the higher two bits control the                                                     |
|      |      |             | delay for the data clocked by DQS_b. Valid                                                        |
|      |      |             | settings for each 2-bit control field are:                                                        |
|      |      |             | 00 = nominal delay                                                                                |
|      |      |             | 01 = nominal delay + 1 step                                                                       |
|      |      |             | 10 = nominal delay + 2 steps                                                                      |
|      |      |             | 11 = nominal delay + 3 steps                                                                      |
|      |      |             | DQDLY1                                                                                            |
|      |      |             | DQ Delay: Used to adjust the delay of the data                                                    |
|      |      |             | relative to the nominal delay that is matched                                                     |
|      |      |             | to the delay of the data strobes through the                                                      |
|      |      |             | slave DLL and clock tree. Every four bits of this                                                 |
|      |      |             | register control the delay of a different data bit in the byte. DQDLY0 controls the delay of data |
|      |      |             | bit [0], DQDLY1 controls data bit [1], and so                                                     |
| 7:4  | RW   | 0xf         | on. The lower two bits of the DQDLY for each                                                      |
| /    |      | OAI ,       | DQ bit controls the delay for the data clocked                                                    |
|      |      |             | by DQS, while the higher two bits control the                                                     |
|      |      | ( ) Y       | delay for the data clocked by DQS_b. Valid                                                        |
|      | N    | 7           | settings for each 2-bit control field are:                                                        |
|      |      | Y           | 00 = nominal delay                                                                                |
|      |      |             | 01 = nominal delay + 1 step                                                                       |
|      |      |             | 10 = nominal delay + 2 steps                                                                      |
|      |      |             | 11 = nominal delay + 3 steps                                                                      |



| Bit | Attr | Reset Value | Description                                        |
|-----|------|-------------|----------------------------------------------------|
|     |      |             | DQDLY0                                             |
|     |      |             | DQ Delay: Used to adjust the delay of the data     |
|     |      |             | relative to the nominal delay that is matched      |
|     |      |             | to the delay of the data strobes through the       |
|     |      |             | slave DLL and clock tree. Every four bits of this  |
|     |      |             | register control the delay of a different data bit |
|     |      |             | in the byte. DQDLY0 controls the delay of data     |
|     |      |             | bit [0], DQDLY1 controls data bit [1], and so      |
| 3:0 | RW   | 0xf         | on. The lower two bits of the DQDLY for each       |
|     |      |             | DQ bit controls the delay for the data clocked     |
|     |      |             | by DQS, while the higher two bits control the      |
|     |      |             | delay for the data clocked by DQS_b. Valid         |
|     |      |             | settings for each 2-bit control field are:         |
|     |      |             | 00 = nominal delay                                 |
|     |      |             | 01 = nominal delay + 1 step                        |
|     |      |             | 10 = nominal delay + 2 steps                       |
|     |      |             | 11 = nominal delay + 3 steps                       |

## DDR\_PHYCTL\_DX3DQSTR

Address: Operational Base + offset (0x0294) DATX8 3 DQS Timing Register

| Bit            | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                           |
|----------------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30          | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                              |
| 31:30<br>29:26 | RO   | Oxf         | reserved  DMDLY  DM Delay: Used to adjust the delay of the data mask relative to the nominal delay that is matched to the delay of the data strobes through the slave DLL and clock tree. The lower two bits of the DQMDLY controls the delay for the data clocked by DQS, while the higher two bits control the delay for the data clocked by DQS_b. |
|                |      |             | Valid settings for each 2-bit control field are:<br>00 = nominal delay                                                                                                                                                                                                                                                                                |
|                |      |             | 01 = nominal delay + 1 step                                                                                                                                                                                                                                                                                                                           |
|                |      |             | 10 = nominal delay + 2 steps                                                                                                                                                                                                                                                                                                                          |
|                |      |             | 11 = nominal delay + 3 steps                                                                                                                                                                                                                                                                                                                          |

| Bit   | Attr | Reset Value | Description                                     |
|-------|------|-------------|-------------------------------------------------|
|       |      |             | DQSNDLY                                         |
|       |      |             | DQS# Delay: Used to adjust the delay of the     |
|       |      |             | data strobes relative to the nominal delay that |
|       |      |             | is matched to the delay of the data bit through |
|       |      |             | the slave DLL and clock tree. DQSDLY control    |
|       |      |             | the delay on DQS strobe and DQSNDLY control     |
|       |      |             | the delay on DQS#. Valid values are:            |
| 25:23 | RW   | 0x3         | 000 = nominal delay - 3 steps                   |
|       |      |             | 001 = nominal delay - 2 steps                   |
|       |      |             | 010 = nominal delay - 1 step                    |
|       |      |             | 011 = nominal delay                             |
|       |      |             | 100 = nominal delay + 1 step                    |
|       |      |             | 101 = nominal delay + 2 steps                   |
|       |      |             | 110 = nominal delay + 3 steps                   |
|       |      |             | 111 = nominal delay + 4 steps                   |
|       |      |             | DQSDLY                                          |
|       |      |             | DQS Delay: Used to adjust the delay of the      |
|       |      |             | data strobes relative to the nominal delay that |
|       |      |             | is matched to the delay of the data bit through |
|       |      |             | the slave DLL and clock tree. DQSDLY control    |
|       |      |             | the delay on DQS strobe and DQSNDLY control     |
|       |      |             | the delay on DQS#. Valid values are:            |
| 22:20 | RW   | 0x3         | 000 = nominal delay - 3 steps                   |
|       |      |             | 001 = nominal delay - 2 steps                   |
|       |      | • (         | 010 = nominal delay - 1 step                    |
|       |      |             | 011 = nominal delay                             |
|       |      |             | 100 = nominal delay + 1 step                    |
|       |      | CA          | 101 = nominal delay + 2 steps                   |
|       | 11   |             | 110 = nominal delay + 3 steps                   |
|       |      | 7           | 111 = nominal delay + 4 steps                   |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19:18 | RW   | 0x1         | R3DGPS Rank n DQS Gating Phase Select: Selects the clock used to enable the data strobes during read so that the value of the data strobes before and after the preamble/postamble are filtered out. The RnDGPS fields are initially set by the PHYCTL during automatic DQS data training and subsequently updated during data strobe drift compensation. However, these values can be overwritten by a direct write to this register, and the automatic update during DQS drift compensation can be disabled using the PHY General Configuration Register (PGCR). Every two bits of this register control the DQS gating for each of the (up to) four ranks. R0DGPS controls the DQS gating for rank 0, R1DGPS controls rank 1, and so on. Valid values for each 2-bit RnDGPS field are: 00 = 90 deg clock (clk90) 01 = 180 deg clock (clk180) 10 = 270 deg clock (clk270) 11 = 360 deg clock (clk0) |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17:16 | RW   | 0x1         | R2DGPS Rank n DQS Gating Phase Select: Selects the clock used to enable the data strobes during read so that the value of the data strobes before and after the preamble/postamble are filtered out. The RnDGPS fields are initially set by the PHYCTL during automatic DQS data training and subsequently updated during data strobe drift compensation. However, these values can be overwritten by a direct write to this register, and the automatic update during DQS drift compensation can be disabled using the PHY General Configuration Register (PGCR). Every two bits of this register control the DQS gating for each of the (up to) four ranks. R0DGPS controls the DQS gating for rank 0, R1DGPS controls rank 1, and so on. Valid values for each 2-bit RnDGPS field are: 00 = 90 deg clock (clk90) 01 = 180 deg clock (clk180) 10 = 270 deg clock (clk270) 11 = 360 deg clock (clk0) |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:14 | RW   | 0x1         | R1DGPS Rank n DQS Gating Phase Select: Selects the clock used to enable the data strobes during read so that the value of the data strobes before and after the preamble/postamble are filtered out. The RnDGPS fields are initially set by the PHYCTL during automatic DQS data training and subsequently updated during data strobe drift compensation. However, these values can be overwritten by a direct write to this register, and the automatic update during DQS drift compensation can be disabled using the PHY General Configuration Register (PGCR). Every two bits of this register control the DQS gating for each of the (up to) four ranks. R0DGPS controls the DQS gating for rank 0, R1DGPS controls rank 1, and so on. Valid values for each 2-bit RnDGPS field are: 00 = 90 deg clock (clk90) 01 = 180 deg clock (clk180) 10 = 270 deg clock (clk270) 11 = 360 deg clock (clk0) |

Rockchil



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:12 | RW   | 0x1         | RODGPS Rank n DQS Gating Phase Select: Selects the clock used to enable the data strobes during read so that the value of the data strobes before and after the preamble/postamble are filtered out. The RnDGPS fields are initially set by the PHYCTL during automatic DQS data training and subsequently updated during data strobe drift compensation. However, these values can be overwritten by a direct write to this register, and the automatic update during DQS drift compensation can be disabled using the PHY General Configuration Register (PGCR). Every two bits of this register control the DQS gating for each of the (up to) four ranks. R0DGPS controls the DQS gating for rank 0, R1DGPS controls rank 1, and so on. Valid values for each 2-bit RnDGPS field are: 00 = 90 deg clock (clk90) 01 = 180 deg clock (clk180) 10 = 270 deg clock (clk270) 11 = 360 deg clock (clk0) |

Rockenin



| Bit  | Attr | Reset Value | Description                                       |
|------|------|-------------|---------------------------------------------------|
|      |      |             | R3DGSL                                            |
|      |      |             | Rank n DQS Gating System Latency: Used to         |
|      |      |             | increase the number of clock cycles needed to     |
|      |      |             | expect valid DDR read data by up to five extra    |
|      |      |             | clock cycles. This is used to compensate for      |
|      |      |             | board delays and other system delays.             |
|      |      |             | Power-up default is 000 (i.e. no extra clock      |
|      |      |             | cycles required). The SL fields are initially set |
|      |      |             | by the PHYCTL during automatic DQS data           |
|      |      |             | training but these values can be overwritten by   |
|      |      |             | a direct write to this register. Every three bits |
| 11:9 | RW   | 0x0         | of this register control the latency of each of   |
|      |      |             | the (up to) four ranks. R0DGSL controls the       |
|      |      |             | latency of rank 0, R1DGSL controls rank 1, and    |
|      |      |             | so on. Valid values are:                          |
|      |      |             | 000 = No extra clock cycles                       |
|      |      |             | 001 = 1 extra clock cycle                         |
|      |      |             | 010 = 2 extra clock cycles                        |
|      |      |             | 011 = 3 extra clock cycles                        |
|      |      |             | 100 = 4 extra clock cycles                        |
|      |      |             | 101 = 5 extra clock cycles                        |
|      |      |             | 110 = Reserved                                    |
|      |      |             | 111 = Reserved                                    |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:6 | RW   | 0x0         | R2DGSL Rank n DQS Gating System Latency: Used to increase the number of clock cycles needed to expect valid DDR read data by up to five extra clock cycles. This is used to compensate for board delays and other system delays. Power-up default is 000 (i.e. no extra clock cycles required). The SL fields are initially set by the PHYCTL during automatic DQS data training but these values can be overwritten by a direct write to this register. Every three bits of this register control the latency of each of the (up to) four ranks. R0DGSL controls the latency of rank 0, R1DGSL controls rank 1, and so on. Valid values are:  000 = No extra clock cycles 001 = 1 extra clock cycles 010 = 2 extra clock cycles 011 = 3 extra clock cycles 100 = 4 extra clock cycles 101 = 5 extra clock cycles 101 = Reserved 111 = Reserved |

| Bit Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit Attr | 0x0         | R1DGSL Rank n DQS Gating System Latency: Used to increase the number of clock cycles needed to expect valid DDR read data by up to five extra clock cycles. This is used to compensate for board delays and other system delays. Power-up default is 000 (i.e. no extra clock cycles required). The SL fields are initially set by the PHYCTL during automatic DQS data training but these values can be overwritten by a direct write to this register. Every three bits of this register control the latency of each of the (up to) four ranks. R0DGSL controls the latency of rank 0, R1DGSL controls rank 1, and so on. Valid values are:  000 = No extra clock cycles  001 = 1 extra clock cycles  001 = 2 extra clock cycles  100 = 4 extra clock cycles  101 = 5 extra clock cycles  101 = 5 extra clock cycles |

| Bit | Attr | Reset Value | Description                                       |
|-----|------|-------------|---------------------------------------------------|
|     |      |             | R0DGSL                                            |
|     |      |             | Rank n DQS Gating System Latency: Used to         |
|     |      |             | increase the number of clock cycles needed to     |
|     |      |             | expect valid DDR read data by up to five extra    |
|     |      |             | clock cycles. This is used to compensate for      |
|     |      |             | board delays and other system delays.             |
|     |      |             | Power-up default is 000 (i.e. no extra clock      |
|     |      |             | cycles required). The SL fields are initially set |
|     |      |             | by the PHYCTL during automatic DQS data           |
|     |      |             | training but these values can be overwritten by   |
|     |      |             | a direct write to this register. Every three bits |
| 2:0 | RW   | 0x0         | of this register control the latency of each of   |
|     |      |             | the (up to) four ranks. R0DGSL controls the       |
|     |      |             | latency of rank 0, R1DGSL controls rank 1, and    |
|     |      |             | so on. Valid values are:                          |
|     |      |             | 000 = No extra clock cycles                       |
|     |      |             | 001 = 1 extra clock cycle                         |
|     |      |             | 010 = 2 extra clock cycles                        |
|     |      |             | 011 = 3 extra clock cycles                        |
|     |      |             | 100 = 4 extra clock cycles                        |
|     |      |             | 101 = 5 extra clock cycles                        |
|     |      |             | 110 = Reserved                                    |
|     |      |             | 111 = Reserved                                    |

## 13.6 Timing Diagram

## 13.6.1 DDR3 Read/Write Access Timing



Fig. 13-10DDR3 burst write operation: AL=0,CWL=4, BC4



Fig. 13-11DDR3 burst read operation: AL=0,CL=5, BC4

tCK

 $t_{QH}$ 

| Table 13-17 meaning of the parameter in Fig.13-10 and Fig.13-11 |                                                  |          |           |      |
|-----------------------------------------------------------------|--------------------------------------------------|----------|-----------|------|
| Parameter                                                       | Description                                      | DDR3-800 |           | unit |
| rarameter                                                       | Description                                      | min      | max       | unic |
| t <sub>CH</sub>                                                 | CK HIGH pulse width                              | 0.43     | _         | tCK  |
| $t_CL$                                                          | CK LOW pulse width                               | 0.43     | _         | tCK  |
| t <sub>DS</sub>                                                 | DQ and DM input setup time (differential strobe) | 75       | -         | ps   |
| t <sub>DH</sub>                                                 | DQ and DM input hold time (differential strobe)  | 150      | -         | ps   |
| t <sub>DSS</sub>                                                | DQS falling edge to CK setup time                | 0.2      | _         | tCK  |
| t <sub>DSH</sub>                                                | DQS falling edge hold time from CK               | 0.2      | -         | tCK  |
| $t_{IS}$                                                        | Address and control input setup time             | 200      | -         | ps   |
| $t_{IH}$                                                        | Address and control input hold time              | 275      | -         | ps   |
| t <sub>WPRE</sub>                                               | Write preamble                                   | 0.9      | - , , , ( | tCK  |
| t <sub>WPST</sub>                                               | Write postamble                                  | 0.3      | -         | tCK  |
| t <sub>RPRE</sub>                                               | Read preamble                                    | 0.9      | 1.1       | tCK  |
| t <sub>RPST</sub>                                               | Read postamble                                   | 0.3      | 0.5       | tCK  |
| t <sub>DQSCK</sub>                                              | DQS output access time from CK/CK_n              | -400     | +400      | ps   |
| t <sub>DQSQ</sub>                                               | DQS-DQ skew for DQS and associated DQ signals    | 0        | 200       | ps   |

## 13.6.2 LPDDR2 Read/Write Access Timing

DQ/DQS output hold time from DQS



Fig. 13-12LPDDR2 burst write operation: WL=1,BL=4



Fig. 13-13LPDDR2 burst read operation: RL=3, BL=4

Table 13-18 meaning of the parameter in Fig.13-12 and Fig.13-13

| 14516 15 15 meaning of the parameter in 118.15 12 and 118.15 15 |                     |               |      |      |
|-----------------------------------------------------------------|---------------------|---------------|------|------|
| Parameter                                                       | Description         | LPDDR2 S4-800 |      | unit |
|                                                                 |                     | min           | max  | unit |
| t <sub>CH</sub>                                                 | CK HIGH pulse width | 0.43          | 0.57 | tCK  |
| t <sub>CL</sub>                                                 | CK LOW pulse width  | 0.43          | 0.57 | tCK  |



| $t_{DS}$           | DQ and DM inputsetup time                     | 0.27                                | _                     | ns  |
|--------------------|-----------------------------------------------|-------------------------------------|-----------------------|-----|
| t <sub>DH</sub>    | DQ and DM input hold time                     | 0.27                                | _                     | ns  |
|                    | '                                             | _                                   |                       |     |
| t <sub>DSS</sub>   | DQS falling edge to CK setup time             | 0.2                                 | -                     | tCK |
| t <sub>DSH</sub>   | DQS falling edge hold time from CK            | 0.2                                 | -                     | tCK |
| $t_{IS}$           | Address and control input setup time          | 0.29                                | -                     | ns  |
| t <sub>IH</sub>    | Address and control input hold time           | 0.29                                | -                     | ns  |
| t <sub>WPRE</sub>  | Write preamble                                | 0.35                                | -                     | tCK |
| t <sub>WPST</sub>  | Write postamble                               | 0.4                                 | -                     | tCK |
| t <sub>RPRE</sub>  | Read preamble                                 | 0.9                                 | -                     | tCK |
| t <sub>RPST</sub>  | Read postamble                                | t <sub>CL</sub> -0.05               | t <sub>CL</sub> -0.05 | tCK |
| t <sub>DQSCK</sub> | DQS output access time from CK/CK_n           | 2.5                                 | 5.5                   | ns  |
| t <sub>DQSQ</sub>  | DQS-DQ skew for DQS and associated DQ signals | 0.24                                | 0.28                  | ns  |
| t <sub>QH</sub>    | DQ/DQS output hold time from DQS              | t <sub>QHP</sub> - t <sub>QHS</sub> | 7                     | ns  |
| RL                 | Read Latency                                  | 6                                   |                       |     |
| WL                 | Write Latency                                 | 3                                   |                       | _   |

# 13.7 Interface description

DDR IOs are listed as following Table.

| Pin Name        | Description                                                                     |
|-----------------|---------------------------------------------------------------------------------|
| CK              | Active-high clock signal to the memory device.                                  |
| CK_B            | Active-low clock signal to the memory device.                                   |
| CKEi (i=0,1)    | Active-high clock enable signal to the memory device for two chip select.       |
| CS_Bi (i=0,1)   | Active-low chip select signal to the memory device. AThere are two chip select. |
| RAS_B           | Active-low row address strobe to the memory device.                             |
| CAS_B           | Active-low column address strobe to the memory device.                          |
| WE_B            | Active-low write enable strobe to the memory device.                            |
| BA[2:0]         | Bank address signal to the memory device.                                       |
| A[15:0]         | Address signal to the memory device.                                            |
| DQ[31:0]        | Bidirectional data line to the memory device.                                   |
| DQS[3:0]        | Active-high bidirectional data strobes to the memory device.                    |
| DQS_B[3:0]      | Active-low bidirectional data strobes to the memory device.                     |
| DM[3:0]         | Active-low data mask signal to the memory device.                               |
| ODTi (i=0,1)    | On-Die Termination output signal for two chip select.                           |
| RET_EN          | Active-low retention latch enable input.                                        |
| VREFi (i=0,1,2) | Reference Voltage input for three regions of DDR IO.                            |
| ZQ_PIN          | ZQ calibration pad which connects 240ohm±1% resistor.                           |
| RESET           | DDR3 reset signal.                                                              |



## 13.8 Application Notes

#### 13.8.1 State transition of PCTL

To operate PCTL, the programmer must be familiar with the available operational states and how to transition to each state from the current state.

Every software programmable register is accessible only during certain operational states. For information about what registers are accessible in each state, refer to "Software Registers," which provides this information in each register description. The general rule is that the PCTL must be in the Init\_mem or Config states to successfully write most of the registers.

The following tables provide the programming sequences for moving to the various states of the state machine.

Moving to the Init mem State

| Step | Application                                                  | PCTL                                                                                                                                              |
|------|--------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | Read STAT register                                           | ReturnsthecurrentPCTLstate.                                                                                                                       |
| 2    | If STAT.ctl_stat = Init_mem, go toEND.                       | A (2.)                                                                                                                                            |
| 3    | If STAT.ctl_stat =Config, go toStep9.                        |                                                                                                                                                   |
| 4    | If STAT.ctl_stat =Access, go toStep8.                        |                                                                                                                                                   |
|      | If STAT.ctl_stat = Low_power,<br>go toStep7.                 |                                                                                                                                                   |
| 6    | Goto Step1.                                                  | PCTLis ina Transitionalstate and not inany ofthe previous operationalstates.                                                                      |
| 7    | WriteWAKEUPtoSCTL.state_cmd andpoll STAT.ctl_stat= Access.   | IssuesSRX,movestotheAccessstate,updates<br>STAT.ctl_stat =Accesswhen complete.                                                                    |
| 8    | WriteCFG to SCTL.state_cmd andpoll<br>STAT.ctl_stat= Config. | PCTLstalls the NIF;completesany pending transaction; issuesPREAifrequired; movesintothe Config state; updates STAT.ctl_stat =Config whencomplete. |
| 9    | WriteINITto SCTL.state_cmd andpoll<br>STAT.ctl_stat=Init_mem | Moves intotheInit_mem stateandupdatesSTAT.ctl_stat =Init_mem.                                                                                     |
| END  |                                                              | PCTLis inInit_memstate.                                                                                                                           |

### **Moving to Config State**

| Step | Application                                     | PCTL                                                                       |
|------|-------------------------------------------------|----------------------------------------------------------------------------|
| 1    | Read STAT register.                             | Returns thecurrentPCTLstate.                                               |
| 2    | If STAT.ctl_stat= Config, goto END.             |                                                                            |
| 3    | If STAT.ctl_stat= Low_power,gotoStep6.          |                                                                            |
| 4    | If STAT.ctl_stat= Init_mem or Access,gotoStep7. |                                                                            |
| 5    | GotoStep1.                                      | PCTLisinatransitionalstateandisnotinanyof the previous operational states. |



| 6   | WriteWAKEUPtoSCTL.state_cmdand poll STAT.ctl_stat= Access. | Issues SRX,movesto theAccess state,and updates STAT.ctl_stat= Accesswhen complete.                                                                      |
|-----|------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | WriteCFGtoSCTL.state_cmdand poll STAT.ctl_stat= Config.    | PCTLstalls the NIF; completesanypending transaction; issuesPREAif required;moves into the Configstate; and updates STAT.ctl_stat = Config whencomplete. |
| END |                                                            | PCTLis in Configstate.                                                                                                                                  |

## **Moving to Access State**

| Step | Application                                                         | PCTL                                                                          |
|------|---------------------------------------------------------------------|-------------------------------------------------------------------------------|
| 1    | Read STATregister                                                   | Returns the current PCTLstate.                                                |
| 2    | IfSTAT.ctl_stat= Access,goto END.                                   | • 0                                                                           |
| 3    | IfSTAT.ctl_stat= Config, gotoStep9                                  | X                                                                             |
| 4    | IfSTAT.ctl_stat= Init_mem, gotoStep8                                |                                                                               |
| 5    | IfSTAT.ctl_stat= Low_power,go to Step7.                             |                                                                               |
| 6    | GotoStep1.                                                          | PCTLisinatransitionalstateandisnot inanyofthe previous operationalstates.     |
| 7    | WriteWAKEUPtoSCTL.state_cmdandpoll<br>STAT.ctl_stat= Access.GotoEND | Issues SRX,movestotheAccess state,updates STAT.ctl_stat= Accesswhen complete. |
| 8    | WriteCFGtoSCTL.state_cmdandpoll STAT.ctl_stat= Config.              | MovesintotheConfigstate,updates STAT.ctl_stat= Config when complete.          |
| 9    | WriteGOtoSCTL.state_cmd andpoll STAT.ctl_stat= Access.              | MovesintotheAccessstate, updates STAT.ctl_stat= Accesswhen complete.          |
| END  | • , • )                                                             | PCTLis inAccess state.                                                        |

**Moving to Low Power State** 

| Step | Application                                               | PCTL                                                                        |
|------|-----------------------------------------------------------|-----------------------------------------------------------------------------|
| 1    | Read STAT register.                                       | Returnscurrent PCTL state.                                                  |
| 2    | If STAT.ctl_stat =Low_power, goto END.                    |                                                                             |
| 3    | If STAT.ctl_stat = Access,gotoStep9                       |                                                                             |
| 4    | If STAT.ctl_stat = Config,gotoStep8                       |                                                                             |
| 5    | If STAT.ctl_stat = Init_mem,go toStep7.                   |                                                                             |
| 6    | Goto Step1.                                               | PCTL is intransitionalstateandis notin anyofthe previous operationalstates. |
| 7    | WriteCFG to SCTL.state_cmdand poll STAT.ctl_stat= Config. | Movesintothe Configstate, updates<br>STAT.ctl_stat = Config when complete.  |
| 8    | WriteGOtoSCTL.state_cmdandpoll<br>STAT.ctl_stat= Access.  | MovesintotheAccessstate,updates<br>STAT.ctl_stat =Access whencomplete.      |



#### 13.8.2 Initialization

Figure 13-14 shows a high-level illustration of the initialization sequence of the PHY. A detailed sequence description and timing diagrams are described in the following. This section assumes a generic configuration port and therefore cfg\_clk and cfg\_rst\_n are shown as the configuration clock and reset, respectively. These signals must be replaced by pclk and presetn if the design is compiled to use the APB configuration port.



Fig. 13-14Protocol controller architecture

#### **PHY Initialization**

The initialization sequence has two phases. The first phase happens automatically at reset and is as follows:

- 1. Before and during configuration reset (i.e. if cfg\_rst\_n is asserted), the PHY is un-initialized and remains in this state until the reset is de-asserted.
- 2. At reset de-assertion, the PHY moves into the DLL initialization (lock) phase. This phase may be bypassed at any time by writing a '1' to the DLL initialization bypass register bit (PIR[LOCKBYP]).
- 3. In parallel to DLL initialization, the impedance calibration phase also starts at reset de-assertion.

This phase can also be bypassed by writing a '1' to the impedance calibration bypass register bit-PIR[ZCALBYP].

4. If the PHY initialization sequence was triggered by the user, a soft reset may optionally be selected to be issued to the ITMs. Initialization that is automatically triggered on reset does not issue a soft reset to the ITMs because the components will already have been reset by the main reset.



Once the DLL initialization and impedance calibration phases are done and after the ITMs are reset, the PHY is initialized. Note that if these phases were bypassed, it is up to the user to perform them in software or trigger them at a later time before the PHY can be used.

#### **SDRAM Initialization**

The second phase of initialization starts after the PHY is initialized. Each step of this phase is triggered by the user or memory controller and is as follows:

1. Prior to normal operation, DDR SDRAMs must be initialized. The PHYCTL has a built-in SDRAM initialization routine that may be triggered by software or memory controller by writing to the PHY Initialization Register (PIR). The initialization routine built into the PHYCTL is generic and does not require any knowledge of the type or configuration of external SDRAMs to be properly executed. The routine is designed with the relevant JEDEC specifications for the fastest & slowest SDRAMs supported by the PHYCTL to result in a universal initialization sequence. This generic sequence is applicable to DDR3, DDR2, LPDDR2, LPDDR, and DDR SDRAMs.

It is recommended to use the built-in PHYCTL routine to initialize the SDRAM. However, there may be cases such as during system debug when the built-in PHYCTL DRAM initialization is not triggered and DRAM initialization is performed by software or the controller. In these cases the system must first wait for the PHY to initialize, i.e. DLL locked and impedance calibration done, then it must write a '1' to PIR[INIT] bit with PIR[CTLDINT] set to '1' (for controller initialization) or '0' (for software or PHYCTL initialization) to inform the PHYCTL that DRAM initialization will be done later, by software, the controller or by re-triggering on the PHYCTL. The software or controller then executes the initialization sequence by sending relevant commands to the DRAM, respecting the various timing requirements of the initialization sequence.

- 2. After the SDRAM is initialized, the user or memory controller performs, or triggers the PHYCTL to perform DQS gate training ("Built-in DQS Gate Training" on page 114). The SDRAM must be initialized before triggering DQS gate training.
- 3. The user or memory controller performs, or triggers the PHYCTL to perform read data eye training. Note that the current version of the PHYCTL does not have the read eye training designed in.
  - 4. The PHY is now ready for SDRAM read/write accesses.

#### **DDR3 Initialization Sequence**

The initialization steps for DDR3 SDRAMs are as follows:

- 1. Optionally maintain RESET# low for a minimum of either 200 us (power-up initialization) or 100ns (power-on initialization). The PHYCTL drives RESET# low from the beginning of reset assertion and therefore this step may be skipped when DRAM initialization is triggered if enough time may already have expired to satisfy the RESET# low time.
  - 2. After RESET# is de-asserted, wait a minimum of 500 us with CKE low.
  - 3. Apply NOP and drive CKE high.
  - 4. Wait a minimum of tXPR.
  - 5. Issue a load Mode Register 2 (MR2) command.
  - 6. Issue a load Mode Register 3 (MR3) command.
- 7. Issue a load Mode Register (MR1) command (to set parameters and enable DLL).
- 8. Issue a load Mode Register (MR0) command to set parameters and reset
  - 9. Issue ZQ calibration command.



10. Wait 512 SDRAM clock cycles for the DLL to lock (tDLLK) and ZQ calibration (tZQinit) to finish. This wait time is relative to Step 8, i.e. relative to when the DLL reset command was issued onto the SDRAM command bus.

## LPDDR2 Initialization Sequence

The initialization steps for LPDDR2 SDRAMs are as follows:

- 1. Wait a minimum of 100 ns (tINIT1) with CKE driven low.
- 2. Apply NOP and set CKE high.
- 3. Wait a minimum of 200 us (tINIT3).
- 4. Issue a RESET command.
- 5. Wait a minimum of 1 us + 10 us (tINIT4 + tINIT5).
- 6. Issue a ZO calibration command.
- 7. Wait a minimum of 1 us (tZQINIT).
- 8. Issue a Write Mode Register to MR1.
- 9. Issue a Write Mode Register to MR2
- 10. Issue a Write Mode Register to MR3

## **Initialization Triggerred and bypass**

All initialization steps shown in Figure 3-1 on page 34 can be triggered using the PHY Initialization Register (PIR) as described in "PHY Initialization Register (PIR)" on page 47. Writing a '1' to PIR[INIT] register bit will start initialization, with the routines to be run being selected by the corresponding PIR register bits. If multiple routines are selected, they are run in the order shown in Figure 3-1 on page 34. This is also the order of the select bits in PIR register. The completion of the routines is indicated in the PHY General Status Register (PGSR) with the corresponding done status bits (see "PHY General Status Register (PGSR)" on page 52). The PGSR[IDONE] bit indicates the overall completion of the initialization sequence. An initialization done status register bit is cleared (reset to '0') when the corresponding routine is re-triggered.

The de-assertion of reset will automatically trigger the PHYCTL to perform DLL initialization (locking) and impedance calibration. Once the DLL has locked and impedance calibration has completed, the SDRAM initialization and DQS gating may be triggered or performed by software or memory controller.

Since the PHYCTL allows the selection of individual routines to be run when initialization is triggered using PIR register, only those routines that automatically trigger on reset de-assertion have individual bypass capability. This means that DLL locking and/or impedance calibration may be bypassed any time by writing a '1' to the corresponding bypass register bit in the PIR register. Once a routine is bypassed, it is internally registered as completed and the corresponding done status register bit is set in the PGSR register.

It is up to the user to re-trigger or perform the bypassed routine at a later time before the PHY can be used. The PIR[INITBYP] register bit provides the option to bypass the whole initialization sequence.

## 13.8.3 MDLL and MSDLL Reset Requirements

Reset issued to the MDLL and MSDLL must always meet the following requirements:

- 1. Reset must always be asserted for a minimum of 50ns to ensure proper reset of the DLL.
- 2. On power-up, reset must be held for a minimum of 50ns after MVDD has been raised to its full value.
- 3. After reset has been asserted and then de-asserted, a number of clock cycles must pass for the DLL to achieve lock.
  - 4. The input clock to the DLL must be stable for a minimum of 50ns before DLL



reset is de-asserted.

The following additional requirements apply when transitioning to/from bypass mode:

- 1. There must be at least 50ns between reset de-assertion and DLL bypass mode entry.
  - 2. The DLL bypass pin must be asserted for at least 1000ns.
- 3. Reset must always be issued after the DLL mode has changed from bypass to normal mode.
- 4. A minimum of 100ns is required between bypass de-assertion and reset assertion.
- 5. Reset must be issued whenever DLL control/trim/option input bits are modified, with the exception of:
  - a. Analog/digital test controls
  - b. Slave DLL phase trim (if applicable).



Fig. 13-15DLL reset requirements

#### 13.8.4 Data Training

## **Built-in DQS Gate Training**

The PHYCTL has a built-in DQS gate training routine that may be triggered by software or memory controller using the PIR register.

DQS gate training returns a number of status, including the done and error status. There are two types of errors. The first type is when no valid window was found for the byte. This is indicated by DTERR register bit in DXnGSR and PGSR registers. This is usually an indication of bad configuration. The second type is when some passing configurations were found but these were interspersed by failures. This is not expected in a working system. A typical window is signified by consecutive passes followed by consecutive failures, e.g. FPPPPF and not FPPFPPF. This type of error is called an intermittent error and is indicated by the DTIERR register bit in DXnGSR and PGSR registers. Provided for debug purpose is the status of how many passing configurations were found for each byte on each rank. This is indicated by DTPASS field in the DXnGSR register.

#### **Software DOS Gate Training**

DQS gate training may also be executed in software using the controller and/or the PUB DCU. Figure 13-16 shows the DQS gate training software algorithm. This is followed by a description of the main phases of the training.



Fig. 13-16DLL reset requirements

The software DQS gate training phases are as follows:

- 1. Disable drift compensation by writing '0' to PGCR.DFTCMP register.
- 2. Start with rank 0, i.e. rank 0 is selected for training.
- 3. Execute a minimum of two writes to the SDRAM. Any type of data and any SDRAM address can be used for DQS gate training. It is however not recommended to use data that is all zeroes since this may mask read data comparison. The data mask must be set to 0 to enable writing of all bytes. The number of writes must be chosen such that it results in a minimum of eight data beats at the SDRAM. This means at least two write commands when using SDRAM burst length of 4.
- 4. Start with byte 0 (i.e. byte 0 is selected for training).
- 5. Disable all the other bytes except the byte that has been selected for training. Bytes are enabled/disabled by writing 1/0 to DXnDGCR.DXEN.
- Start with the selected rank byte DQS gating system latency (DXnDQSTR.RnDGSL) of 0.
- Start with the selected rank byte DQS gating phase select



(DXnDQSTR.RnDGPS) of 0.

- 8. Write the selected DQS gating configurations (RnDGSL and RnDGPS) to DXnDQSTR register of the selected byte, making sure the fields for the unselected ranks remain unchanged.
- 9. Execute reads from the SDRAM locations previously written. The number of reads must be equal to the number of writes used in Step 3. Compare the read data with the expected (written) data and log the pass/fail status as a sequence or history of flags for each trained RnDGSL/RnDGPS configuration (e.g. FFPPPFF). A fail is either when there is a data miscompare or when fewer data than expected is returned. Note that a controller that is designed to always wait for the correct number of read data may need a time-out in case the trained configuration results in fewer data than expected. This is not as issue when using the PUB DCU because it does not wait for the expected number of reads; rather the read count status will indicate if fewer reads were returned.
- 10. Once the read data has been compared and the pass/fail status logged, issue an ITM soft reset to clear the status of the read data logic in the PHY. This is important because the ITM read data FIFO pointers may be in the wrong state at the end of training an RnDGSL/RnDGPS configuration that resulted in wrong DOS gating window.
- 11. If two consecutive fails and some passes exist, then this is the end of the training for this rank byte. In this case, do the following:
- Select the middle of the passes and write the values to the corresponding fields of DXnDQSTR register, making sure the fields for the unselected ranks remain unchanged
- If this is not the last byte, then select the next byte and go to Step 5
- If this is the last byte but not the last rank, then select the next rank and go to Step 3
- If this is the last byte and the last rank, then go to Step 12 to do final clean-up before the end of the DQS gate training.
- If the condition of two consecutive fails and some passes does not exist, then this signals that more RnDGSL/RnDGPS configurations need to be trained for this rank byte. If this is the case, do the following:
  - if RnDGPS is less than 3, then increment RnDGPS and go to Step 8
  - ■if RnDGPS is equal to 3 but RnDGSL is less than 7, then increment RnDGSL and go to Step 7
  - ■if RnDGPS is equal to 3 and RnDGSL is equal to 7, then log an error because this is a signal that something in the system is very wrong such that no passing configuration is possible for this rank byte. With such an error condition, you can either terminate the whole training to investigate the system or you can go to train the next byte.
- 12. Once the training of all ranks and all bytes is finished, issue one or more dummy reads to the same SDRAM locations. This will flush out the DQS drift compensation logic in the PHY and therefore avoid reporting any false drift events caused by previous DQS gating settings.
- 13. Once the dummy reads have completed, re-enable drift compensation by writing 1 to PGCR.DFTCMP register. This is the end of DQS gate training. Regular memory operations can now commence.

#### 13.8.5 Impedance Calibration

The impedance calibration circuit, which controls the impedance values for ODT and driver output impedance, consists of the following components:

- ♦ ZQ calibration cell PZQ
- ♦ External RZQ precision resistor
- ♦ Impedance control logic zctrl



- VREF cell (for code encoding and level shifting)
- Functional I/O cells

The connectivity of these components is shown as follow figure:



Fig. 13-17Impedance Calibration Circuit

A single calibration cell (PZQ) is used for the interface. The user connects the PZQ pin through an external 240ohm±1% resistor to ground. One or multiple VREF cells exist in the interface, depending on the total data width of the interface. The ZCTRL bus from the impedance control logic is connected to all VREF cells in the interface. It is not permitted to have a VREF cell in the interface that is not connected to the impedance control logic.

The impedance control logic sends an impedance code through the ZCTRL bus to the VREF cells. The VREF cells encodes this data, level shifts it to the VDDO power domain, and sends it to both the functional I/O cells and the PZQ cell through the ZIOH bus embedded within the SSTL cells. The PZQ cell also receives the desired divide ratios from the Memory Controller or the user logic. The PZQ cell compares the impedance control code received from the PVREF cell with the external resistor, taking into account the selected divide ratio. The PZQ cell then sends ZCOMP back to the impedance control logic to relay information about impedance matching. The impedance control logic then sends a new impedance code to the PVREF cells. This results in a closed-loop system.

The four impedance elements are calibrated sequentially:

- Pull-up termination impedance
- Pull-down termination impedance
- Pull-up output impedance
- Pull-down output impedance

The ZPROG bus is used to signal which element is being calibrated. The state machine is implemented on the Impedance Controller RTL block.

The impedance control logic connects to the Memory Controller or customer logic to allow full controllability and observability of the loop operation.

The impedance control loop operates with a low bandwidth as compared to the memory system, thus the impedance control logic contains a clock divider to permit operation at a reduced clock frequency.

There are three basic modes of operation:

- Direct Calibration -uses ZPROG settings.
- Override Setting uses ctrl ovrd data settings.
- Custom Calibration extends calibration beyond the values available on **ZPROG**



#### **Direct Calibration**

In this mode, the user is setting independently the value for ODT (ZPROG[7:4]) and Output Impedance (ZPROG[3:0]) and runs the calibration sequence:

- 1. Output impedance pulldown
- 2. Output impedance pull-up
- 3. On-Die termination (ODT) pull-down
- 4. ODT pull-up

#### **Override Setting**

In this mode, the user is not using the calibration loop, and instead directly controls the impedance control using zctrl\_ovrd\_data[19:0] bus, which is parsed in four nibbles that independently control driver pull-down/up and ODT pull-down/up impedance in 31 steps.

For example, assuming one step is associated to current I and the calibration voltage is VREF, the programmed impedance for index N is:

$$ZPROG = K * VREF/(N * I)$$

K is correction factor, which is approximately equal to 1. Based on the formula, it can be concluded that if index N is increased, then the impedance is decreased.

#### **Custom Calibration**

This mode is a two-step procedure combining the previous two modes.

- 1. The user provides a Direct Calibration using a convenient value and records the Impedance control results from status register.
- 2. The user applies the correction factor that provides the custom impedance. The following example assumes that it is required to program Driver Output Impedance to 18 ohms.
- 1. The user performs a Direct Calibration for driver Zo=36 ohms. For example, assume the result shows that Driver pull-up index is 12, and Driver pull-down index is 13.
- 2. Calculate and apply the Override Data for 18 ohm impedance adjustment as follows:

```
(<cal value>/<reg value>) * <cal index>
Driver pull-down (36/18) * 13 = 26
                 (36/18) * 12 = 24
Driver pull-up
```

## 13.8.6 Retention Functional

The purpose of the retention function is to retain a known state on the signals to the SDRAMs while the system is placed in a low power mode, specifically when the core VDD supply is powered down. The general concept is that an external input signal (RET\_EN) is driven low to put the SSTL I/O cells into retention mode shortly before the core VDD supply is powered down. The user must set the SSTL I/O outputs in the state required during power down before asserting RET EN. This ensures that the output state of all SSTL I/Os are held static in the desired state while core VDD is power down. After core VDD is restored, the user must re-initialize the core logic to a known state before de-asserting the RET EN signal.

Following figure provides the I/O cell arrangement with retention.





Fig. 13-18I/O cell arrangement with retention

IOs between two ISO is a VDDQ island, they will maintain power on when other IOs are powered down by RET\_EN active.

Following figure provides a sequence of events to enter and exit retention.



Fig. 13-19Sequence of Events to Enter and Exit Retention

#### **CKE Retention Mode**

An alternative CKE retention mode is supported. This scheme works by placing the SDRAMs into self-refresh mode and then driving the CKE signal low. Core VDD and VDDQ can then both be powered down except for a small VDDQ island supplying the CKE output cell. Two of the special 5um spacer cells ISO are used to break the VDDQ rail in order to create a separate CKE VDDQ island, which is kept powered while core VDD and the main VDDQ are powered down.

The sequence of events is as follows:

- 1. Enter self-refresh mode using the Self-Refresh Command
- 2. Set CKE low
- 3. Stop CK/CKB
- 4. Assert RET\_EN (low)
- 5. Power-Off
- 6. Power-On



- 7. After reset is released, execute initialization
- 8. De-assert RET\_EN (high)
- 9. Start CK/CKB
- 10. Set CKE high
- 11. Exit self-refresh mode

#### 13.8.7 Low Power Operation

Low power state can be entered/exited via following ways:

- Software control of PCTL State machine (highest priority)
- Hardware Low Power Interface (middle priority)
- Auto Self Refresh feature (lowest priority)

Note the priority of requests from Access to Low\_power is highlighted above. The STAT.lp trig register field reports which of the 3 requests caused the entry to Low power state.

#### **Software control of PCTL State**

The application can request via software to enter the memories into Self Refresh state by issuing the SLEEP command by programming SCTL.PCTL responds to the software request by moving into the Low power operational state and issuing the SRE command to the memories. Note that the Low power state can only be reached from the Access state.

In a similar fashion, the application requests to exit the memories from Self Refresh by issuing a WAKEUP command by programming SCTL.. PCTL responds to the WAKEUP command issuing SRX and restoring normal NIF address channel operation.

#### **Hardware Low Power Interface**

The hardware low power interface can also be used to enter/exit Self Refresh. The functionality is enabled by setting SCFG.hw\_low\_power\_en=1. Once that bit is set, the input c sysreg has the ability to trigger entry into the

Low Power configuration state just like the software methodology (SCTL.state\_cmd=SLEEP). A hardware Low Power entry trigger will be ignored/denied if the input c\_active\_in=1 or n\_avalid=1. It may be accepted if c\_active\_in=0 and n\_avalid=0, depending on the current state of the PCTL. When SCFG.hw\_low\_power\_en=1, the outputs c\_sysack and c\_active provide feedback as required by the AXI low power interface specification (this interface's operation is defined by the AXI specification). acknowledges the request to go into the Low\_power state, and c\_active indicates when the PCTL is actually in the Low\_power state.

The c\_active output could also be used by an external Low Power controller to decide when to request a transistion to low power. When MCFG1.hw idle > 0, c\_active = 1'b0 indicates that the NIF has been idle for at least MCFG1.hw\_idle \* 32 \* n clk cycles while in the Access state.

When in low power the c\_active output can used by an external Low Power controller to trigger a low power exit. c\_active will be driven high when either c\_active\_in or n\_avalid are high. The path from c\_active\_in and n\_valid to c\_active is asynhronous so even if the clocks have been removed c\_active will assert. The Low Power controller should re-enable the clocks when c active is driven high while in the Low\_power state.

#### **Auto Clock Stop/Power Down/Self Refresh**

The Clock Stop and/or Power Down and/or Self Refresh sequence is automatically started by PCTL when the NIF address channel is idle for a number



of cycles, depending on the programmed value in MCFG.mddr\_lpddr2\_clkstop\_idle and MCFG.pd\_idle and MCFG1.sr\_idle. Following table outlines the effect of these settings in conjunction with NIF being idle.

| mddr_lpddr2_<br>clkstop_idle | pd_idle | sr_idle | Memory modes                                             | Memory Type         |
|------------------------------|---------|---------|----------------------------------------------------------|---------------------|
| 0                            | 0       | 0       | none                                                     | All                 |
| >0                           | 0       | 0       | Clock Stop                                               | mDDR/LPDDR2<br>only |
| 0                            | >0      | 0       | Power Down                                               | All                 |
| >0                           | >0      | 0       | Clock Stop -> Power<br>Down <sup>1</sup>                 | mDDR/LPDDR2<br>only |
| 0                            | 0       | >0      | Self Refresh                                             | All                 |
| >0                           | 0       | >0      | Clock Stop -> Self<br>Refresh <sup>2</sup>               | mDDR/LPDDR2<br>only |
| 0                            | >0      | >0      | Power Down -> Self<br>Refresh <sup>3</sup>               | All                 |
| >0                           | >0      | >0      | Clock Stop -> Power<br>Down -> Self Refresh <sup>4</sup> | mDDR/LPDDR2<br>only |

#### Note:

- 1. Clock Stop is entered if NIF is idle for mddr\_lpddr2\_clkstop\_idle. Following on from that, if NIF continues to be idle fora further pd\_idle cycles, Clock Stop is exited and Power
- 2. Clock Stop is entered if NIF is idle for mddr\_lpddr2\_clkstop\_idle. Following on from that, if NIF continues to be idle for a further sr\_idle\*32 cycles, Clock Stop is exited and Self Refresh is entered.
- 3. Power Down is entered if NIF is idle for pd\_idle. Following on from that, if NIF continues to be idle for a further sr\_idle\*32 cycles, Power Down is exited and Self Refresh is entered.
- 4. Clock Stop is entered if NIF is idle for mddr\_lpddr2\_clkstop\_idle. Following on from that, if NIF continues to be idle for a further pd\_idle cycles, Clock Stop is exited and Power Down is entered. Following on from that, if NIF continues to be idle for a further sr\_idle\*32 cycles, Power Down is exited and Self Refresh is entered.

## Removing PCTL's n\_clk

LPDDR2 and DDR3, the relationship between SRE/SRX and stopping/starting the memory clock (CK)are formalized and are accounted for automatically by PCTL. With LPDDR2 and DDR3, CK should onlybe stopped after PCTL has reached the Low\_power state. The current operational state can be verified byreading STAT.ctl stat. The CK must be started and stable before the Software or Hardware Low Power Interface attempts to take the memory out of Self Refresh.

PCTL's n\_clk can be safely removed when PCTL is in Low Power state. The sequences outlined in Table P2-17 or Table P2-18 should be followed for safe operation:

| Step | Application                                                                                                                                  | PCTL                                                                          |
|------|----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|
| 1    | Write SLEEP to SCTL.state_cmd and poll STAT.ctl_stat = LOW_POWER.                                                                            | Tells PCTL to move memories into Self Refresh and waits until this completes. |
| 2    | Write TREFI=0. Also, write DFITCRLUPDI=0 and DFIREFMSKI=0, if they are not already 0.                                                        | Stops any MC-driven DFI updates occurring internally with PCTL                |
| 3    | Wait a minimum interval which is equivalent to the PCTL's Refresh Interval (previous value of TREFI*TOGCNT100N*internal timers clock period; | Ensures any already scheduled PHY/PVT updates have completed successfully.    |
| 4    | Stop toggling n_clk to PCTL.                                                                                                                 | n_clk logic inside PCTL is stopped.                                           |
| end  |                                                                                                                                              |                                                                               |



| Step | Application                                                                                                                                        | PCTL                                                                  |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|
| 1    | Drive c_active_in low                                                                                                                              | Confirms that system external to PCTL can accept a Low- power request |
| 2    | Drive c_sysreq low                                                                                                                                 | System Low-power request                                              |
| 3    | Wait for PCTL to drive c_sysack low                                                                                                                | PCTL Low-power request acknowledgement                                |
| 4    | Check value of c_active when Step 3 occurs.  - if c_active=1, request denied. Cannot remove n_clk.  Go to END.  - if c_active=0, request accepted. | PCTL low-power request status response                                |
| 5    | Stop toggling n_clk to PCTL                                                                                                                        | n_clk logic inside PCTL is stopped                                    |
| end  |                                                                                                                                                    |                                                                       |

### **Deep Power-Down**

Compared with DDR2/DDR3, mDDR and LPDDR2 has an additional low power mode (Deep Power Down).:

- ❖ Software-driven Deep Power Down Entry on reception of DPDE from the application, PCTL drives CKE low for TDPD.t\_dpd. After TDPD, MCMD.start cmd will be cleared to 1'b0. The following are recommended values for TDPD:
  - ♦ mDDR: TDPD=0
  - ◆ LPDDR2: dependent on if the system wants to immediately power off the PCTL after Deep Power down is entered::
    - ♦ If PCTL not Powered off: TDPD=500µs
    - ♦ Else if PCTL is Poweredoff: TDPD=0 up to higher level system to meet tDPD requirement.
  - To Exit Deep Power Mode, full initialization of the memories must be performed.

#### 13.8.8 PHY Power Down

The PHYCTL includes several registers for putting certain components of the PHY in power down mode. The PHTCTL also supports DFI-initiated power-down of its components using the DFI low-power protocol.

Several components of the PHY can be powered down using PHYCTL registers. There are separate power-down register bits for the address/command lane and for each byte lane. Also there are separate controls for powering down the I/Os versus powering down the DLL. Following table describes the registers that are used to power down various components of the PHY.

| Register<br>Name | Bit Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PIR              | DLLBYP    | Bypasses, and hence disables or powers down all PHY DLLs.                                                                                                                                                                                                                                                                                                                                                                                                       |
| ACDLLCR          | DLLDIS    | Disables (powers down) the address/command lane DLL                                                                                                                                                                                                                                                                                                                                                                                                             |
| ACIOCR           | *PDD      | Powers down the output drivers for address/command lane signal I/Os. Different groups of signals have dedicated driver power-down control registers to allow finer selection of signals to power down, especially that some signals, such as CKE and RST#, are required to remain powered up when the SDRAM is in self-refresh mode.  Each rank CS# signal and each CK/CK# pair has dedicated driver power down control registers, with the other rank-specific |



| Γ        |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |        | signals (CKE and ODT) of each rank being controlled by separate power down control registers in a separate PUB register (DSGCR). There is also a dedicated driver power down control register for SDRAM reset signal. However, the rest of the signals going to the SDRAM (address, bank address, RAS#, CAS#, WE#, and PAR_IN) share a common driver power down register just dedicated for this group. The LPDDR TPD signal has a dedicated output driver power down control register in a separate PUB register (DSGCR).                                                                                                                                                                                        |
| ACIOCR   | *PDR   | Powers down the input receivers for address/command lane signal I/Os. Different groups of signals have dedicated receiver power-down control registers to allow finer selection of signals to power down. Each rank and each CK/CK# pair has dedicated receiver power down control register, with all rank-specific signals (CKE, ODT, and CS#) of each rank sharing a common, but rank-specific, receiver power down control register. There is also a dedicated receiver power down control register for SDRAM reset pins. However, the rest of the signals going to the SDRAM (address, bank address, RAS#, CAS#, WE#, PAR_IN, TPD) share a common receiver power down register just dedicated for this group. |
| DXCCR    | DXPDD  | Powers down the output drivers for DQ, DM, and DQS/DQS# signal I/Os of all byte lanes. This is a convenient way of powering down the output drivers of all byte lane I/Os with just a single register write. In addition to this, each byte has a dedicated output driver power-down register control to allow only selected bytes to be powered down.                                                                                                                                                                                                                                                                                                                                                            |
| DXCCR    | DXPDR  | Powers down the input receivers for DQ, DM, and DQS/DQS# signal I/Os of all byte lanes. It also powers down the PDQSR cells of all bytes. This is a convenient way of powering down the input receivers of all byte lane I/Os with just a single register write. In addition to this, each byte has a dedicated input receiver power-down register control to allow only selected bytes to be powered down.                                                                                                                                                                                                                                                                                                       |
| DSGCR    | CKEPDD | Powers down the output drivers for CKE I/Os. Each rank CKE has a dedicated driver power down control register to allow finer control of CKE I/O driver power-down, especially that the CKE I/O driver of an SDRAM that is in self refresh is required to remain powered up.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| DSGCR    | ODTPDD | Powers down the output drivers for ODT I/Os. Each rank ODT has a dedicated driver power down control register to allow finer control of ODT I/O driver power-down, especially that the ODT I/O driver of an SDRAM that is in self refresh or power down mode may be required in certain DDR modes to remain powered up.                                                                                                                                                                                                                                                                                                                                                                                           |
| DSGCR    | TPDPD  | Powers down the output driver for the optional LPDDR TPD signal I/O.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| DSGCR    | NL2PD  | Powers down the output driver and the input receiver on the I/O for non-LPDDR2 signals (ODT, RAS#, CAS#, WE#, and BA). This may be used when a chip that is designed for both LPDDR2 and other DDR modes is being used in LPDDR2 mode, in which case one may want to power down the unused I/Os. This power down control register is in addition to (ORed with) the individual ACIOCR power down control registers for these signals.                                                                                                                                                                                                                                                                             |
| ZQnCR0   | ZQPD   | Powers down the PZQ cell. Each PZQ has a dedicated power down control register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| DXnDLLCR | DLLDIS | Disables (powers down) the byte lane DLL. Each byte lane has a dedicated DLL power down control register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| DXnGCR   | DXPDD  | Powers down the output drivers for DQ, DM, and DQS/DQS# signal I/Os of the byte lane. Each byte lane has a dedicated output driver power down control register, in conjunction with the global output driver power down control register DXCCR.DXPDD.                                                                                                                                                                                                                                                                                                                                                                                                                                                             |



| DXnGCR | DXPDR   | Powers down the input receivers for DQ, DM, and DQS/DQS# signal I/Os of the byte lane. Each byte lane has a dedicated input receiver power down control register, in conjunction with the global input receiver power down control register DXCCR.DXPDR |
|--------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DXnGCR | DQSRPD  | Powers down the PDQSR cells of the byte lane. Each byte lane has a dedicated PDQSR power down control register, in conjunction with the global PDQSR power down control register DXCCR.DXPDR.                                                           |
| PGCR   | PDDISDX | Selects whether the I/Os and DLL of a disabled byte should automatically be powered down by the PUB. A byte can be disabled by writing a '0' to the DXnGCR.DXEN register or by using the DFI data byte disable (dfi_data_byte_disable) signal.          |
| DSGCR  | LPIOPD  | Specifies whether the PHY should respond to the controller-initiated DFI low power opportunity request and power down the I/Os of the PHY.                                                                                                              |
| DSGCR  | LPDLLPD | Specifies whether the PHY should respond to the controller-initiated DFI low power opportunity request and power down the DLL of the PHY if the requested wakeup time is greater than 2048 clock cycles                                                 |

#### **DFI-Initiated Power-Down**

There are two ways how the controller can initiate PHY power down through the DFI interface. The first method is when the controller asserts the DFI data byte disable (dfi\_data\_byte\_disable) signal during initialization when the DFI initialization start (dfi\_init\_start) signal is high. In this state, the PHY will power down the DLL and I/Os of the selected bytes if it is configured through DSGCR.BDISEN to respond to DFI data byte disable and if disabled bytes are configured through PGCR. PDDISDX to be powered down. The DFI data byte disable feature is normally used as a static configuration to disable bytes that are not being used.

The controller can also initiate PHY power down by using the DFI low power control interface. This is a dynamic low power request-acknowledge protocol that the controller may use to put the PHY into low power mode when it is not being used for a prolonged time. The PHY will acknowledge a low power request from the controller and power down I/Os and DLLs if it is configured to do so through DSGCR.LPIOPD and DSGCR.LPDLLPD. If the low power wakeup time requested by the controller is less than 2048 clock cycles, then only the I/Os will be powered down. Otherwise if the wakeup time is equal to or more than 2048 cycles, then the DLLs and the I/Os are all powered down. If the DLLs are powered down, then on low power wakeup the PUB will soft reset the DLLs and wait for them to lock before acknowledging the low power wakeup request to the controller.

## 13.8.9 Dynamic ODT for I/Os

By default the DFI turns on the ODT for the PHY I/Os for DQ/DQS# only when there is read data coming back. This is called dynamic ODT control and is used to reduce power consumed by the termination resistors. The DFI uses the timing of the DOS gating to accurately place the PHY I/O ODT enable signal around the read data. Typically, the DFI turns on the byte ODT enable signal 2 clocks before the pre-amble and turns it off one clock after the post-amble. This guarantees correct setup and hold on the I/Os.

The PHY ODT signal does not go through the ITMs and therefore has to fan out to the DQ/DQS from RTL logic in the PHYCTL. This may result in different timing on these signals depending on the routing. For this

reason various programmable features are provided on the ODT control signals to help mitigate some of the timing issues that may result from different



implementations. These are described in the DXnGCR register. In summary, both the starting position and the width of the enable signal can be adjusted relative to the default position and lengths.



## **Chapter 14 SMC(Static Memory Controller)**

### 14.1 Overview

The SMC is an Advanced Microcontroller Bus Architecture (AMBA) compliant System-on-Chip peripheral. It consists of high-performance, area-optimized SRAM memory controllers with on-chip bus interfaces that conform to the AMBA Advanced extensible Interface (AXI) protocol.

The SRAM memory interface type is defined as supportingasynchronous SRAMand NOR flash.

The SMC provides the following features:

- Support asynchronous SRAM and Nor Flash
- Configurable SRAM memory data widths of 8-bit or 16-bit
- AXI data width of 32-bit
- Up to two chip selects, each is up to 16MBbytes
- Programmable cycle timings per chip select.
- Support shared and separated data/address bus
- Support for a remap signal

## 14.2 Block Diagram



Fig. 14-1 SMC architecture diagram

## 14.3 Function Description

#### 14.3.1 APB slave interface

The APB interface is a fully-compliant APB slave. The SMC has 4KB of memory allocated to it. The APB slave interface accesses the SMC registers to program the memory system configuration parameters and to provide status information.

The APB interface is clocked by the same clock as the AXI domain clock, aclk, but has a clock enable so that it can be slowed down to execute at an integer divisor of aclk.



#### 14.3.2 Format

The format block receives memory accesses from the AXI slave interface and the memory manager. Requests from AR and AW channels are arbitrated on a round-robin basis. Requests from the manager have the highest priority. The format block also maps AXI transfers onto appropriate memory transfers and passes these to the memory interface through the command FIFO.

#### **Hazard handling**

The following types of hazard exist:

- Read after read (RAR)
- Write after write (WAW)
- Read after write (RAW)
- Write after read (WAR).

The AXI specification defines that RAW and WAR ordering is determined by the master, whereas RAR and WAW ordering is enforced by the slave. If an AXI master requires ordering between reads and writes to certain memory locations, it must wait for a write response before issuing a read from a location it has written to (RAW). It must also wait for read data before issuing a write to a location it has read from (WAR). The SMC ensures the ordering of read transfers from a single master is maintained (RAR), and additionally, that the ordering of write transfers from a single master is maintained (WAW).

RAR and WAW hazards only occur in configurations that have two memory interfaces. But we only use one memory interface, so we can ignore them.

### **SRAM** memory accesses

A.Memory address shifting

To produce the address presented to the memory device, the AXI address is aligned to the memory width. This is done because the AXI address is a byte-aligned address, whereas the memory address is a memory-width-aligned address.

During initial configuration of a memory device, the memory mode register can be accessed with a sequence of transfers to specific addresses. You must take into consideration the shifting performance by the SMC when accessing memory mode registers.

### B.Memory burst alignment

The SMC provides a programmable option for controlling the formatting of memory transfers with respect to memory burst boundaries, through the burst\_align bit of the opmode registers.

When set, the burst align bit causes memory bursts to be aligned to a memory burst boundary. This setting is intended for use with memories that use the concept of internal pages. This can be an asynchronous page mode memory, or a synchronous PSRAM. If an AXI burst crosses a memory burst boundary, the SMC partitions the AXI transfer into multiple memory bursts, terminating a memory transfer at the burst boundary. Ensure the page size is an integer multiple of the burst length, to avoid a memory burst crossing a page boundary.

When the burst\_align bit is not set, the SMC ignores the memory burst boundary when mapping AXI commands onto memory commands. This setting is intended for use with devices such as NOR flash. These devices have no concept of pages.

#### C.Memory burst length

The SMC enables you to program the memory burst length on an individual chip basis, from length 1 to 32 beats, or a continuous burst. The length of



memory bursts are however automatically limited by the size of the read or write data FIFOs.

For read transfers, the maximum memory burst length on the memory interface is the depth of the read data FIFO. For writes, the maximum burst length is dependent on:

- the beat size of the AXI transfer, asize
- the memory data bus width, mw
- the depth of the write data FIFO depth, wfifo depth.

The formula to determine the maximum memory write burst length is: Memory write burst length =  $((1 < asize) \times wfifo depth) / (1 < mw)$ 

## 14.3.3 Memory manager

The memory manager tracks and controls the current state of the SMC aclk domain FSM. The block is responsible for Updating register values that are used in the mclk domain, and controlling direct commands issued to memory.

## **Chip configuration registers**

The SMC provides a mechanism for synchronizing the switching of operating modes with that of the memory device.

The SMC SET CYCLES Register and SMC SET OPMODE Register act as holding registers for new operating parameters until the SMC detects the memory device has switched modes. This enables a memory device to be made to change its operating mode while still being accessed.

The manager register bank consists of all the timing parameters chip<x>\_cycles, and access modes chip<x>\_opmode. These are required for the SMC to correctly time any type of access to a supported memory type.

The APB registers SMC\_SET\_CYCLES and SMC\_SET\_OPMODE act as holding registers, the configuration registers within the manager are only updated if either:

- the Direct Command Register indicates only a register update is taking
- the SMC\_DIRECT\_CMD Register indicates a mode register access either using the SMC\_DIRECT\_CMD Register or using the AXI interface and the command has completed

#### **Direct commands**

The SMC enables code to be executed from the memory while simultaneously, from the software perspective, moving the same chip to a different operating mode. This is achieved by synchronizing the update of the chip configuration registers from the holding registers with the dispatch of the memory configuration register write.

The SMC provides software mechanisms for simultaneously updating the controller and memory configuration registers.

For memories that require a sequence of read and write commands, for example, most NOR flash devices use the AXI interface, with the write data bus used to indicate when the last transfer has completed and when it is safe for the SMC to update the chip configuration registers.



Fig. 14-2Software Mechanism of Direct Commands in SMC

new mode of operation.

In addition, the APB configuration registers can be programmed for the next memory device.

End

### 14.3.4 Memory interface

The SMC supports SRAM memory interface type, it is composed of command, read data, and write data FIFOs plus a control FSM. The memory interface FSM is specific to SRAM.

The memory interface issues commands to the memory from the command FIFO, and controls the cycle timings of these commands. It only issues a new command after the previous command is complete and any turn-around times have been met. It only issues a read command when there is space for all the impending data in the read data FIFO.

The SMC does not perform WRAP transfers on the memory interface. For memory devices that only operate in WRAP mode, you must program the SMC\_SET\_OPMODE Register to align transfers to a memory burst boundary. If the SMC is programmed to perform transfers that cross a memory boundary, then you must program the memory device to operate in INCR mode.



#### 14.3.5 Pad interface

The pad interface module provides a registered I/O interface for data and control signals. It also contains interrupt generation logic.

### 14.3.6 SRAM interface timing diagrams

All address, control, and write data outputs of the SMC are registered on the rising edge of mclkn, equivalent to the falling edge of mclk, for asynchronous accesses.

Read data output by the memory device is also registered on the rising edge of mclkn, equivalent to the falling edge of mclk, for asynchronous reads. For asynchronous accesses, the data is then pushed onto the read data FIFO to be returned by the AXI interface.

## Asynchronous read

Following figure show a single asynchronous read transfer with an initial access time, tRC, of 3 cycles and an output enable assertion delay, tCEOE, of one cycle.



Fig. 14-3 SMC asynchronous read timing

#### Asynchronous read in multiplexed mode

Following figure show a single asynchronous read transfer in multiplexed SRAM mode, with tRC=7, and tCEOE=5.

In multiplexed mode, both address and data are output by the SMC on the data\_out bus. Read data is accepted on the data\_in bus. The address is still driven onto the address bus in multiplexed mode. This enables you to use the upper address bits for memories that require more address bits than data bits.



Fig. 14-4 SMC asynchronous read timing in multiplexed mode

#### **Asynchronous write**



Following figure show a single asynchronous write with a write cycle time tWC of four cycles and a we\_n assertion duration, tWP, of two cycles.

The timing parameter tWP controls the deassertion of we n. You can use it to vary the hold time of cs n, addr and data. This differs from the read case where the timing parameter tCEOE controls the delay in the assertion of oe\_n. Additionally, we n is always asserted one cycle after cs n to ensure the address bus is valid.



Fig. 14-5 SMC asynchronous write timing

## Asynchronous write in multiplexed mode

Following figure show a single asynchronous write in multiplexed mode when the we\_time bit is 0. tWC is seven cycles, tWP is four cycles, and the we\_time bit programs the assertion of we in to occur two clock cycles after cs in goes LOW.



Fig. 14-6 SMC asynchronous write timing in multiplexed mode 1

Following figure show a single asynchronous write in multiplexed mode when the we\_time bit is 1. tWC is seven cycles, tWP is four cycles, and the we\_time bit programs the assertion of we\_n to occur when cs\_n goes LOW



Fig. 14-7 SMC asynchronous write timing in multiplexed mode 2

#### Asynchronous page mode read

Following figure show a page read access, with an initial access time, tRC, of three cycles, an output enable assertion delay, tCEOE, of two cycles, and a page access time, tPC, of one cycle.



You enable Page mode in the SMC by setting the opmode Register for the relevant chip to asynchronous reads, and the burst length to the page size. Multiplexed mode page accesses are not supported.



Fig. 14-8 SMC page read timing

## 14.4 Register Description

This section describes the control/status registers of the design. 14.4.1 Registers Summary

| Name                     | Offset | Size | Reset Value | Description                                |
|--------------------------|--------|------|-------------|--------------------------------------------|
| SMC_MEMC_STATUS          | 0x0000 | W    | 0×00000000  | Memory Controller Status<br>Register       |
| SMC_MEMIF_CFG            | 0x0004 | W    | 0×00000000  | Memory Interface<br>Configuration Register |
| SMC_MEMC_CFG_SET         | 0x0008 | W    | 0x00000000  | Set Configuration Register                 |
| SMC_SMC_MEMC_CF<br>G_CLR | 0x000c | W    | 0×00000000  | Clear Configuration<br>Register            |
| SMC_DIRECT_CMD           | 0x0010 | W    | 0x00000000  | Direct Command Register                    |
| SMC_SET_CYCLES           | 0x0014 | W    | 0x00000000  | set_cycles Register                        |
| SMC_SET_OPMODE           | 0x0018 | W    | 0x00000000  | set_opmode Register                        |
| SMC_REFRESH_PERI<br>OD0  | 0x0020 | W    | 0x00000000  | refresh_period_0 Register                  |
| SMC_SRAM_CYCLES0         | 0x0100 | W    | 0x00000000  | sram_cycles Register for CS0               |
| SMC_OPMODE0              | 0x0104 | W    | 0x00000000  | opmode Register for CS0                    |
| SMC_SRAM_CYCLES1         | 0x0120 | W    | 0x00000000  | sram_cycles Register for CS1               |
| SMC_OPMODE1              | 0x0124 | W    | 0x0000000   | opmode Register for CS1                    |

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

## 14.4.2 Detail Register Description

### SMC\_MEMC\_STATUS

Address: Operational Base + offset (0x0000)

Memory Controller Status Register

| Bit  | Attr | Reset Value | Description                                                  |
|------|------|-------------|--------------------------------------------------------------|
| 31:6 | RO   | 0x0         | reserved                                                     |
| 5    | RO   | 111711      | raw_int_status0 Current raw interrupt status for interface 0 |
| 4    | RO   | 0x0         | reserved                                                     |



| Bit | Attr | <b>Reset Value</b> | Description                                   |
|-----|------|--------------------|-----------------------------------------------|
| 2   | RO   | 0x0                | int_status0                                   |
| 3   | KO   | UXU                | Current interrupt status for interface 0      |
| 2   | RO   | 0x0                | reserved                                      |
| 4   | RO   | 0x0                | int_en0                                       |
| 1   |      |                    | Status of memory interface 0 interrupt enable |
|     |      |                    | state                                         |
| 0   | RO   | DO 0.40            | Operating state of the SMC:                   |
| U   |      | O 0x0              | 0 = SMC is in the ready state                 |
|     |      |                    | 1 = SMC is in the low-power state.            |

## SMC\_MEMIF\_CFG

Address: Operational Base + offset (0x0004) Memory Interface Configuration Register

| Memory Interface Configuration |      | •           |                                                                                                                                                                                                      |
|--------------------------------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                            | Attr | Reset Value | Description                                                                                                                                                                                          |
| 31:18                          | RO   | 0x0         | reserved                                                                                                                                                                                             |
| 17:16                          | RO   | 0x0         | exclusive_monitors exclusive_monitor - Returns the number of exclusive access monitor resources that are implemented in the SMC. b00 = 0 monitors b01 = 1 monitor b10 = 2 monitors b11 = 4 monitors. |
| 15:7                           | RO   | 0x0         | reserved                                                                                                                                                                                             |
| 6                              | RO   | 0x0         | remap0 remap0 - Returns the value of the remap_0 input.                                                                                                                                              |
| 5:4                            | RO   | 0x0         | memory_width0 memory_width0 - Returns the maximum width of the SMC memory data bus for interface 0: b00 = 8 bits b01 = 16 bits b10 = 32 bits b11 = reserved.                                         |
| 3:2                            | RO   | 0x0         | memory_chips0 memory_chips0 - Returns the number of different chip selects that the memory interface 0 supports: b00 = 1 chip b01 = 2 chips b10 = 3 chips b11 = 4 chips.                             |
| 1:0                            | RO   | 0×0         | memory_type0 memory_type0 - Returns the memory interface 0 type: b00 = reserved b01 = SRAM non-multiplexed b10 = NAND b11 = SRAM multiplexed.                                                        |



## SMC\_MEMC\_CFG\_SET

Address: Operational Base + offset (0x0008)

Set Configuration Register

| Bit  | Attr | Reset Value | Description                                                                                                  |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------|
| 31:3 | RO   | 0x0         | reserved                                                                                                     |
| 2    | WO   | 0×0         | low_power_req<br>0 = No effect<br>1 = Request the SMC to enter low-power state<br>when it next becomes idle. |
| 1    | RO   | 0x0         | reserved                                                                                                     |
| 0    | WO   | 0x0         | <pre>int_enable0 0 = No effect 1 = Interrupt enable, memory interface 0.</pre>                               |

## SMC\_SMC\_MEMC\_CFG\_CLR

Address: Operational Base + offset (0x000c)

Clear Configuration Register

| Bit  | Attr | Reset Value | Description                                                                        |
|------|------|-------------|------------------------------------------------------------------------------------|
| 31:4 | RO   | 0x0         | reserved                                                                           |
| 3 V  | WO   | 0x0         | <pre>int_clr_0 0 = No effect 1 = Clear SMC Interrupt 0 (as an alternative to</pre> |
|      |      |             | an AXI read).                                                                      |
| 2    | WO   | 0x0         | low_power_exit 0 = No effect 1 = Request the SMC to exit low-power state.          |
| 1    | RO   | 0x0         | reserved                                                                           |
| 0    | wo   | 0x0         | <pre>int_disable0 0 = No effect 1 = Interrupt disable, memory interface 0.</pre>   |

## SMC\_DIRECT\_CMD

Address: Operational Base + offset (0x0010)

Direct Command Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:26 | RO   | 0x0         | reserved                                                                                                                                                                                   |
| 25:23 | wo   | 0x0         | chip_select Selects chip configuration register bank to update, and enables chip mode register access depending on cmd_type. The encoding is: b000-b011 = Chip selects 1-4 on interface 0. |
| 22:21 | wo   | 0×0         | cmd_type Selects the command type: b00 = UpdateRegs and AXI b01 = ModeReg b10 = UpdateRegs b11 = ModeReg and UpdateRegs                                                                    |



| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                        |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20   | wo   | 0x0         | set_cre Maps to the configuration register enable signal, cre, when a ModeReg command is issued. The encoding is: 0 = cre is LOW 1 = cre is HIGH when ModeReg write occurs.                                                                                                                                        |
| 19:0 | wo   | 0×00000     | addr When cmd_type = UpdateRegs and AXI then: bits [15:0] are used to match wdata[15:0] bits [19:16] are reserved. Write as zero. When cmd_type = ModeReg or ModeReg and UpdateRegs, these bits map to the external memory address bits [19:0]. When cmd_type = UpdateRegs, these bits are reserved. Write as zero |

## SMC\_SET\_CYCLES

Address: Operational Base + offset (0x0014)

set\_cycles Register

| Bit   | Attr | Reset Value | Description                                                                         |
|-------|------|-------------|-------------------------------------------------------------------------------------|
| 31:24 | RO   | 0x0         | reserved                                                                            |
| 23:20 | WO   | 0x0         | set_t6 Contains the value to be written towe_time bit of the sram_cycles Register.  |
| 19:17 | wo   | 0x0         | set_t5 Contains the value to be written tot_tr field of the sram_cycles Register.   |
| 16:14 | wo   | 0x0         | set_t4 Contains the value to be written tot_pc field of the sram_cycles Register.   |
| 13:11 | wo   | 0x0         | set_t3 Contains the value to be written to the t_wp field in sram_cycles Register.  |
| 10:8  | wo   | 0x0         | set_t2 Contains the value to be written tot_ceoe field of the sram_cycles Register. |
| 7:4   | WO   | 0x0         | set_t1 Contains the value to be written to the t_wc field in sram_cycles Register.  |
| 3:0   | WO   | 0x0         | set_t0 Contains the value to be written to the t_rc field in sram_cycles Register.  |

## SMC\_SET\_OPMODE

Address: Operational Base + offset (0x0018)

set\_opmode Register

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



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:13 | WO   | 0×0         | set_burst_align Contains the value to be written to the specific SRAM chip opmode Register burst_align field. When you configure the SMC to perform synchronous transfersa, these bits control if memory bursts are split on memory burst boundaries: b000 = bursts can cross any address boundary b001 = burst split on memory burst boundary, that is, 32 beats for continuous b010 = burst split on 64 beat boundary b011 = burst split on 128 beat boundary b100 = burst split on 256 beat boundary b101-b111 = reserved. |
| 12    | WO   | 0x0         | set_bls Contains the value to be written to the specific SRAM chip opmode Register byte lane strobe (bls) bit. This bit affects the assertion of the byte-lane strobe outputs.  0 = bls timing equals chip select timing. This is the default setting.  1 = bls timing equals we_n timing. This setting is used for eight memories that have no bls_n inputs. In this case, the bls_n output of the SMC is connected to the we_n memory input.                                                                                |
| 11    | wo   | 0x0         | set_adv Contains the value to be written to the specific SRAM chip opmode Register address valid (adv) bit. The memory uses the address advance signal adv_n when set.                                                                                                                                                                                                                                                                                                                                                        |
| 10    | WO   | 0×0         | set_baa Contains the value to be written to the specific SRAM chip opmode Register burst address advance (baa) bit. The memory uses the baa_n signal when set.                                                                                                                                                                                                                                                                                                                                                                |
| 9:7   | wo   | 0×0         | set_wr_bl Contains the value to be written to the specific SRAM chip opmode Register wr_bl field. Encodes the memory burst length: b000 = 1 beat b001 = 4 beats b010 = 8 beats b011 = 16 beats b100 = 32 beats b101 = continuous b110-b111 = reserved.                                                                                                                                                                                                                                                                        |
| 6     | WO   | 0x0         | set_wr_sync<br>Contains the value to be written to the specific<br>SRAM chip opmode Register wr_sync bit.<br>The memory writes are synchronous when set.                                                                                                                                                                                                                                                                                                                                                                      |



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                         |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:3 | wo   | 0x0         | set_rd_bl Contains the value to be written to the specific SRAM chip opmode Register rd_bl field. Encodes the memory burst length: b000 = 1 beat b001 = 4 beats b010 = 8 beats b011 = 16 beats b100 = 32 beats b101 = continuous b110-b111 = reserved.              |
| 2   | WO   | 0×0         | set_rd_sync Contains the value to be written to the specific SRAM chip opmode Register rd_sync bit. Memory in sync mode when set.                                                                                                                                   |
| 1:0 | wo   | 0x0         | set_mw Contains the value to be written to the specific chip opmode Register memory width (mw) field. Encodes the memory data bus width: b00 = 8 bits b01 = 16 bits b10 = 32 bits b11 = reserved. You can program this to the configured width, or half that width. |

## **SMC\_REFRESH\_PERIOD0**

Address: Operational Base + offset (0x0020)

refresh period 0 Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | RO   |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 31:4 | KU   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 3:0  | RW   | 0x0         | period Sets the number of consecutive memory bursts that are permitted, prior to the SMC deasserting chip select to enable the PSRAM to initiate a refresh cycle. The options are: b0000 = disables the insertion of idle cycles between consecutive bursts b0001 = an idle cycle occurs after each burst b0010 = an idle cycle occurs after 2 consecutive bursts b0011 = an idle cycle occurs after 3 consecutive bursts b0100 = an idle cycle occurs after 4 consecutive bursts . |
|      |      |             | b1111 = an idle cycle occurs after 15                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|      |      |             | consecutive bursts.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |



# **SMC\_SRAM\_CYCLES0**

Address: Operational Base + offset (0x0100)

sram\_cycles Register for CS0

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                   |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:21 | RO   | 0x0         | reserved                                                                                                                                                                                      |
| 20    | RO   | 0x0         | we_time For asynchronous multiplexed transfers this bit controls when the SMC asserts we_n: 0 = SMC asserts we_n two mclk cycles after asserting cs_n. 1 = SMC asserts we_n and cs_n together |
| 19:17 | RO   | 0x0         | t_tr Turnaround time for SRAM chip configurations. Minimum permitted value = 1.                                                                                                               |
| 16:14 | RO   | 0x0         | t_pc Page cycle time for SRAM chip configurations. Minimum permitted value = 1                                                                                                                |
| 13:11 | RO   | 0x0         | t_wp<br>we_n assertion delay.<br>Minimum permitted value = 1.                                                                                                                                 |
| 10:8  | RO   | 0×0         | t_ceoe oe_n assertion delay for SRAM chip configurations. Minimum permitted value = 1.                                                                                                        |
| 7:4   | RO   | 0x0         | t_wc<br>Write cycle time.<br>Minimum permitted value = 2.                                                                                                                                     |
| 3:0   | RO   | 0x0         | t_rc Read cycle time. Minimum permitted value = 2.                                                                                                                                            |

### SMC\_OPMODE0

Address: Operational Base + offset (0x0104)

opmode Register for CS0

| Bit   | Attr | Reset Value | Description                                                                                                                                                                               |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | RO   | 0x00        | address_match Returns the value of this tie-off. This is the comparison value for address bits [31:24] to determine the chip that is selected.                                            |
| 23:16 | RO   | 0x00        | address_mask Returns the value of this tie-off. This is the mask for address bits[31:24] to determine the chip that must be selected. A logic 1 indicates the bit is used for comparison. |



| Bit   | Attr | Reset Value                                                                                                                                                                                                                                                                                                                                                                                                       | Description                                                                                                                                                                                                                                                                                                                     |  |  |
|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 15:13 | RO   | burst_align When you configure the SMC to perform synchronous transfersa, these bits contro memory bursts are split on memory burst boundaries:  b000 = bursts can cross any address bound b001 = burst split on memory burst bound that is, 32 beats for continuous b010 = burst split on 64 beat boundary b011 = burst split on 128 beat boundary b100 = burst split on 256 beat boundary b101-b111 = reserved. |                                                                                                                                                                                                                                                                                                                                 |  |  |
| 12    | RO   | 0x0                                                                                                                                                                                                                                                                                                                                                                                                               | bls This bit affects the assertion of the byte-lane strobe outputs: 0 = bls timing equals chip select timing. This is the default setting. 1 = bls timing equals we_n timing. This setting is used for 8-bit memories that have no bls inputs. In this case, the bls_n output of the SMC is connected to the we_n memory input. |  |  |
| 11    | RO   | 0x0                                                                                                                                                                                                                                                                                                                                                                                                               | adv The memory uses the address advance signal, adv_n, when set.                                                                                                                                                                                                                                                                |  |  |
| 10    | RO   | 0×0                                                                                                                                                                                                                                                                                                                                                                                                               | baa The memory uses the burst address advance signal, baa_n, when set.                                                                                                                                                                                                                                                          |  |  |
| 9:7   | RO   | 0x0                                                                                                                                                                                                                                                                                                                                                                                                               | wr_bl Selects the memory burst length for writes: b000 = 1 beat b001 = 4 beats b010 = 8 beats b011 = 16 beats b100 = 32 beats b101 = continuous b110-b111 = reserved.                                                                                                                                                           |  |  |
| 6     | RO   | 0x0                                                                                                                                                                                                                                                                                                                                                                                                               | wr_sync When set, the memory operates in write sync mode.                                                                                                                                                                                                                                                                       |  |  |
| 5:3   | RO   | 0x0                                                                                                                                                                                                                                                                                                                                                                                                               | rd_bl Selects the memory burst length for reads: b000 = 1 beat b001 = 4 beats b010 = 8 beats b011 = 16 beats b100 = 32 beats b101 = continuous b110-b111 = reserved.                                                                                                                                                            |  |  |
| 2     | RO   | 0x0                                                                                                                                                                                                                                                                                                                                                                                                               | rd_sync When set, the memory operates in read sync mode.                                                                                                                                                                                                                                                                        |  |  |



| Bit | Attr | Reset Value | Description                                                                                        |
|-----|------|-------------|----------------------------------------------------------------------------------------------------|
| 1:0 | RO   | 0x0         | mw Selects the SMC memory data bus width: b00 = 8 bits b01 = 16 bits b10 = 32 bits b11 = reserved. |

## SMC\_SRAM\_CYCLES1

Address: Operational Base + offset (0x0120)

sram cycles Register for CS1

| Bit   | Attr | Reset Value                                                                                                                                                                         | Description                                                                            |
|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|
| 31:21 | RO   | 0x0                                                                                                                                                                                 | reserved                                                                               |
| 20    | RO   | we_time For asynchronous multiplexed transfers bit controls when the SMC asserts we_n 0 = SMC asserts we_n two mclk cycles a asserting cs_n. 1 = SMC asserts we_n and cs_n together |                                                                                        |
| 19:17 | RO   | 0x0                                                                                                                                                                                 | t_tr Turnaround time for SRAM chip configurations. Minimum permitted value = 1.        |
| 16:14 | RO   | 0x0                                                                                                                                                                                 | t_pc Page cycle time for SRAM chip configurations. Minimum permitted value = 1         |
| 13:11 | RO   | 0x0                                                                                                                                                                                 | t_wp<br>we_n assertion delay.<br>Minimum permitted value = 1.                          |
| 10:8  | RO   | 0x0                                                                                                                                                                                 | t_ceoe oe_n assertion delay for SRAM chip configurations. Minimum permitted value = 1. |
| 7:4   | RO   | 0x0                                                                                                                                                                                 | t_wc<br>Write cycle time.<br>Minimum permitted value = 2.                              |
| 3:0   | RO   | 0x0                                                                                                                                                                                 | t_rc<br>Read cycle time.<br>Minimum permitted value = 2.                               |

# SMC\_OPMODE1

Address: Operational Base + offset (0x0124)

opmode Register for CS1

| Bit   | Attr | Reset Value | Description                                                                                                                                    |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | RO   | 0x00        | address_match Returns the value of this tie-off. This is the comparison value for address bits [31:24] to determine the chip that is selected. |



b110-b111 = reserved.

| Bit | Attr | Reset Value | Description                                                                                        |
|-----|------|-------------|----------------------------------------------------------------------------------------------------|
| 2   | RO   | 0x0         | rd_sync When set, the memory operates in read sync mode.                                           |
| 1:0 | RO   | 0x0         | mw Selects the SMC memory data bus width: b00 = 8 bits b01 = 16 bits b10 = 32 bits b11 = reserved. |

Notes: Attr: **RW**- Read/writable, **RO**- read only, **WO**-write only

# 14.5 Timing Diagram



Fig. 14-9 SMC timing diagram of asynchronous read



Fig. 14-10Asynchronous Write Timing Diagram In Multiplexed Mode

Table 14-1Meaning of The Parameter in Fig.14-9 and Fig.14-10

| Parameter            | Description                               | min   | typ   | max   | unit |
|----------------------|-------------------------------------------|-------|-------|-------|------|
| t <sub>rcsk0</sub>   | Rise and fall skew for smc_csn0           | -273  | -385  | -544  | ps   |
| t <sub>rcsk1</sub>   | Rise and fall skew for smc_csn1           | -121  | -128  | -102  | ps   |
| t <sub>wesk</sub>    | Rise and fall skew for smc_we_n           | -213  | -276  | -403  | ps   |
| t <sub>cs02oe</sub>  | smc_csn0 valid to smc_oe_n valid skew     | -58   | -85   | -148  | ps   |
| t <sub>cs12oe</sub>  | smc_csn1 valid to smc_oe_n valid skew     | -1483 | -2218 | -3234 | ps   |
| t <sub>oe2cs0</sub>  | smc_oe_n invalid to smc_csn0 invalid skew | 29    | 33    | 21    | ps   |
| t <sub>oe2cs1</sub>  | smc_oe_n invalid to smc_csn1 invalid skew | 1606  | 2423  | 3549  | ps   |
| t <sub>cs02add</sub> | smc_csn0 valid to smc_addr valid skew     | -213  | -303  | -415  | ps   |
| t <sub>cs12add</sub> | smc_csn1 valid to smc_addr valid skew     | -1638 | -2436 | -3501 | ps   |



| t <sub>add2cs0</sub> | smc_addr invalid to smc_csn0 invalid skew | -1658 | -2515 | -3426 | ps |
|----------------------|-------------------------------------------|-------|-------|-------|----|
| t <sub>add2cs1</sub> | smc_addr invalid to smc_csn1 invalid skew | -81   | -125  | 102   | ps |
| t <sub>cs02we</sub>  | smc_csn0 valid to smc_we_n valid skew     | -113  | -178  | -235  | ps |
| t <sub>cs12we</sub>  | smc_csn1 valid to smc_we_n valid skew     | -1538 | -2311 | -3321 | ps |
| t <sub>advsk</sub>   | Rise and fall skew for smc_adv_n          | -195  | -243  | -305  | ps |
| t <sub>cs02adv</sub> | smc_csn0 valid to smc_adv_n valid skew    | 89    | 111   | 135   | ps |
| t <sub>cs12adv</sub> | smc_csn1 valid to smc_adv_n valid skew    | -1336 | -2022 | -2951 | ps |
| t <sub>cs02da</sub>  | smc_csn0 valid to smc_data valid skew     | -3    | 99    | 207   | ps |
| t <sub>cs12da</sub>  | smc_csn1 valid to smc_data valid skew     | -1422 | -2034 | -2879 | ps |
| t <sub>da2cs0</sub>  | smc_data invalid to smc_csn0 invalid skew | -530  | -826  | -1283 | ps |
| t <sub>da2cs1</sub>  | smc_data invalid to smc_csn1 invalid skew | 1047  | 1564  | 2245  | ps |

# 14.6 Interface Description

SMC IOs are multiplexed with GPIO as following Table Table 14-2 SMC interface mux description

| ModulePin  | Direction | Pad Name   | IOMUX Setting                    |
|------------|-----------|------------|----------------------------------|
| smc_oe_n   | 0         | GPIO0_D[2] | $GRF\_GPIOOD\_IOMUX[5:4] = 10$   |
| smc_bls_n1 | 0         | GPIO2_C[2] | $GRF_GPIO2C_IOMUX[5:4] = 10$     |
| smc_bls_n0 | 0         | GPIO2_C[1] | $GRF\_GPIO2C\_IOMUX[3:2] = 10$   |
| smc_we_n   | 0         | GPIO0_D[1] | $GRF\_GPIO0D\_IOMUX[3:2] = 10$   |
| smc_addr0  | 0         | GPIO0_D[4] | $GRF\_GPIO0D\_IOMUX[9:8] = 10$   |
| smc_addr1  | 0         | GPIO0_D[5] | $GRF\_GPIOOD\_IOMUX[11:10] = 10$ |
| smc_addr2  | 0         | GPIO0_C[6] | $GRF\_GPIOOC\_IOMUX[13:12] = 10$ |
| smc_addr3  | 0         | GPIO0_C[7] | $GRF\_GPIOOC\_IOMUX[15:14] = 10$ |
| smc_addr4  | 0         | GPIO2_A[0] | $GRF\_GPIO2A\_IOMUX[1:0] = 10$   |
| smc_addr5  | 0         | GPIO2_A[1] | $GRF\_GPIO2A\_IOMUX[3:2] = 10$   |
| smc_addr6  | 0         | GPIO2_A[2] | $GRF\_GPIO2A\_IOMUX[5:4] = 10$   |
| smc_addr7  | 0         | GPIO2_A[3] | $GRF\_GPIO2A\_IOMUX[7:6] = 10$   |
| smc_addr8  | 0         | GPIO2_A[4] | $GRF\_GPIO2A\_IOMUX[9:8] = 10$   |
| smc_addr9  | 0         | GPIO2_A[5] | $GRF\_GPIO2A\_IOMUX[11:10] = 10$ |
| smc_addr10 | 0         | GPIO2_A[6] | $GRF\_GPIO2A\_IOMUX[13:12] = 10$ |
| smc_addr11 | 0         | GPIO2_A[7] | $GRF\_GPIO2A\_IOMUX[15:14] = 10$ |
| smc_addr12 | 0         | GPIO2_B[0] | $GRF\_GPIO2B\_IOMUX[1:0] = 10$   |
| smc_addr13 | 0         | GPIO2_B[1] | $GRF\_GPIO2B\_IOMUX[3:2] = 10$   |
| smc_addr14 | 0         | GPIO2_B[2] | $GRF\_GPIO2B\_IOMUX[5:4] = 10$   |
| smc_addr15 | 0         | GPIO2_B[3] | $GRF\_GPIO2B\_IOMUX[7:6] = 10$   |
| smc_addr16 | 0         | GPIO2_B[4] | $GRF\_GPIO2B\_IOMUX[9:8] = 10$   |
| smc_addr17 | 0         | GPIO2_B[5] | $GRF\_GPIO2B\_IOMUX[11:10] = 10$ |
| smc_addr18 | 0         | GPIO2_B[6] | $GRF\_GPIO2B\_IOMUX[13:12] = 10$ |
| smc_addr19 | 0         | GPIO2_B[7] | $GRF\_GPIO2B\_IOMUX[15:14] = 10$ |
| smc_csn1   | 0         | GPIO2_D[1] | $GRF\_GPIO2D\_IOMUX[3:2] = 10$   |
| smc_csn0   | 0         | GPIO0_D[0] | $GRF\_GPIOOD\_IOMUX[1:0] = 10$   |
| smc_adv_n  | 0         | GPIO0_D[3] | $GRF\_GPIOOD\_IOMUX[7:6] = 10$   |
| smc_data0  | I/O       | GPIO4_C[0] | $GRF\_GPIO4C\_IOMUX[1:0] = 01$   |
| smc_data1  | I/O       | GPIO4_C[1] | $GRF\_GPIO4C\_IOMUX[3:2] = 01$   |
| smc_data2  | I/O       | GPIO4_C[2] | $GRF\_GPIO4C\_IOMUX[5:4] = 01$   |
| smc_data3  | I/O       | GPIO4_C[3] | $GRF\_GPIO4C\_IOMUX[7:6] = 01$   |
| smc_data4  | I/O       | GPIO4_C[4] | $GRF\_GPIO4C\_IOMUX[9:8] = 01$   |
| smc_data5  | I/O       | GPIO4_C[5] | $GRF\_GPIO4C\_IOMUX[11:10] = 01$ |
| smc_data6  | I/O       | GPIO4_C[6] | $GRF\_GPIO4C\_IOMUX[13:12] = 01$ |



| smc_data7  | I/O | GPIO4_C[7] | $GRF\_GPIO4C\_IOMUX[15:14] = 01$ |
|------------|-----|------------|----------------------------------|
| smc_data8  | I/O | GPIO4_D[0] | $GRF\_GPIO4D\_IOMUX[1:0] = 01$   |
| smc_data9  | I/O | GPIO4_D[1] | $GRF\_GPIO4D\_IOMUX[3:2] = 01$   |
| smc_data10 | I/O | GPIO4_D[2] | $GRF\_GPIO4D\_IOMUX[5:4] = 01$   |
| smc_data11 | I/O | GPIO4_D[3] | $GRF\_GPIO4D\_IOMUX[7:6] = 01$   |
| smc_data12 | I/O | GPIO4_D[4] | $GRF\_GPIO4D\_IOMUX[9:8] = 01$   |
| smc_data13 | I/O | GPIO4_D[5] | $GRF\_GPIO4D\_IOMUX[11:10] = 01$ |
| smc_data14 | I/O | GPIO4_D[6] | $GRF\_GPIO4D\_IOMUX[13:12] = 01$ |
| smc_data15 | I/O | GPIO4_D[7] | $GRF\_GPIO4D\_IOMUX[15:14] = 01$ |

# 14.7 Application Notes

#### 14.7.1 multiplexed address/data mode

When SMC memory interface operates in multiplexed address/data mode, you first must config bit 6 of register GRF\_SOC\_CON1 in GRF(General Register Files) as 1.

In multiplexed address/data mode, smc\_addr[15:0] are multiplexed with smc\_data0 - smc\_data15, so you don't need config GPIO mux of smc\_addr[15:0], but smc\_addr[19:16] need config GPIO mux. If SMC has be set to 8 bits data bus width, then smc\_data8 - smc\_data15 and addr[7:0] don't need config GPIO mux in multiplexed address/data mode and other data and address need.

### 14.7.2 Booting using the SRAM interface

The SMC enables the lowest SRAM chip select, normally chip 0, to be bootable To enable SRAM memory to be bootable, the SRAM interface does not require any special functionality, other than knowing the memory width of the memory concerned. This is indicated by a top-level tie-off. To enable the SMC to work with the slowest memories, the timing registers reset to the worst-case values. When the remap signal is HIGH, the memory with the bootable chip select is set by the sram mw [1:0] tie-off signals.

Additionally, while the SMC input remap is HIGH, the bootable chip is aliased to base address 0x0.

You can config the remap and sram mw via write register GRF SOC CON1 bit 3 and bit 5-4.

# Chapter 15 NandC(Nand Flash Controller)

## 15.1 Overview

Nand Flash Controller (NandC) is used to control data transmission from host to flash device or from flash device to host. NandC is connected to AHB BUS through an AHB Master and an AHB Slave. The data transmission between host and external memory can be done through AHB Master Interface or AHB Slave Interface.

#### 15.1.1 Features

- Software Interface Type
  - ◆ Support directly mode
  - ◆ Support LLP mode
- Flash Interface Type
  - Support Asynchronous Flash Interface with 8bits datawidth ("Asyn8x" for short)
  - Support Asynchronous Flash Interface with 16bits data width ("Asyn16x" for short)
  - ◆ Support ONFI Synchronous Flash Interface ("ONFI Syn" for short)
  - ◆ Support Toggle Flash Interface ("Toggle" for short)
  - ♦ Support 8 flash devices at most
- Flash Type
  - ◆ Support Managed NAND Flash(LBA) and Raw NAND Flash(NO-LBA)
  - ◆ Support SLC/MLC/TLC Flash
- Flash Interface Timing
  - Asyn8x: configurable timing, one byte per two host clocks at the fastest speed
  - ◆ Asyn16x: configurable timing, two bytes per two host clocks at the fastest speed
  - ONFI Syn: configurable timing, two bytes per two host clocksat the fastest speed
  - ◆ Toggle: configurable timing, two byte per two host clocks at the fastest speed
- Randomizer Ability
  - ◆ Supporttwo randomizer mode with different polynomial
  - Support two randomizer width, 8bit and 16bit parallel
- BCH/ECC Ability
  - ◆ 16bit/1KB BCH/ECC: support 16bitBCH/ECC, which can detect and correct up to 16 error bits in every 1K bytes data
  - ◆ 24bit/1KB BCH/ECC: support 24bitBCH/ECC, which can detect and correct up to 24 error bits in every 1K bytes data
  - ◆ 40bit/1KB BCH/ECC: support 40bitBCH/ECC, which can detect and correct up to 40 error bits in every 1K bytes data
  - ◆ 60bit/1KB BCH/ECC: support 60bitBCH/ECC, which can detect and correct up to 60 error bits in every 1K bytes data
  - ◆ 8bit/512B BCH/ECC: support 8bitBCH/ECC, which can detect and correct up to 8 error bits in every 512 bytes data
  - ◆ 12bit/512B BCH/ECC: support 12bitBCH/ECC, which can detect and correct up to 12 error bits in every 512 bytes data
  - ◆ 20bit/512B BCH/ECC: support 20bitBCH/ECC, which can detect and correct up to 20 error bits in every 512 bytes data
  - ◆ 30bit/512B BCH/ECC: support 30bitBCH/ECC, which can detect and



- correct up to 30 error bits in every 512 bytes data
- 16bit/512B BCH/ECC: support 16bitBCH/ECC, which can detect and correct up to 16 error bits in every 512 bytes data
- 24bit/512B BCH/ECC: support 24bitBCH/ECC, which can detect and correct up to 24 error bits in every 512 bytes data
- 40bit/512B BCH/ECC: support 40bitBCH/ECC, which can detect and correct up to 40 error bits in every 512 bytes data
- 60bit/512B BCH/ECC: support 60bitBCH/ECC, which can detect and correct up to 60 error bits in every 512 bytes data
- Support auto correction for all" FF" code
- Transmission Ability
  - Support 16K bytes data transmission at a time at most
  - Support two transfer working modes: Bypass or DMA
  - Support two transfer codeword size for Managed NAND Flash: 1024 bytes/codeword or 512 bytes/codeword
- **Internal Memory** 
  - 2 built-in srams, and the size is 1k bytes respectively
  - Can be accessed by other masters
  - Can be operated in pingpang mode by other masters

For detailed information about NandC (Nand Flash Controller), please refer to RK30xx NandC.pdf.

# **Chapter 16 eMMC Interface**

### 16.1 Overview

The SDMMC Host Controller is designed to support Secure Digital memory (SD mem - version 3.00), Secure Digital I/O(SDIO-version 3.00), Multimedia Cards(MMC-version 4.41). The SDMMC support SD Card(1/4bit), SDIO, MMC(1/4/8bit).

#### **Feature**

- Supports AMBA AHB interface
- Supports DMA controller for data transfers
- Supports interrupt output
- Supports SD version3.0 except SPI mode
- Supports MMC version4.41 except SPI mode
- Supports SDIO version3.0
- Supports programmable baud rate.
- Provides individual clock control to selectively turn ON or OFF clock to a card
- Supports power management and power switch. Provides individual power control to selectively turn ON or OFF power to a card
- Support DDR in 4-bit mode

For detailed information about eMMC Controller, please refer to **RK30xx** eMMC Controller.pdf.

# **Chapter 17 SD/MMC Card Host Controller**

## 17.1 Overview

The SDMMC Host Controller is designed to support Secure Digital memory (SD mem - version 3.00), Secure Digital I/O(SDIO-version 3.00), Multimedia Cards(MMC-version 4.41). The SDMMC support SD Card(1/4bit), SDIO, MMC(1/4bit).

#### **Feature**

- Supports AMBA AHB interface
- Supports DMA controller for data transfers
- Supports interrupt output
- Supports SD version3.0 except SPI mode
- Supports MMC version4.41 except SPI mode
- Supports SDIO version3.0
- Supports programmable baud rate.
- Provides individual clock control to selectively turn ON or OFF clock to a card
- Supports power management and power switch. Provides individual power control to selectively turn ON or OFF power to a card
- Support DDR in 4-bit mode

# 17.2 Block Diagram

The SD/MMC controller consists of the following main functional blocks, which are illustrated in Fig. 17-1.



Fig. 17-1SD/MMC Controller Block Diagram

- Bus Interface Unit (BIU) Provides AMBA AHB and DMA interfaces for register and dataread/writes.
- Card Interface Unit (CIU) Takes care of the SD\_MMC protocols and provides clockmanagement.

# 17.3 Function description

#### 17.3.1 Bus Interface Unit

The Bus Interface Unit provides the following functions:

- Host interface
- DMA interface
- Interrupt control
- Register access
- FIFO access
- Power control and card detection
- 235x32bit external fifo

#### **Host Interface Unit**

The Host Interface Unit is an AHB slave interface, which provides theinterface between the SD/MMC host controller and the host bus. You can configure the host interface as either an AHB.

#### **DMA Interface Unit**

DMA signals interface the SD/MMC Host Controller to an external DMA controller to reduce the software overhead during FIFO data transfers. The DMA request/acknowledge handshake is used for only data transfers. The DMA interface provides a connection to the DMA Controller.

On seeing the DMA request, the DMA controller initiates accesses through the host interface to read or write into the data FIFO. The SD/MMC Host Controller has FIFO transmit/receive watermark registers that you can set, depending on system latency. The DMA interface asserts the request in the following cases:

- Read from a card when the data FIFO word count exceeds the Rx-Watermark level
- Write to a card when the FIFO word count is less than or equal to the Tx-Watermark level

When the DMA interface is enabled, you can use normal host read/writes to access the data FIFOs.

#### **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 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 CMD register, the following registers cannot be reprogrammed until the command is accepted by the card interface unit:

- CMD Command
- CMDARG Command Argument
- BYTCNT Byte Count
- BLKSIZ Block Size
- CLKDIV Clock Divider



- CLKENA Clock Enable
- CLKSRC Clock Source
- TMOUT Timeout
- CTYPE Card Type

The hardware resets the start bit once the CIU accepts the command. If a host write to any of these registers is attempted during this locked time, then the write is ignored and the hardware lock error bit is set in the raw interrupt status register. Additionally, if the interrupt is enabled and not masked for a hardware lock error, then an interrupt is sent to the host.

When the Card Interface Unit is in an idle state, it typically takes the following number of clocks for the command handshake, where clk is the BIU clock and cclk in is the CIU clock:

 $3 (clk) + 3 (cclk_in)$ 

Once a command is accepted, you can send another command to the CIU-which has a one-deep command queue-under the following conditions:

- If the previous command was not a data transfer command, the new command is sent to the SD/MMC card once the previous command
- If the previous command is a data transfer command and if wait\_prvdata\_complete (bit[13]) of the Command 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.

### **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. 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, int, 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 alitches.

The following bits are available as top-level ports for debug purposes:

- Interrupt mask bits (int\_mask\_n[31:0])
- Raw interrupt status bits (raw ints[31:0])
- Interrupt enable bit (int\_enable)

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.

Table 17-1 Bits in Interrupt Status Register

| Bits | Interrupt      | Description |
|------|----------------|-------------|
| 24   | SDIO Interrupt | -           |



| 1.0 | Cand Na lavar                               | TE and with house shakes the intermed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----|---------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16  | Card No busy<br>Interrupts                  | If card exit busy status, the interrupt happened                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 15  | End Bit Error (read)<br>/Write no CRC (EBE) | Error in end-bit during read operation, or no data CRC or negative CRC received during write operation.  Notes: For MMC CMD19, there may be no CRC status returned by the card. Hence, EBE is set for CMD19. The                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 14  | Auto Command<br>Done (ACD)                  | application should not treat this as an error.  Stop/abort commands automatically sent by card unit and not initiated by host; similar to Command Done (CD) interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 13  | Start Bit Error (SBE)                       | Error in data start bit when data is read from a card. In 4-bit mode, if all data bits do not have start bit, then this error is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 12  | Hardware Locked<br>write Error (HLE)        | During hardware-lock period, write attempted to one of locked registers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 11  | FIFO Underrun/<br>Overrun Error<br>(FRUN)   | Host tried to push data when FIFO was full, or host tried to read data when FIFO was empty. Typically this should not happen, except due to error in software.  Card unit never pushes data into FIFO when FIFO is full, and pop data when FIFO is empty.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 10  | Data Starvation by Host Timeout (HTO)       | To avoid data loss, card clock out (sdmmc_clkout) 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.  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 sdmmc_clkout and card state machines.  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 cmd signal along with data that is sent or received on data line. |
| 9   | Data Read Timeout<br>(DRTO)                 | Data timeout occurred. Data Transfer Over (DTO) also set if data timeout occurs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 8   | Response Timeout (RTO)                      | 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 SD/MMC Host Controller.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 7   | Data CRC Error<br>(DCRC)                    | Received Data CRC does not match with locally-generated CRC in CIU.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 6   | Response CRC Error                          | Response CRC does not match with                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |



|   | (RCRC)                               | locally-generated CRC in CIU.                                                                                                                                                                                                                         |
|---|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5 | Receive FIFO Data<br>Request (RXDR)  | Interrupt set during read operation from card when FIFO level is greater than Receive-Threshold level.                                                                                                                                                |
| 4 | Transmit FIFO Data<br>Request (TXDR) | Interrupt set during write operation to card when FIFO level reaches less than or equal to Transmit-Threshold level.                                                                                                                                  |
| 3 | Data Transfer Over (DTO)             | Data transfer completed, even if there is Start Bit Error or CRC error. This bit is also set when "read data-timeout" occurs.  Notes: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. Also set when response timeout occurs                                                                                                                    |
| 1 | Response Error (RE)                  | Error in received response set if one of following occurs:  Transmission bit != 0 Command index mismatch End-bit != 1                                                                                                                                 |
| 0 | Card-Detect (CDT)                    | When card inserted or removed, this interrupt occurs. Software should read card-detect register (CDETECT, 0x50) to determine current card status.                                                                                                     |

#### **FIFO Controller Unit**

The FIFO controller interfaces the external FIFO to the host/DMA interface and the card controller unit. When FIFO overrun and underrun conditions occur, the card clock stops in order to avoid data loss.

The FIFO uses a two-clock synchronous read and synchronous write dual-port RAM. One of the ports is connected to the host clock, clk, and the second port is connected to the card clock, cclk\_in.

Notes: The FIFO controller does not support simultaneous read/write access from the same port. For debugging purposes, the software may try to write into the FIFO and read back the data; results are indeterminate, since the design does not support read/write access from the same port.

#### **Power Control and Card Detection Unit**

The register unit has registers that control the power and MMC open-drain pullup. Power to each card can be selectively turned on or off.

The card detection unit looks for any changes in the card-detect signals for card insertion or card removal. It filters out the debounces associated with mechanical insertion or removal, and generates one interrupt to the host. You can program the debounce filter value.

On power-on, the controller should read in the card detect port and store the value in the memory. Upon receiving a card-detect interrupt, it should again read the card\_detect port and XOR with the previous card-detect status to find out which card has interrupted. If more than one card is simultaneously removed or inserted, there is only one card-detect interrupt; the XOR value indicates which cards have been disturbed. The memory should be updated with the new card-detect value.





Fig. 17-2SD/MMC Card-Detect Signal

#### 17.3.2 Card Interface Unit

The Card Interface Unit interfaces (CIU) with the Bus Interface Unit (BIU) and the SD/MMC cards or devices. The host writes command parameters to the SD/MMC Host Controller 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 SD/MMC 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
- During an SDIO card transfer, if the card function is suspended and the software wants to resume the suspended transfer, it must first reset the FIFO and start the resume command as if it were a new data transfer command.
- 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 Command register so that the SD/MMC Host Controller can stop the data transfer after issuing the card reset command.
- When the data end bit error is set in the RINTSTS register, the SD/MMC Host Controller does not quarantee 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
- Mux/demux unit

#### 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 SD/MMC Host Controller by programming the BIU registers and setting the start\_cmd bit in the Command register. The BIU asserts start cmd, which indicates that a new command is issued to the SD/MMC Host Controller. The command path loads this new command (command, command argument, timeout) and sends an acknowledge to the BIU by asserting cmd taken.

Once the new command is loaded, the command path state machine sends a command to the SD\_MMC 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 Command 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 irg response" request is signaled by the BIU, then the send\_irg\_response bit is set in the control register.

Loading a new command from the BIU in the command path depends on the following Command register bit settings:

- update\_clock\_registers\_only If this bit is set in the Command 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
  - 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 SD MMC bus; the command path state machine is illustrated in Fig.17-3.



Fig. 17-3 SD/MMC Command Path State Machine

The command path state machine performs the following functions, according to Command register bit values:

- A. send\_initialization Initialization sequence of 80 clocks is sent before sending the command.
- B. 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.
- C. response\_length If this bit is set, a 136-bit response is received; if it is not set, a 48-bit response is received.
- D. 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.

#### **Send Response to BIU**

If the response\_expected bit is set in the Command 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.

#### **Driving P-bit on CMD Line**

The command path drives a P-bit = 1 on the CMD line between two commands if a response is not expected. If a response is expected, the P-bit is driven after the response is received and before the start of the next command; this is done by asserting both ccmd out and ccmd out en. If the command expects the Command Completion Signal, then the P-bit is driven only after receiving the Command Completion Signal. During initialization, the software should set the ccmd\_od\_pullup\_en bit, which indicates an open-drain mode, during which the controller drives only a 0 or high-impedance (Z) on the command bus; a hard 1 is never driven in open-drain mode.

#### 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 Command 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 Fig.17-4, 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 Command register, the data transmit state machine puts data on the card data bus in a stream or in block(s).





Fig. 17-4 SD/MMC Data Transmit State Machine

#### **Stream Data Transmit**

If the transfer mode bit in the Command 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 Command 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 Command 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 CTYPE register bit for the selected card – indicated by the card\_num value in the Command register – is set for a 1-bit, 4-bit, or 8-bit data transfer, the data is transmitted on 1, 4, or 8 data lines, respectively, and CRC16 is separately generated and transmitted for 1, 4, or 8 data lines, respectively.



After a single data block is transmitted, the data transmit state machine receives the CRC status from the card and signals a data transfer to the BIU; this happens when the data-transfer-over bit is set in the 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 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 RINTSTS register.

#### **Multiple Block Data**

A multiple-block write-data transfer occurs if the transfer mode bit in the Command 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 CTYPE register bit for the selected card – indicated by the card num value in the Command register - is set to 1-bit, 4-bit, or 8-bit data transfer, the data is transmitted on 1, 4, or 8 data lines, respectively, and CRC16 is separately generated and transmitted on 1, 4, or 8 data lines, respectively.

After one data block is transmitted, the data transmit state machine receives the CRC status from the card. If the remaining byte count becomes 0, the data path signals to the BIU that the data transfer is done; this happens when the data-transfer-over bit is set in the 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 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 RINTSTS register; further data transfer is terminated.

If the send auto stop bit is set in the Command register, the stop command is internally generated during the transfer of the last data block, where no extra bytes are transferred to the card. The end bit of the stop command may not exactly match the end bit of the CRC status in the last data block.

If the block size is less than 4, 16, or 32 for card data widths of 1 bit, 4 bits, or 8 bits, respectively, the data transmit state machine terminates the data transfer when all the data is transferred, at which time the internally generated stop command is loaded in the command path.

If the byte\_count is 0 - the block size must be greater than 0 - it is an open-ended block transfer. The data transmit state machine for this type of data transfer continues the block-write data transfer until the host software issues a stop or abort command.

#### **Data Receive**

The data-receive state machine, illustrated in Fig.17-5, 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 SD/MMC 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 Command register, the data-receive state machine gets data from the card data bus in a stream or block(s).



Fig. 17-5 SD/MMC Data Receive State Machine

#### **Stream Data Read**

A stream-read data transfer occurs if the transfer mode bit in the Command 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 Command 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 Command 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 CTYPE register bit for the selected card – indicated by the card\_num value in the Command register - is set to a 1-bit, 4-bit, or 8-bit data transfer, data is received from 1, 4, or 8 data lines, respectively, and CRC16 is separately generated and checked for 1, 4, or 8 data lines, respectively. If there is a CRC16 mismatch, the data path signals a data CRC error to the BIU. If the received end bit is not 1, the BIU receives an end-bit error.

#### **Multiple-Block Data Read**

If the transfer mode bit in the Command 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 CTYPE register bit for the selected card – indicated by the card\_num value in the Command register - is set to a 1-bit, 4-bit, or 8-bit data transfer, data is received from 1, 4, or 8 data lines, respectively, and CRC16 is separately generated and checked for 1, 4, or 8 data lines, respectively.

After a data block is received, if the remaining byte\_count becomes 0, the data path signals a data transfer to the BIU.

If the remaining data bytes are greater than 0, the data path state machine causes another data block to be received. If CRC16 of a received data block does not match the internally-generated CRC16, a data CRC error to the BIU and data reception continue further data transmission until all bytes are transmitted.

Additionally, if the end of a received data block is not 1, data on the data path signals terminate the bit error to the CIU and the data-receive state machine terminates data reception, waits for data timeout, and signals to the BIU that the data transfer is complete.

If the send auto stop bit is set in the Command 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 SD/MMC Host Controller internally generates a stop command and is loaded in the command path when the send auto stop bit is set in the Command register. The auto-stop command helps to send an exact number of data bytes using a stream read or write for the MMC, and a multiple-block read or write for SD memory transfer for SD cards

The software should set the send\_auto\_stop bit according to details listed in Table 17-2.

Table 17-2 Auto-Stop Generation

| Card Transfer type Byte | send_auto_stop | Comments |
|-------------------------|----------------|----------|
|-------------------------|----------------|----------|



| type  |                      | Count | bit set          |                                    |
|-------|----------------------|-------|------------------|------------------------------------|
| ММС   | Stream read          | 0     | No               | Open-ended stradm                  |
| MMC   | Stream read          | >0    | Yes              | Auto-stop after all bytes transfer |
| MMC   | Stream write         | 0     | No               | Open-ended stradm                  |
| 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         |
| ММС   | Multiple-block write | 0     | No               | Open-ended multiple block          |
| MMC   | Multiple-block write | >0    | Yes <sup>⊕</sup> | Pre-defined multiple block         |
| SDMEM | Single-block read    | >0    | No               | Byte count =0 is illegal           |
| SDMEM | Single-block write   | >0    | No               | Byte count =0 illegal              |
| SDMEM | Multiple-block read  | 0     | No               | Open-ended multiple block          |
| SDMEM | Multiple-block read  | >0    | Yes              | Auto-stop after all bytes transfer |
| SDMEM | Multiple-block write | 0     | No               | Open-ended multiple block          |
| SDMEM | Multiple-block write | >0    | Yes              | Auto-stop after all bytes transfer |
| SDIO  | Single-block read    | >0    | No               | Byte count =0 is illegal           |
| SDIO  | Single-block write   | >0    | No               | Byte count =0 illegal              |
| SDIO  | Multiple-block read  | 0     | No               | Open-ended multiple block          |
| SDIO  | Multiple-block read  | >0    | No               | Pre-defined multiple block         |
| SDIO  | Multiple-block write | 0     | No               | Open-ended multiple block          |
| SDIO  | Multiple-block write | >0    | No               | Pre-defined multiple block         |

①: 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 SD/MMC 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 SD/MMC 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 Host Controller until the auto-stop is sent by the SD/MMC 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 SD/MMC Host Controller does not generate an auto-stop command.

#### 3. Non-Data Transfer Commands that Use Data Path

Some non-data transfer commands (non-read/write commands) also use the data path. Table 17-3 lists the commands and register programming requirements for them.

Table 17-3 Non-data Transfer Commands and Requirements

| 14570 1              | CMD27                        | CMD30       | CMD42      | AACMD         | ACMD2 | ACMD5 |
|----------------------|------------------------------|-------------|------------|---------------|-------|-------|
|                      | CINDZI                       | CHDS        | CITIDAZ    | 13            | 2     | 1     |
| Command registe      | r progra                     | mmina       | <u> </u>   | 1 + 2         |       | -     |
|                      | Command register programming |             |            |               |       |       |
| Cmd_index            | 6'h1B                        | 6'h1E       | 6'h2A      | 6'h0D         | 6'h16 | 6'h33 |
| Response_expect      | 1                            | 1           | 1          | 1             | 1     | 1     |
| Response_length      | 0                            | 0           | 0          | 0             | 0     | 0     |
| Check_response_      | 4                            |             | 1          | 4             | 4     |       |
| 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_co     | 0                            | 0           | 0          | 0             | 0     | 0     |
| mplete               | 0                            |             | 0          |               |       | 0     |
| Stop_abort_cmd       | 0                            | 0           | 0          | 0             | 0     | 0     |
| <b>Command Argum</b> | ent regi                     | ster progra | mming      |               |       |       |
|                      |                              | 32-bit      |            |               |       |       |
|                      | Stuff                        | write       |            | Chuff         | Chuff | Chuff |
|                      | bits                         | protect     | Stuff bits | Stuff<br>bits | Stuff | Stuff |
|                      |                              | data        |            |               | bits  | bits  |
|                      |                              | address     |            |               |       |       |



| Block Size register programming |                                 |   |                         |    |   |   |
|---------------------------------|---------------------------------|---|-------------------------|----|---|---|
|                                 | 16                              | 4 | Num_byt es <sup>①</sup> | 64 | 4 | 8 |
| Byte Count regist               | Byte Count register programming |   |                         |    |   |   |
|                                 | 16                              | 4 | Num_byt es <sup>①</sup> | 64 | 4 | 8 |

①: Num bytes = No. of bytes specified as per the lock card data structure SD specification and the MMC specification)

(Refer to the

#### 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 SD/MMC Host 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.

- A. 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 SD/MMC Host Controller stops the interrupt sampling period after the resume command end bit, instead of stopping after the response end bit of the resume command.
- B. Suspend during read transfer If the read data transfer is suspended by the host, the host sets the abort read data bit in the SD/MMC Host 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 SD/MMC Host 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.

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



(sdmmc\_clkout). The card clock can have different clock frequencies, since the SD card can be a low-speed SD card or a full-speed SD card. The SD/MMC Host Controller provides one clock signal (sdmmc clkout).

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. The clock divider is an 8-bit value that provides a clock division factor from 1 to 510; a value of 0 represents a clock-divider bypass, a value of 1 represents a divide by 2, a value of 2 represents a divide by 4, and so on.
- Clock Control register sdmmc\_clkout can be enabled or disabled for each card under the following conditions:
  - clk\_enable sdmmc\_clkout 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 sdmmc clkout 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, sdmmc clkout 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.

#### 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 RINTSTS Register) and the data path continues to wait for the FIFO to start to empty.

# 17.4 Register description

#### 17.4.1 Register Summary

| Name          | Offset | Size | Reset<br>Value | Description               |
|---------------|--------|------|----------------|---------------------------|
| SDMMC_CTRL    | 0x0000 | W    | 0x00000000     | Control register          |
| SDMMC_PWREN   | 0x0004 | W    | 0x00000000     | Power-enable register     |
| SDMMC_CLKDIV  | 0x0008 | W    | 0x00000000     | Clock-divider register    |
| SDMMC_CLKENA  | 0x0010 | W    | 0x00000000     | Clock-enable register     |
| SDMMC_TMOUT   | 0x0014 | W    | 0xffffff40     | Time-out register         |
| SDMMC_CTYPE   | 0x0018 | W    | 0x00000000     | Card-type register        |
| SDMMC_BLKSIZ  | 0x001c | W    | 0x00000200     | Block-size register       |
| SDMMC_BYTCNT  | 0x0020 | W    | 0x00000200     | Byte-count register       |
| SDMMC_INTMASK | 0x0024 | W    | 0×00000000     | Interrupt-mask register   |
| SDMMC_CMDARG  | 0x0028 | W    | 0×00000000     | Command-argument register |



| Name                 | Offset | Size | Reset<br>Value | Description                                      |
|----------------------|--------|------|----------------|--------------------------------------------------|
| SDMMC_CMD            | 0x002c | W    | 0x00000000     | Command register                                 |
| SDMMC_RESP0          | 0x0030 | W    | 0x00000000     | Response-0 register                              |
| SDMMC_RESP1          | 0x0034 | W    | 0x00000000     | Response-1 register                              |
| SDMMC_RESP2          | 0x0038 | W    | 0x00000000     | Response-2 register                              |
| SDMMC_RESP3          | 0x003c | W    | 0x00000000     | Response-3 register                              |
| SDMMC_MINTSTS        | 0x0040 | W    | 0×00000000     | Masked<br>interrupt-status<br>registe            |
| SDMMC_RINTSTS        | 0x0044 | W    | UXUUUUUUU      | Raw interrupt-status register                    |
| SDMMC_STATUS         | 0x0048 | W    | 0x00000406     | Status register                                  |
| SDMMC_FIFOTH         | 0x004c | W    |                | FIFO threshold register                          |
| SDMMC_CDETECT        | 0x0050 | W    | 0x00000000     | Card-detect register                             |
| SDMMC_WRTPRT         | 0x0054 | W    | 0x00000000     | Write-protect register                           |
| SDMMC_TCBCNT         | 0x005c | W    | 0×00000000     | Transferred CIU card byte count                  |
| SDMMC_TBBCNT         | 0x0060 | W    |                | Transferred host/DMA to/from BIU-FIFO byte count |
| SDMMC_DEBNCE         | 0x0064 | W    | 0x00ffffff     | Card detect debounce register                    |
| SDMMC_USRID          | 0x0068 | W    | 0x00000000     | User ID register                                 |
| SDMMC_VERID          | 0x006c | W    | 0x5342240a     | Version ID register                              |
| SDMMC_UHS_REG        | 0x0074 | W    | 0x00000000     | UHS-1 register                                   |
| SDMMC_RST_n          | 0x0078 | W    |                | Hardware reset register                          |
| SDMMC_CARDTHRCTL     | 0x0100 | W    | 0×00000000     | Card Read Threshold<br>Enable                    |
| SDMMC_BACK_END_POWER | 0x0104 | W    | 0x0000000      | Back-end Power                                   |
| SDMMC_FIFO_BASE      | 0x0200 | W    | 0x00000000     |                                                  |

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

# 17.4.2 Detail Register Description

### SDMMC\_CTRL

Address: Operational Base + offset (0x0000)

Control register

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:9 | RO   | 0x0         | reserved    |



| Bit | Attr   | Reset Value | Description                                       |
|-----|--------|-------------|---------------------------------------------------|
|     |        |             | abort_read_data                                   |
|     |        |             | 0 –No change                                      |
|     |        |             | 1 –After suspend command is issued during         |
|     |        |             | read-transfer, software polls card to find when   |
| 0   | DW     | 00          | suspend happened. Once suspend occurs,            |
| 8   | RW     | 0x0         | 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.                                   |
|     |        |             | Used in SDIO card suspend sequence.               |
|     |        |             | send_irq_response                                 |
|     |        |             | 0 –No change                                      |
|     |        |             | 1 –Send auto IRQ response                         |
|     |        |             | Bit automatically clears once response is sent.   |
|     |        |             | To wait for MMC card interrupts, host issues      |
| 7   | RW     | 0x0         | CMD40, and SDMMC Controller waits for             |
|     |        |             | interrupt response from MMC card(s). In           |
|     |        |             | meantime, if host wants SDMMC Controller to       |
|     |        |             | exit waiting for interrupt state, it can set this |
|     |        |             | bit, at which time SDMMC Controller command       |
|     |        |             | state-machine sends CMD40 response on bus         |
|     |        |             | and returns to idle state.                        |
|     |        |             | read_wait                                         |
| 6   | RW     | 0x0         | 0 -Clear read wait                                |
|     |        | • . ~       | 1 –Assert read wait                               |
|     |        | A 0 Y       | For sending read-wait to SDIO cards               |
|     |        |             | dma_enable 0 -Disable DMA transfer mode           |
|     |        |             | 1 –Enable DMA transfer mode                       |
|     |        |             | Even when DMA mode is enabled, host can still     |
|     |        | ·           | push/pop data into or from FIFO; this should      |
| 5   | RW     | 0x0         | not happen during the normal operation. If        |
|     | $\cup$ |             | there is simultaneous FIFO access from            |
|     |        |             | host/DMA, the data coherency is lost. Also,       |
| *   |        |             | there is no arbitration inside SDMMC Controller   |
|     |        |             | to prioritize simultaneous host/DMA access.       |
|     |        |             | int enable                                        |
|     |        |             | Global interrupt enable/disable bit:              |
|     | 5144   |             | 0 –Disable interrupts                             |
| 4   | RW     | 0x0         | 1 –Enable interrupts                              |
|     |        |             | The int port is 1 only when this bit is 1 and one |
|     |        |             | or more unmasked interrupts are set.              |
| 3   | RO     | 0x0         | reserved                                          |



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | W1C  | 0×0         | dma_reset 0 -No change 1 -Reset internal DMA interface control logic To reset DMA interface, firmware should set bit to 1. This bit is auto-cleared after two AHB clocks.                                                                                                                                                                                                                                                                      |
| 1   | W1C  | 0×0         | fifo_reset 0 -No change 1 -Reset to data FIFO To reset FIFO pointers To reset FIFO, firmware should set bit to 1. This bit is auto-cleared after completion of reset operation                                                                                                                                                                                                                                                                 |
| 0   | W1C  | 0x0         | controller_reset  0 -No change  1 -Reset SDMMC controller  To reset controller, firmware should set bit to  1. This bit is auto-cleared after two AHB and two cclk_in clock cycles.  This resets:  * BIU/CIU interface  * CIU and state machines  * abort_read_data, send_irq_response, and read_wait bits of Control register  * start_cmd bit of Command register Does not affect any registers or DMA interface, or FIFO or host interrupts |

# SDMMC\_PWREN

Address: Operational Base + offset (0x0004)

Power-enable register

| Bit  | Attr  | Reset Value | Description                                   |
|------|-------|-------------|-----------------------------------------------|
| 31:1 | RO    | 0x0         | reserved                                      |
|      |       |             | power_enable                                  |
|      | ~     |             | Power on/off switch for the card.             |
| 7    |       |             | Once power is turned on, firmware should wait |
| 0    | RW    | (()x()      | for regulator/switch ramp-up time before      |
| U    | IK VV |             | trying to initialize card.                    |
|      |       |             | 0 –power off                                  |
|      |       |             | 1 –power on                                   |
|      |       |             | Bit values output to card_power_en port.      |

# SDMMC\_CLKDIV

Address: Operational Base + offset (0x0008)

Clock-divider register



| Bit  | Attr | Reset Value | Description                                       |
|------|------|-------------|---------------------------------------------------|
| 31:8 | RO   | 0x0         | reserved                                          |
|      |      |             | clk_divider0                                      |
|      |      |             | Clock divider-0 value. Clock division is 2*n. For |
|      |      |             | example, value of 0 means divide by $2*0 = 0$     |
| 7:0  | RW   | 0x00        | (no division, bypass), value of 1 means divide    |
|      |      |             | by 2*1 = 2, value of "ff됽on.In                    |
|      |      |             | MMC-Ver3.3-only mode, bits not implemented        |
|      |      |             | because only one clock divider is supported.      |

# SDMMC\_CLKENA

Address: Operational Base + offset (0x0010)

Clock-enable register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                     |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                        |
| 16    | RW   | 0×0         | cclk_low_power Low-power control for SD card clock and MMC card clock supported.  0 -Non-low-power mode  1 -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   | 0x0         | reserved                                                                                                                                                                                                                                                                                        |
| 0     | RW   | 0x0         | cclk_enable Clock-enable control for SD card clock and MMC card clock supported. 0 -Clock disabled 1 -Clock enabled                                                                                                                                                                             |

# SDMMC\_TMOUT

Address: Operational Base + offset (0x0014)

Time-out register

| Bit         | Attr | Reset Value | Description                                    |
|-------------|------|-------------|------------------------------------------------|
| <b>&gt;</b> |      | 0xffffff    | data_timeout                                   |
|             |      |             | Value for card Data Read Timeout; same value   |
| 31:8        | RW   |             | also used for Data Starvation by Host timeout. |
|             |      |             | Value is in number of card output clocks       |
|             |      |             | -cclk_out of selected card.                    |
| 7:0         | RW   | 0x40        | response_timeout                               |
|             |      |             | Response timeout value.                        |
|             |      |             | Value is in number of card output clocks       |
|             |      |             | -cclk_out.                                     |



### SDMMC\_CTYPE

Address: Operational Base + offset (0x0018)

Card-type register

| Bit   | Attr | Reset Value | Description                          |
|-------|------|-------------|--------------------------------------|
| 31:17 | RO   | 0x0         | reserved                             |
|       |      | 0x0         | card_width_8                         |
| 16    | RW   |             | Indicates if card is 8-bit:          |
| 16    | KVV  |             | 0 -Non 8-bit mode                    |
|       |      |             | 1 –8-bit mode                        |
| 15:1  | RO   | 0x0         | reserved                             |
|       | RW   | 0x0         | card_width                           |
| 0     |      |             | Indicates if card is 1-bit or 4-bit: |
|       |      |             | 0 −1-bit mode                        |
|       |      |             | 1 -4-bit mode                        |

### SDMMC\_BLKSIZ

Address: Operational Base + offset (0x001c)

Block-size register

|       |      | •           |                       |
|-------|------|-------------|-----------------------|
| Bit   | Attr | Reset Value | Description           |
| 31:16 | RO   | 0x0         | reserved              |
| 15:0  | RW   | 10x0200     | block_size Block size |

### SDMMC\_BYTCNT

Address: Operational Base + offset (0x0020)

Byte-count register

| Dyte-co | unit regis | Stei        |                                                      |
|---------|------------|-------------|------------------------------------------------------|
| Bit     | Attr       | Reset Value | Description                                          |
|         |            | • 0         | byte_count                                           |
|         |            |             | Number of bytes to be transferred; should be         |
|         |            |             | integer multiple of Block Size for block             |
|         |            |             | transfers.                                           |
| 31:0    | RW         | 0x00000200  | For undefined number of byte transfers, byte         |
|         |            | 7           | count should be set to 0. When byte count is         |
| ,       |            |             | set to 0, it is responsibility of host to explicitly |
|         |            |             | send stop/abort command to terminate data            |
|         | ~          |             | transfer.                                            |

### SDMMC\_INTMASK

Address: Operational Base + offset (0x0024)

Interrupt-mask register

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



| Bit   | Attr | Reset Value | Description                                  |
|-------|------|-------------|----------------------------------------------|
|       |      |             | sdio_int_mask                                |
|       |      |             | Mask SDIO interrupts                         |
| 2.4   | DW   | 00          | When masked, SDIO interrupt detection for    |
| 24    | RW   | 0x0         | that card is disabled.                       |
|       |      |             | A 0 masks an interrupt, and 1 enables an     |
|       |      |             | interrupt.                                   |
| 23:17 | RO   | 0x0         | reserved                                     |
|       |      |             | new_int_mask                                 |
| 16    | RW   | 0x0         | New Interrupt Mask                           |
|       |      |             | 1: data no busy interrupt masked             |
|       |      |             | int_mask                                     |
|       |      |             | Bits used to mask unwanted interrupts. Value |
|       |      |             | of 0 masks interrupt; value of 1 enables     |
|       |      |             | interrupt.                                   |
|       |      |             | bit 15 -End-bit error (read)/Write no CRC    |
|       |      |             | (EBE)                                        |
|       |      |             | bit 14 –Auto command done (ACD)              |
|       |      |             | bit 13 -Start-bit error (SBE)                |
|       | RW   | 0×0000      | bit 12 -Hardware locked write error (HLE)    |
|       |      |             | bit 11 –FIFO underrun/overrun error (FRUN)   |
| 15:0  |      |             | bit 10 -Data starvation-by-host timeout      |
| 13.0  |      |             | (HTO) /Volt_switch_int                       |
|       |      |             | bit 9 –Data read timeout (DRTO)              |
|       |      |             | bit 8 -Response timeout (RTO)                |
|       |      |             | bit 7 –Data CRC error (DCRC)                 |
|       |      |             | bit 6 -Response CRC error (RCRC)             |
|       |      |             | bit 5 –Receive FIFO data request (RXDR)      |
|       |      |             | bit 4 –Transmit FIFO data request (TXDR)     |
|       | 11   |             | bit 3 –Data transfer over (DTO)              |
|       |      | 7           | bit 2 –Command done (CD)                     |
|       |      |             | bit 1 -Response error (RE)                   |
|       |      |             | bit 0 -Card detect (CD)                      |

# SDMMC\_CMDARG

Address: Operational Base + offset (0x0028)

Command-argument register

| Bit  | Attr | Reset Value | Description                                                    |
|------|------|-------------|----------------------------------------------------------------|
| 31:0 | RW   | 0×00000000  | cmd_arg Value indicates command argument to be passed to card. |

### SDMMC\_CMD

Address: Operational Base + offset (0x002c)

Command register



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31  | RW   | 0×0         | start_cmd Start command. Once command is taken by CIU, bit is cleared. 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. Once command is sent and response is received from SD_MMC cards, Command Done bit is set in raw interrupt register.                                                                                       |
| 30  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 29  | RW   | 0×0         | use_hold_reg Use Hold Register 0 - CMD and DATA sent to card bypassing HOLD Register 1 - CMD and DATA sent to card through the HOLD Register Note: a. Set to 1'b1 for SDR12 and SDR25 (with non-zero phase-shifted cclk_in_drv); zero phase shift is not allowed in these modes. b. Set to 1'b0 for SDR50, and DDR50 (with zero phase- shifted cclk_in_drv) c. Set to 1'b1 for SDR50, and DDR50 (with non-zero phase-shifted cclk_in_drv) |
| 28  | RW   | 0×0         | volt_switch Voltage switch bit 0 - No voltage switching 1 - Voltage switching enabled; must be set for CMD11 only                                                                                                                                                                                                                                                                                                                         |
| 27  | RW   | 0×0         | boot_mode Boot Mode 0 - Mandatory Boot operation 1 - Alternate Boot operation                                                                                                                                                                                                                                                                                                                                                             |
| 26  | RW   | 0x0         | disable_boot Disable Boot. When software sets this bit along with start_cmd, CIU terminates the boot operation. Do NOT set disable_boot and enable_boot together.                                                                                                                                                                                                                                                                         |



| Bit   | Attr | Reset Value | Description                                     |
|-------|------|-------------|-------------------------------------------------|
|       |      |             | expect_boot_ack                                 |
|       |      |             | Expect Boot Acknowledge. When Software sets     |
| 25    | RW   | 0x0         | this bit along with enable_boot, CIU expects a  |
|       |      |             | boot acknowledge start pattern of 0-1-0 from    |
|       |      |             | the selected card.                              |
|       |      |             | enable_boot                                     |
|       |      |             | Enable Boot—this bit should be set only for     |
|       |      |             | mandatory boot mode. When Software sets this    |
| 24    | RW   | 0x0         | 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:22 | RO   | 0x0         | reserved                                        |
|       |      |             | update_clock_registers_only                     |
|       |      |             | 0 –Normal command sequence                      |
|       |      |             | 1 -Do not send commands, just update clock      |
|       |      |             | register value into card clock domain Following |
|       |      | 0×0         | register values transferred into card clock     |
|       |      |             | domain: CLKDIV, CLRSRC, CLKENA.                 |
|       |      |             | Changes card clocks (change frequency,          |
|       |      |             | truncate off or on, and set low-frequency       |
|       |      |             | mode); provided in order to change clock        |
| 21    | RW   |             | frequency or stop clock without having to send  |
| 21    |      |             | command to cards.                               |
|       |      |             | During normal command sequence, when            |
|       |      | Cl. Ch.     | update_clock_registers_only = 0, following      |
|       |      |             | control registers are transferred from BIU to   |
|       |      |             | CIU: CMD, CMDARG, TMOUT, CTYPE, BLKSIZ,         |
|       | 41   |             | BYTCNT. CIU uses new register values for new    |
|       |      |             | command sequence to card.                       |
|       |      |             | When bit is set, there are no Command Done      |
|       |      |             | interrupts because no command is sent to        |
|       |      |             | SD_MMC cards.                                   |
| 20:16 | RO   | 0x0         | reserved                                        |



| Bit           | Attr | Reset Value      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------|------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b> 15 | RW   | Reset Value  0x0 | send_initialization  0 -Do not send initialization sequence (80 clocks of 1) before sending this command  1 -Send initialization sequence before sending this command  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                                                                                                                                                                                                                         |
| 14            | RW   | 0×0              | modes (alternate or mandatory).  stop_abort_cmd  0 -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.  1 -Stop or abort command intended to stop current data transfer in progress.  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 CMD[26] = disable_boot. |
| 13            | RW   | 0×0              | wait_prvdata_complete 0 -Send command at once, even if previous data transfer has not completed 1 -Wait for previous data transfer completion before sending command 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.                                                                                                                                                                                                                                                                                                                              |



| Bit | Attr | Reset Value | Description                                    |
|-----|------|-------------|------------------------------------------------|
|     |      |             | send_auto_stop                                 |
|     |      |             | 0 –No stop command sent at end of data         |
|     |      |             | transfer                                       |
|     |      |             | 1 –Send stop command at end of data transfer   |
|     |      |             | When set, SDMMC Controller sends stop          |
|     |      |             | command to SD_MMC cards at end of data         |
|     |      |             | transfer.                                      |
|     |      |             | * when send_auto_stop bit should be set,       |
| 12  | RW   | 0x0         | since some data transfers do not need explicit |
|     |      |             | stop commands                                  |
|     |      |             | * open-ended transfers that software           |
|     |      |             | should explicitly send to stop command         |
|     |      |             | 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.                 |
|     |      |             | Don't care if no data expected from card.      |
|     |      |             | transfer_mode                                  |
| 11  | RW   | 0×0         | 0 –Block data transfer command                 |
|     |      | OXO         | 1 –Stream data transfer command                |
|     |      |             | Don't care if no data expected.                |
|     |      |             | wr                                             |
| 10  | RW   | 0x0         | 0 – Read from card                             |
|     |      | 0.00        | 1 – Write to card                              |
|     |      |             | Don't care if no data expected from card.      |
|     | DW   |             | data_expected                                  |
| 9   | RW   | 0x0         | 0 –No data transfer expected (read/write)      |
|     |      | C           | 1 –Data transfer expected (read/write)         |
|     | 1    |             | check_response_crc                             |
|     |      | 7           | 0 –Do not check response CRC                   |
|     |      |             | 1 -Check response CRC                          |
| 8   | RW   | 0x0         | Some of command responses do not return        |
|     | V    |             | valid CRC bits. Software should disable CRC    |
| 7   |      |             | checks for those commands in order to disable  |
| _   |      |             | CRC checking by controller                     |
|     | DV4  | 00          | response_length                                |
| 7   | RW   | 0x0         | 0 –Short response expected from card           |
|     |      |             | 1 –Long response expected from card            |
| 6   | DV4  |             | response_expect                                |
|     | RW   | 0x0         | 0 –No response expected from card              |
|     |      |             | 1 –Response expected from card                 |
| 5:0 | RW   | 0x00        | cmd_index                                      |
|     | 1    | 0,00        | Command index                                  |



## SDMMC\_RESP0

Address: Operational Base + offset (0x0030)

Response-0 register

| Bit  | Attr | Reset Value | Description                     |
|------|------|-------------|---------------------------------|
| 31:0 | RO   | 10×00000000 | response0 Bit[31:0] of response |

## SDMMC\_RESP1

Address: Operational Base + offset (0x0034)

Response-1 register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                     |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0×00000000  | response Register represents bit[63:32] of long response. When CIU sends auto-stop command, then response is saved in register. Response for previous command sent by host is still preserved in Response 0 register. Additional auto-stop issued only for data transfer commands, and response type is always "short"for them. |

# SDMMC\_RESP2

Address: Operational Base + offset (0x0038)

Response-2 register

| Bit  | Attr | Reset Value | Description                           |
|------|------|-------------|---------------------------------------|
| 31:0 | RO   | 10×00000000 | response2 Bit[95:64] of long response |

## SDMMC\_RESP3

Address: Operational Base + offset (0x003c)

Response-3 register

| Bit  | Attr | Reset Value | Description                  |
|------|------|-------------|------------------------------|
| 31:0 |      | 0×00000000  | response3                    |
| 31.0 | RO   | 0x00000000  | Bit[127:96] of long response |

# SDMMC\_MINTSTS

Address: Operational Base + offset (0x0040)

Masked interrupt-status registe

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:25 | RO   | 0x0         | reserved    |



#### SDMMC\_RINTSTS

Address: Operational Base + offset (0x0044)

Raw interrupt-status register

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:25 | RO   | 0x0         | reserved    |

bit 0 -Card detect (CD)



| Bit   | Attr   | Reset Value | Description                                        |
|-------|--------|-------------|----------------------------------------------------|
|       |        |             | sdio_interrupt                                     |
|       |        |             | Interrupt from SDIO card; Writes to these bits     |
| 24    | RO     | 0×0         | clear them. Value of 1 clears bit and 0 leaves     |
| 24    | KO     | 0.00        | bit intact.                                        |
|       |        |             | 0 –No SDIO interrupt from card                     |
|       |        |             | 1 -SDIO interrupt from card                        |
| 23:17 | RO     | 0x0         | reserved                                           |
|       |        |             | new_int_status                                     |
| 16    | RW     | 0x0         | New Interrupt Status                               |
|       |        |             | 0: data no busy int                                |
|       |        |             | int_status                                         |
|       |        |             | Writes to bits clear status bit. Value of 1 clears |
|       |        |             | status bit, and value of 0 leaves bit intact. Bits |
|       |        |             | are logged regardless of interrupt mask            |
|       |        |             | status.                                            |
|       |        |             | bit 15 -End-bit error (read)/write no CRC          |
|       |        |             | (EBE)                                              |
|       |        |             | bit 14 –Auto command done (ACD)                    |
|       |        |             | bit 13 -Start-bit error (SBE)                      |
|       |        |             | bit 12 -Hardware locked write error (HLE)          |
|       |        |             | bit 11 -FIFO underrun/overrun error (FRUN)         |
|       |        |             | bit 10 -Data starvation-by-host timeout            |
| 15:0  | RO     | 0×0000      | (HTO) /Volt_switch_int                             |
|       |        |             | bit 9 –Data read timeout (DRTO)/Boot Data          |
|       |        | • (1)       | Start (BDS)                                        |
|       |        |             | bit 8 –Response timeout (RTO)/Boot Ack             |
|       |        |             | Received (BAR)                                     |
|       |        |             | bit 7 –Data CRC error (DCRC)                       |
|       | 1      |             | bit 6 –Response CRC error (RCRC)                   |
|       |        | 7           | bit 5 –Receive FIFO data request (RXDR)            |
|       |        |             | bit 4 –Transmit FIFO data request (TXDR)           |
|       | $\cup$ |             | bit 3 –Data transfer over (DTO)                    |
|       |        |             | bit 2 –Command done (CD)                           |
| 7     |        |             | bit 1 –Response error (RE)                         |
|       |        |             | bit 0 -Card detect (CD)                            |

# SDMMC\_STATUS

Address: Operational Base + offset (0x0048)

Status register

| Bit | Attr | Reset Value | Description              |
|-----|------|-------------|--------------------------|
| 21  | RO   | 0×0         | dma_req                  |
| 31  | KO   | UXU         | DMA request signal state |



| Bit   | Attr | Reset Value | Description                                    |
|-------|------|-------------|------------------------------------------------|
| 30    | RO   | 0x0         | dma_ack                                        |
| 30    | RO   | UXU         | DMA acknowledge signal state                   |
| 29:17 | RO   | 0x0000      | fifo_count                                     |
| 29.17 | RO   | 00000       | FIFO count -Number of filled locations in FIFO |
|       |      |             | response_index                                 |
| 16:11 | RO   | 0x00        | Index of previous response, including any      |
|       |      |             | auto-stop sent by core                         |
| 10    | RO   | 0x1         | data_state_mc_busy                             |
| 10    | RO   |             | Data transmit or receive state-machine is busy |
|       |      |             | data_busy                                      |
|       |      |             | Inverted version of raw selected card_data[0]  |
| 9     | RO   | 0x0         | 0 -card data not busy                          |
|       |      |             | 1 –card data busy                              |
|       |      |             | default value is 1 or 0 depending on cdata_in  |
|       |      |             | data_3_status                                  |
|       |      | 0x0         | Raw selected card_data[3]; checks whether      |
| 8     | RO   |             | card is present                                |
|       | KO   |             | 0 -card not present                            |
|       |      |             | 1 -card present                                |
|       |      |             | default value is 1 or 0 depending on cdata_in  |



| Bit      | Attr | Reset Value | Description                                       |
|----------|------|-------------|---------------------------------------------------|
|          |      |             | command_fsm_states                                |
|          |      |             | Command FSM states:                               |
|          |      |             | 0 -Idle                                           |
|          |      |             | 1 -Send init sequence                             |
|          |      |             | 2 –Tx cmd start bit                               |
|          |      |             | 3 -Tx cmd tx bit                                  |
|          |      |             | 4 –Tx cmd index + arg                             |
|          |      |             | 5 -Tx cmd crc7                                    |
|          |      |             | 6 -Tx cmd end bit                                 |
|          |      |             | 7 -Rx resp start bit                              |
|          |      |             | 8 -Rx resp IRQ response                           |
|          |      |             | 9 -Rx resp tx bit                                 |
|          |      |             | 10 -Rx resp cmd idx                               |
|          |      |             | 11 –Rx resp data                                  |
|          |      |             | 12 -Rx resp crc7                                  |
|          |      |             | 13 -Rx resp end bit                               |
| 7:4      | RO   | 0×0         | 14 -Cmd path wait NCC                             |
| ,        |      | UXU         | 15 -Wait; CMD-to-response turnaround              |
|          |      |             | NOTE: The command FSM state is represented        |
|          |      |             | using 19 bits.                                    |
|          |      |             | The 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          |
|          |      | (1)         | represented in the STATUS(7:4) register. The      |
|          |      |             | three states that are not represented in the      |
|          |      |             | STATUS Register(7:4) are:                         |
|          | N    | C           | * Bit 16 –Wait for CCS                            |
|          |      |             | * Bit 17 –Send CCSD                               |
|          |      |             | * Bit 18 –Boot Mode                               |
|          |      |             | Due to this, while command FSM is in "Wait for    |
|          |      |             | CCS state"or "Send CCSD"or "Boot Mode", the       |
|          |      |             | Status register indicates status as 0 for the bit |
| <u> </u> |      |             | field 7:4.                                        |
| 3        | RO   | 0x0         | fifo_full                                         |
|          |      |             | FIFO is full status                               |
| 2        | RO   | 0x1         | fifo_empty                                        |
|          |      |             | FIFO is empty status                              |
|          |      |             | fifo_tx_watermark                                 |
| 1        | RO   | 0x1         | FIFO reached Transmit watermark level; not        |
|          |      |             | qualified with data transfer                      |



| Bit | Attr | Reset Value | Description                               |
|-----|------|-------------|-------------------------------------------|
|     |      |             | fifo_rx_watermark                         |
| 0   | RO   | 0x0         | FIFO reached Receive watermark level; not |
|     |      |             | qualified with data transfer              |

## SDMMC\_FIFOTH

Address: Operational Base + offset (0x004c)

FIFO threshold register

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



| Bit   | Attr       | Reset Value | Description                                     |
|-------|------------|-------------|-------------------------------------------------|
|       |            |             | DMA_Mutiple_Transaction_Size                    |
|       |            |             | Burst size of multiple transaction; should be   |
|       |            |             | programmed same as DMA controller               |
|       |            |             | multiple-transaction-size SRC/DEST_MSIZE.       |
|       |            |             | 000 −1 transfers                                |
|       |            |             | 001 -4                                          |
|       |            |             | 010 -8                                          |
|       |            |             | 011 -16                                         |
|       |            |             | 100 –32                                         |
|       |            |             | 101 -64                                         |
|       |            |             | 110 -128                                        |
|       |            |             | 111 -256                                        |
|       |            |             | The units for transfers is the H_DATA_WIDTH     |
|       |            |             | parameter. A single transfer would be signalled |
|       |            |             | based on this value.                            |
|       |            |             | Value should be sub-multiple of (RX_WMark +     |
|       |            |             | 1)* (F_DATA_WIDTH/H_DATA_WIDTH) and             |
|       |            |             | (FIFO_DEPTH - TX_WMark)* (F_DATA_WIDTH/         |
| 30:28 | RW         | 0x0         | H_DATA_WIDTH)                                   |
| 30.20 | IXVV       | 0.00        | For example, if FIFO_DEPTH = 16,                |
|       |            |             | FDATA_WIDTH == H_DATA_WIDTH                     |
|       |            |             | Allowed combinations for MSize and TX_WMark     |
|       |            |             | are:                                            |
|       |            |             | MSize = 1, TX_WMARK = 1-15                      |
|       |            |             | MSize = 4, TX_WMark = 8                         |
|       |            |             | MSize = 4, TX_WMark = 4                         |
|       |            | AC Y        | MSize = 4, TX_WMark = 12                        |
|       |            |             | MSize = 8, TX_WMark = 8                         |
|       | <b>A</b> 1 |             | MSize = 8, TX_WMark = 4                         |
|       |            |             | Allowed combinations for MSize and RX_WMark     |
|       |            | <b>y</b>    | are:                                            |
|       |            |             | MSize = 1, RX_WMARK = 0-14                      |
|       |            |             | MSize = 4, RX_WMark = 3                         |
|       |            |             | MSize = 4, RX_WMark = 7                         |
|       |            |             | MSize = 4, RX_WMark = 11                        |
|       |            |             | MSize = 8, RX_WMark = 7                         |
|       |            |             | Recommended:                                    |
|       |            |             | MSize = 8, TX_WMark = 8, RX_WMark = 7           |



| Bit   | Attr | <b>Reset Value</b> | Description                                                                                 |
|-------|------|--------------------|---------------------------------------------------------------------------------------------|
|       |      |                    | RX_WMark                                                                                    |
|       |      |                    | 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.                                                                         |
|       |      |                    | 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                                                |
| 27.16 | DW   | 0000               | Done interrupt.                                                                             |
| 27:16 | RW   | 0x000              | 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.                                                                 |
|       |      |                    | Limitation: RX_WMark <= FIFO_DEPTH-2                                                        |
|       |      |                    | Recommended: (FIFO_DEPTH/2) - 1; (means                                                     |
|       |      |                    | greater than (FIFO_DEPTH/2) - 1)                                                            |
|       |      | AOY                | NOTE: In DMA mode during CCS time-out, the                                                  |
|       |      |                    | DMA does not generate the request at the end of                                             |
|       | A 1  |                    | packet, even if remaining bytes are less than                                               |
|       |      | 7                  | threshold. In this case, there will be some data                                            |
|       |      | 7                  | left in the FIFO. It is the responsibility of the                                           |
|       |      |                    | application to reset the FIFO after the CCS                                                 |
| 1     |      |                    | timeout.                                                                                    |
| 15:12 | RO   | 0x0                | reserved                                                                                    |



| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:0 | RW   | 0×000       | TX_WMark 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. In non-DMA mode, when transmit FIFO threshold (TXDR) interrupt is enabled, then interrupt is generated instead of DMA request. During end of packet, on last interrupt, host is responsible for filling FIFO with only required remaining bytes (not before FIFO is full or after CIU completes data transfers, because FIFO may not be empty). 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. 12 bits -1 bit less than FIFO-count of status register, which is 13 bits. Limitation: TX_WMark >= 1; Recommended: FIFO_DEPTH/2; (means less than or equal to FIFO_DEPTH/2) |

# SDMMC\_CDETECT

Address: Operational Base + offset (0x0050)

Card-detect register

| B': All B IVI |      |             |                                               |
|---------------|------|-------------|-----------------------------------------------|
| Bit           | Attr | Reset Value | Description                                   |
| 31:1          | RO   | 0x0         | reserved                                      |
|               |      |             | card_detect_n                                 |
| 0             | RO   | 0x0         | Value on card_detect_n input ports; read-only |
|               |      |             | bits. 0 represents presence of card.          |

# SDMMC\_WRTPRT

Address: Operational Base + offset (0x0054)

Write-protect register

| White proceed register |      |             |                                     |  |
|------------------------|------|-------------|-------------------------------------|--|
| Bit                    | Attr | Reset Value | Description                         |  |
| 31:1                   | RO   | 0x0         | reserved                            |  |
|                        |      |             | write_protect                       |  |
| 0                      | RW   | 0x0         | Value on card_write_prt input port. |  |
|                        |      |             | 1 represents write protection.      |  |



Address: Operational Base + offset (0x005c)

Transferred CIU card byte count

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0×00000000  | trans_card_byte_count Number of bytes transferred by CIU unit to card. In 32-bit or 64-bit AMBA data-bus-width modes, register should be accessed in full to avoid read-coherency problems. In 16-bit AMBA data-bus-width mode, internal 16-bit coherency register is implemented. User should first read lower 16 bits and then higher 16 bits. When reading lower 16 bits, higher 16 bits of counter are stored in temporary register. When higher 16 bits are read, data from temporary register is supplied. Both TCBCNT and TBBCNT share same coherency register. When AREA_OPTIMIZED parameter is 1, register should be read only after data transfer completes; during data transfer, register returns 0. |

# SDMMC\_TBBCNT

Address: Operational Base + offset (0x0060)
Transferred host/DMA to/from BIU-FIFO byte count

| Bit      | Attr | Reset Value | Description                                     |
|----------|------|-------------|-------------------------------------------------|
|          | 1    |             | trans_fifo_byte_count                           |
|          |      | ,           | Number of bytes transferred between             |
|          |      |             | Host/DMA memory and BIU FIFO.                   |
|          |      |             | In 32-bit or 64-bit AMBA data-bus-width         |
|          |      |             | modes, register should be accessed in full to   |
| <b>Y</b> |      |             | avoid read-coherency problems. In 16-bit        |
|          |      |             | AMBA data-bus-width mode, internal 16-bit       |
| 31:0     | RO   | 0x00000000  | coherency register is implemented. User         |
|          |      |             | should first read lower 16 bits and then higher |
|          |      |             | 16 bits. When reading lower 16 bits, higher 16  |
|          |      |             | bits of counter are stored in temporary         |
|          |      |             | register. When higher 16 bits are read, data    |
|          |      |             | from temporary register is supplied.            |
|          |      |             | Both TCBCNT and TBBCNT share same               |
|          |      |             | coherency register.                             |



Address: Operational Base + offset (0x0064)

Card detect debounce register

| Bit   | Attr | Reset Value | Description                                     |
|-------|------|-------------|-------------------------------------------------|
| 31:24 | RO   | 0x0         | reserved                                        |
|       |      |             | debounce_count                                  |
| 23:0  | RW   | 0xffffff    | Number of host clocks (clk) used by debounce    |
|       |      |             | filter logic; typical debounce time is 5-25 ms. |

## SDMMC\_USRID

Address: Operational Base + offset (0x0068)

User ID register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                         |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0×00000000  | USRID User identification register; value set by user. Default reset value can be picked by user while configuring core before synthesis. Can also be used as scratch pad register by user. the default value is determined by Configuration Value. |

# SDMMC\_VERID

Address: Operational Base + offset (0x006c)

Version ID register

| Bit  | Attr | Reset Value | Description                                     |
|------|------|-------------|-------------------------------------------------|
|      | RO   | 0v5342240a  | VERID                                           |
| 31:0 |      |             | Version identification register; register value |
|      |      |             | is hard-wired. Can be read by firmware to       |
|      |      |             | support different versions of core.             |

# SDMMC\_UHS\_REG

Address: Operational Base + offset (0x0074)

UHS-1 register

| Bit   | Attr | Reset Value Description |                                             |
|-------|------|-------------------------|---------------------------------------------|
| 31:17 | RO   | 0x0                     | reserved                                    |
| 1.5   |      |                         | DDR_REG                                     |
|       |      |                         | DDR mode. Determines the voltage fed to the |
|       | RW   |                         | buffers by an external voltage regulator.   |
| 16    |      |                         | 0 –Non-DDR mode                             |
|       |      |                         | 1 –DDR mode                                 |
|       |      |                         | UHS_REG [16] should be set for card         |



| Bit  | Attr | Reset Value | Description                                     |
|------|------|-------------|-------------------------------------------------|
| 15:1 | RO   | 0x0         | reserved                                        |
|      |      |             | VOLT_REG                                        |
|      |      |             | High Voltage mode. Determines the voltage       |
|      |      |             | fed to the buffers by an external voltage       |
|      |      |             | regulator.                                      |
|      | RW   |             | 0 -Buffers supplied with 3.3V Vdd               |
|      |      |             | 1 -Buffers supplied with 1.8V Vdd               |
| 0    |      |             | These bits function as the output of the host   |
| 0    | KVV  |             | controller and are fed to an external voltage   |
|      |      |             | regulator. The voltage regulator must switch    |
|      |      |             | the voltage of the buffers of a particular card |
|      |      |             | to either 3.3V or 1.8V, depending on the value  |
|      |      |             | programmed in the register.                     |
|      |      |             | VOLT_REG[0] should be set to 1'b1 for card in   |
|      |      |             | order to make it operate for 1.8V.              |

# SDMMC\_RST\_n

Address: Operational Base + offset (0x0078)

Hardware reset register

| Bit  | Attr | Reset Value | Description                                      |
|------|------|-------------|--------------------------------------------------|
| 31:1 | RO   | 0x0         | reserved                                         |
|      |      |             | CARD_RESET                                       |
|      |      |             | Hardware reset.                                  |
|      | RW   |             | 1 –Active mode                                   |
| 0    |      | 0×1         | 0 -Reset                                         |
| U    |      | OXI         | These bits cause the cards to enter pre-idle     |
|      |      |             | state, which requires them to be re-initialized. |
|      |      |             | CARD_RESET[0] should be set to 1'b1 to reset     |
|      | 1    |             | card                                             |

# SDMMC\_CARDTHRCTL

Address: Operational Base + offset (0x0100)

Card Read Threshold Enable

| Bit   | Attr | Reset Value Description |                          |
|-------|------|-------------------------|--------------------------|
| 31:28 | RO   | 0x0                     | reserved                 |
| 27:16 | RW   | 10x000                  | CardRdThreshold          |
|       |      |                         | Card Read Threshold size |
| 15:1  | RO   | 0x0                     | reserved                 |



| Bit | Attr | Reset Value | Description                                  |
|-----|------|-------------|----------------------------------------------|
|     |      |             | CardRdThrEn                                  |
|     |      |             | Card Read Threshold Enable                   |
|     |      |             | 1'b0 - Card Read Threshold disabled          |
| 0   | RW   | 0x0         | 1'b1 - Card Read Threshold enabled. Host     |
|     |      |             | Controller initiates Read Transfer only if   |
|     |      |             | CardRdThreshold amount of space is available |
|     |      |             | in receive FIFO.                             |

# SDMMC\_BACK\_END\_POWER

Address: Operational Base + offset (0x0104)

Back-end Power

| Bit  | Attr | Reset Value | Description                           |
|------|------|-------------|---------------------------------------|
| 31:1 | RO   | 0x0         | reserved                              |
|      |      |             | Back_End_Power                        |
|      |      |             | Back end power                        |
| 0    | RW   | 0x0         | 1'b0 -Off; Reset                      |
|      |      |             | 1'b1 –Back-end Power supplied to card |
|      |      |             | application                           |

# SDMMC\_FIFO\_BASE

Address: Operational Base + offset (0x0200)

| Bit  | Attr   | Reset Value | Description    |
|------|--------|-------------|----------------|
| 31:0 | RW     | 0×00000000  | fifo_base_addr |
| 51.0 | IT V V | 020000000   | fifo base addr |

# 17.5 Timing Diagram

# 17.6 Interface description

17.6.1 Card-Detect and Write-Protect Mechanism

Figure 17-6 illustrates how the SD/MMC Host Controller card detection and write-protect signals are connected. Most of the SD\_MMC sockets have card-detect pins. When no card is present, card\_detect\_n is 1 due to the pull-up. When the SD\_MMC card is inserted, the card-detect pin is shorted to ground, which makes card detect n go to 0. Similarly in SD cards, when the write-protect switch is toward the left, it shorts the write protect port to ground.





Fig. 17-6 Card-Detect and Write-Protect

# 17.6.2 SD/MMC Controller Termination Requirement

Fig.17-7 illustrates the SD/MMC Host Controller termination requirements, which is required to pull up ccmd and cdata lines on the SD MMC bus. The recommended specification for pull-up on the ccmd line (Rcmd) is 4.7K - 100K for MMC, and 10K - 100K for an SD. The recommended pull-up on the cdata line (Rdat) is 50K - 100K.



Fig. 17-7 SD/MMC Termination

# Rcmd and Rod Calculation

The SD and MMC card enumeration happens at a very low frequency -100-400KHz. Since the MMC bus is a shared bus between multiple cards, during enumeration open-drive mode is used to avoid bus conflict. Cards that drive 0 win over cards that drive "z." The pull-up in the command line pulls the bus to 1 when all cards drive "z." MMC interrupt mode also uses the pull-up. During normal data transfer, the hose chooses only one card and the card driver switches to push-pull mode.

For example, if enumeration is done at 400KHz and the total bus capacitance is 200 pf, the pull-up needed during enumeration is:

2.2 RC = rise-time = 1/400 KHzR = 1/(2.2 \* C \* 100KHz) $= 1/(2.2 \times 200 \times 10^{**}-12 \times 400 \times 10^{**}3)$  $= 1/(17.6 \times 10^{**}-5)$ 

= 5.68K

The Rod and Rcmd should be adjusted in such a way that the effective pull-up is at the maximum 5.68K during enumeration. If there are only a few cards in the bus, a fixed Rcmd resister is sufficient and there is no need for an additional



Rod pull-up during enumeration. You should also ensure the effective pull-up will not violate the Iol rating of the drivers.

In SD mode, since each card has a separate bus, the capacitance is less, typically in the order of 20-30pf (host capacitance + card capacitance + trace + socket capacitance). For example, if enumeration is done at 400KHz and the total bus capacitance is 20pf, the pull-up needed during enumeration is:

2.2 RC = rise-time = 1/400 KHz

R = 1/(2.2 \* C \* 100KHz)

 $= 1/(2.2 \times 20 \times 10^{**}-12 \times 400 \times 10^{**}3)$ 

 $= 1/(1.76 \times 10**-5)$ 

= 56.8K

Therefore, a fixed 56.8K permanent Rcmd is sufficient in SD mode to enumerate the cards.

The driver of the SD/MMC Host Controller on the "command" port needs to be only a push-pull driver. During enumeration, the SD/MMC Host Controller emulates an open-drain driver by driving only a 0 or a "z" by controlling the ccmd out and ccmd out en signals.

#### 17.6.3 SD/MMC Controller IOMUX

The SDMMC Host Controller share the pin with GPIO. In default, the pins are used for GPIO, if user want to work in sdmmc function, the user must configure the GRF registers as following table:

Table 17-4 SDMMC IOMUX Settings

| Module Pin      | Direction  | Pad Name   | IOMUX Setting         |
|-----------------|------------|------------|-----------------------|
| sdmmc_clkout    | 0          | GPIO3_B[0] | GPIO3B_IOMUX[0]=0x1&  |
|                 |            |            | GPIO3B_IOMUX[16]=0x1  |
| sdmmc_cmd       | I/O        | GPIO3_B[1] | GPIO3B_IOMUX[2]=0x1&  |
|                 | ,          |            | GPIO3B_IOMUX[18]=0x1  |
| sdmmc_data0     | I/O        | GPIO3_B[2] | GPIO3B_IOMUX[4]=0x1&  |
|                 | • (1)      |            | GPIO3B_IOMUX[20]=0x1  |
| sdmmc_data1     | I/O        | GPIO3_B[3] | GPIO3B_IOMUX[6]=0x1&  |
|                 | $\bigcirc$ |            | GPIO3B_IOMUX[22]=0x1  |
| sdmmc_data2     | I/O        | GPIO3_B[4] | GPIO3B_IOMUX[8]=0x1&  |
|                 |            |            | GPIO3B_IOMUX[24]=0x1  |
| sdmmc_data3     | I/O        | GPIO3_B[5] | GPIO3B_IOMUX[10]=0x1& |
|                 |            |            | GPIO3B_IOMUX[26]=0x1  |
| sdmmc_detect_n  | I          | GPIO3_B[6] | GPIO3B_IOMUX[12]=0x1& |
|                 |            |            | GPIO3B_IOMUX[28]=0x1  |
| sdmmc_write_prt | I          | GPIO3_B[7] | GPIO3B_IOMUX[14]=0x1& |
|                 |            |            | GPIO3B_IOMUX[30]=0x1  |
| sdmmc_rstn_out  | 0          | GPIO3_A[6] | GPIO3A_IOMUX[12]=0x1& |
|                 |            |            | GPIO3A_IOMUX[28]=0x1  |
| sdmmc_pwr_en    | 0          | GPIO3_A[7] | GPIO3B_IOMUX[14]=0x1& |
|                 |            |            | GPIO3B_IOMUX[30]=0x1  |

Notes: Direction: I- Input, O- Output, I/O- Input/Output

# 17.7 Application Notes

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

If the card is enumerated in SDR50, or DDR50 mode, then the application must program the use\_hold\_reg bit[29] in the CMD register to 1'b0 (phase shift of cclk\_in\_drv = 0) or 1'b1 (phase shift of cclk\_in\_drv > 0). If the card is enumerated in SDR12 or SDR25 mode, the application must program the use\_hold\_reg bit[29] in the CMD register to 1'b1.

This programming should be done for all data transfer commands and non-data commands that are sent to the card. When the use\_hold\_reg bit is programmed to 1'b0, the SD/MMC Controller bypasses the Hold Registers in the transmit path. The value of this bit should not be changed when a Command or Data Transfer is in progress. For more details on using use\_hold\_reg and the implementation requirements for meeting the Card input hold time, refer to "Recommended Usage" and Table 17-5.

| No. | Speed Mode | use_hold_reg | cclk_in | clk_in_drv | clk_divider |
|-----|------------|--------------|---------|------------|-------------|
| 1   | SDR50      | 1'b1         | 200     | 200        | 1           |
| 2   | DDR50      | 1'b1         | 50      | 50         | 0           |
| 3   | SDR25      | 1'b1         | 50      | 50         | 0           |
| 4   | SDR12      | 1'b1         | 50      | 50         | 1           |

Table 17-5 Recommended Usage of use\_hold\_reg

To avoid glitches in the card clock outputs (sdmmc\_clkout), 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 STATUS register.
- 2. Update the Clock Enable register to disable all clocks. To ensure completion of any previous command before this update, send a command to the CIU to update the clock registers by setting:
  - start cmd bit
  - "update clock registers only" bits
  - "wait\_previous data complete" bit

Wait for the CIU to take the command by polling for 0 on the start\_cmd bit.

- 3. Set the start\_cmd bit to update the Clock Divider and/or Clock Source registers, and send a command to the CIU in order to update the clock registers; wait for the CIU to take the command.
- 4. Set start\_cmd to update the Clock Enable register in order to enable the required clocks and send a command to the CIU to update the clock registers; wait for the CIU to take the command.

In non-DMA mode, while reading from a card, the Data Transfer Over (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 DW-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 SDMMC card (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.

## 17.7.2 Programming Sequence

#### **Initialization**

Fig. 17-8 illustrates the initialization flow.



Fig. 17-8 Initialization Sequence

Once the power and clocks are stable, reset in should be asserted(active-low) for at least two clocks 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 control 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 Control 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 sdmmc clkout according to SDMMC 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 DEBNCE register.
  - FIFO threshold value in bytes in the FIFOTH register. Typically, the threshold value can be set to half the FIFO depth; that is: RX WMark=15; TX WMark=16

#### **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 SDMMC Host Controller; 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, or 8-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 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 valueBit[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.
  - SDIO Send CMD5, CMD3.
  - MMC Send CMD0, CMD1, CMD2, CMD3.

#### **Power Control**

You can implement power control using the following registers, along with external circuitry:

- Control register bits card voltage a and card voltage b Status of these bits is reflected at the IO pins. The bits can be used to generate or control the supply voltage that the memory cards require.
- Power enable register Control power to individual cards.

Programming these two register depends on the implemented external circuitry. While turning on or off the power enable, you should confirm that power supply settings are correct. Power to all cards usually should be disable while switching off the power.

#### **Clock Programming**

The SDMMC controller supports four clock sources, each of which can be programmed with a different frequency; software can select the clock source for each card. The clock to an individual card can be enabled or disabled. Registers that support this are:

- CLKDIV Programs individual clock source frequency.
- CLKSRC Assign clock source for each card.
- 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 SDMMC Controller loads each of these registers only when the start cmd bit and the Update clk regs only bit in the CMD register are set. When a command is successfully loaded, the SDMMC Controller clears this bit, unless the SDMMC 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 SDMMC 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 xxxx0000 to the CLKENA register. Set the start\_cmd, Update\_clk\_regs\_only, and wait\_prvdata\_complete bits in the CMD register. Wait until start cmd is cleared or an HLE is set; in case of an HLE, repeat the command.
- 3. Program the CLKDIV and CLKSRC registers, as required. Set the start\_cmd, Update\_clk\_regs\_only, and wait\_prvdata\_complete bits in the CMD register. Wait until start cmd is cleared or an HLE is set; in case of an HLE, repeat the command.
- 4. Re-enable all clocks by programming the CLKENA register. Set the start\_cmd,Update\_clk\_regs\_only, and wait\_prvdata\_complete bits in the CMD register. Wait until start\_cmdis cleared or an HLE is set; in case of an HLE, repeat the command.

#### No-Data Command With or Without Response Sequence

To send any non-data command, the software needs to program the CMD register @0x2C and theCMDARG register @0x28 with appropriate parameters. Using these two registers, the SD/MMC controller forms the command and sends it to the command bus. The SD/MMC controller reflects the errors in the command response through the error bits of theRINTSTS register.

When a response is received - either erroneous or valid - the SD/MMC controller sets the command\_done bit in the 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 Response3register bit 31 represents the MSB, and the Response0 register bit 0 represents the LSB of a

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 Table 17-6. Table 17-6 Command Settings for No-Data Command

| Parameter               | Value   | Description                                  |
|-------------------------|---------|----------------------------------------------|
| Default                 | 7       |                                              |
| start_cmd               | 1       | -                                            |
| use_hold_reg            | 1/0     | Choose value based on speed mode being       |
|                         |         | used;ref to "use_hold_reg" on 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               | comman  | _                                            |
|                         | d-index |                                              |
| send_initialization     | 0       | Can be 1, but only for card reset commands,  |
|                         |         | such as CMD0                                 |
| stop_abort_cmd          | 0       | Can be 1 for commands to stop data transfer, |
|                         |         | such as CMD12                                |
| response_length         | 0       | Can be 1 for R2(long) response               |
| response_expect         | 1       | Can be 0 for commands with no response; for  |
|                         |         | example, CMD0, CMD4, CMD15, and so on        |
| <b>User-selectable</b>  |         |                                              |
| wait_prvdata_complete 1 |         | Before sending command on command line,      |



|                    |   | host should wait for completion of any data command in process, if any (recommended to always set this bit, unless the current command is to query status or stop data transfer when transfer is in progress) |
|--------------------|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| check_response_crc | 1 | If host should crosscheck CRC of response received                                                                                                                                                            |

- 3. Wait for command acceptance by host. The following happens when the command is loaded into the SD/MMC controller:
  - SD/MMC controller accepts the command for execution and clears the start\_cmd bit in theCMD register, unless one command is in process, at which point the SD/MMC controller can load and keep the second command in the buffer.
  - If the SD/MMC controller is unable to load the command that is, a command is already inprogress, a second command is in the buffer, and a third command is attempted - then itgenerates 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 orresponse timeout, the SD/MMC controller sets the command\_done bit in the 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 doneeither by responding to an interrupt raised by these errors or by polling bits 1, 6, and 8 from theRINTSTS 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.

#### **Data Transfer Commands**

Data transfer commands transfer data between the memory card and the SD/MMC controller. To send a data command, the SD/MMC 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 SD/MMC controller generates an interrupt for different conditions during data transfer, which are reflected in the 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 SD/MMC 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 SD/MMC 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.

## Single-Block or Multiple-Block Read

Steps involved in a single-block or multiple-block read are:

- Write the data size in bytes in the BYTCNT register @0x20.
- Write the block size in bytes in the BLKSIZ register @0x1C. The SD/MMC controller expects data from the card in blocks of size BLKSIZ
- Program the CMDARG register @0x28 with the data address of the 3. beginning of a data read.

Program the Command register with the parameters listed in Table 17-7. 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 17-7 Command Setting for Single-Block or Multiple-Block Read

| Parameter Value            |        | Description                                                                                               |
|----------------------------|--------|-----------------------------------------------------------------------------------------------------------|
| Default                    |        |                                                                                                           |
| start_cmd                  | 1      | -                                                                                                         |
| use_hold_reg               | 1/0    | Choose value based on speed mode being used;ref to "use_hold_reg" on 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 or 1 | Set according to Table xx                                                                                 |
| 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                         |
| User-selectable            |        |                                                                                                           |
| cmd_index comma<br>d-index |        | -                                                                                                         |
| wait_prvdata_complete 1    |        | <ul><li>0- Sends command immediately</li><li>1- Sends command after previous data transfer ends</li></ul> |



| check_response_crc | 1 | 0- SD/MMC controller should not check      |
|--------------------|---|--------------------------------------------|
|                    |   | response CRC                               |
|                    |   | 1- SD/MMC controller should check response |
|                    |   | CRC                                        |

After writing to the CMD register, the SD/MMC controller starts executing the command; when the command is sent to the bus, the command done interrupt is generated.

- 4. Software should look for data error interrupts; that is, bits 7, 9, 13, and 15 of the RINTSTS register. If required, software can terminate the data transfer by sending a STOP command.
- 5. 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.
- 6. When a Data Transfer Over interrupt is received, the software should read the remaining data from the FIFO.

#### 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 BYTCNT register @0x20.
- 2. Write the block size in bytes in the BLKSIZ register @0x1C; the SD/MMC controller sends data in blocks of size BLKSIZ each.
- 3. Program 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 Table 17-8. For SD and MMC cards, use CMD24 for a single-block write and CMD25 for a multiple-block write. For SDIO cards, use CMD53 for both single-block and multiple-block transfers.

Table 17-8 Command Settings for Single-Block or Multiple-Block Write

| Parameter •            | Value   | Description                                  |  |
|------------------------|---------|----------------------------------------------|--|
| Default                |         |                                              |  |
| start_cmd              | 1       | -                                            |  |
| use_hold_reg           | 1/0     | Choose value based on speed mode being       |  |
|                        |         | used;ref to "use_hold_reg" on 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 or 1  | Set according to Table xx                    |  |
| _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              | comman  | _                                            |  |
|                        | d-index |                                              |  |



| wait_prvdata_complete | 1 | Sends command immediately     Sends command after previous data transfer ends                                                       |
|-----------------------|---|-------------------------------------------------------------------------------------------------------------------------------------|
| check_response_crc    | 1 | <ul><li>0- SD/MMC controller should not check<br/>response CRC</li><li>1- SD/MMC controller should check response<br/>CRC</li></ul> |

After writing to the CMD register, SD/MMC controller starts executing a command; when the command is sent to the bus, a command\_done interrupt is generated.

- 6. Software should look for data error interrupts; that is, for bits 7, 9, and 15 of the RINTSTS register. If required, software can terminate the data transfer by sending the STOP command.
- 7. 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.
- 8. 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 SD/MMC 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 RINTSTS register. A response to AUTO\_STOP is stored in RESP1 @0x34.

#### **Stream Read**

A stream read is like the block read mentioned in "Single-Block or Multiple-Block Read", except for the following bits in the Command register:

transfer\_mode = 1; //Stream transfer

 $cmd_index = CMD20;$ 

A stream transfer is allowed for only a single-bit bus width.

#### Stream Write

A stream write is exactly like the block write mentioned in "Single-Block or Multiple-Block Write", except for the following bits in the Command register:

transfer\_mode = 1;//Stream transfer

cmd index = CMD11;

In a stream transfer, if the byte count is 0, then the software must send the STOP command. If the bytecount is not 0, then when a given number of bytes completes a transfer, the SD/MMC controller sends the STOP command.

Completion of this AUTO\_STOP command is reflected by

theAuto\_command\_done interrupt. A response to an AUTO\_STOP is stored in the RESP1 register@0x34.

A stream transfer is allowed for only a single-bit bus width.

#### Sending Stop or Abort in Middle of Transfer

The STOP command can terminate a data transfer between a memory card and the SD/MMC 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. For information on sending this command, refer to "No-Data Command With or Without Response Sequence". 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 SD/MMC 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 SD/MMC controller sendthe 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.

This is a non-data command. For information on sending this command, refer to "No-Data Command With or Without Response Sequence". The command format for CMD52 is illustrated in Fig. 17-9:



Fig. 17-9 Command format for CMD52

a. Program the CMDARG register @0x28 with the appropriate command argument parameterslisted in Table 17-9.

|             |                  | <u> </u>                         |
|-------------|------------------|----------------------------------|
| CMDARG Bits | Contents         | Value                            |
| 31          | R/W flag         | 1                                |
| 30-28       | Function Number  | 0, for CCCR access               |
| 27          | RAW flag         | 1, if needed to read after write |
| 26          | Don't care       | -                                |
| 25-9        | Register address | 0x06                             |
| 8           | Don't care       | -                                |
| 7-0         | Write Data       | Function number to be aborted    |

Table 17-9 Parameters for CMDARG Registers

- Program the Command register using the command index as CMD52. Similar to the STOP command described, set bit 14 of the Command register (stop\_abort\_cmd) to 1, which must be done in order to inform the SD/MMC controller that the user aborted the data transfer. Reset bit 13 (wait\_prvdata\_complete) of the Command register to 0 in order to make the SD/MMC controller send the command at once, even though a data transfer is in progress.
- Wait for command transfer over.
- d. Check response (R5) for errors.

#### **Suspend or Resume Sequence**

In an SDIO card, the data transfer between an I/O function and the SD/MMC controller can betemporarily halted using the SUSPEND command; this may be



required in order to perform ahigh-priority data transfer with another function. When desired, the data transfer can be resumed using the RESUME command.

The following functions can be implemented by programming the appropriate bits in the CCCRregister (Function 0) of the SDIO card. To read from or write to the CCCR register, use the CMD52command.

- SUSPEND data transfer Non-data command.
  - a. Check if the SDIO card supports the SUSPEND/RESUME protocol; this can be done through the SBS bit in the CCCR register @0x08 of the
  - b. Check if the data transfer for the required function number is in process; the function number that is currently active is reflected in bits 0-3 of the CCCR register @0x0D. Note that if the BS bit (address 0xc::bit 0) is 1, then only the function number given by the FSx bits is valid.
  - To suspend the transfer, set BR (bit 2) of the CCCR register @0x0C.
  - d. Poll for clear status of bits BR (bit 1) and BS (bit 0) of the CCCR @0x0C. The BS (Bus Status) bit is 1 when the currently-selected function is using the data bus; the BR (Bus Release) bit remains 1 until the bus release is complete. When the BR and BS bits are 0, the data transfer from the selected function has been suspended.
  - During a read-data transfer, the SD/MMC controller can be waiting for the data from the card. If the data transfer is a read from a card, then the SD/MMC controller must be informed after the successful completion of the SUSPEND command. The SD/MMC controller then resets the data state machine and comes out of the wait state. To accomplish this, set abort\_read\_data (bit 8) in the Control register.
  - Wait for data completion. Get pending bytes to transfer by reading the TCBCNT register @0x5C.
- RESUME data transfer This is a data command.
  - a. Check that the card is not in a transfer state, which confirms that the bus is free for data transfer.
  - b. If the card is in a disconnect state, select it using CMD7. The card status can be retrieved in response to CMD52/CMD53 commands.
  - Check that a function to be resumed is ready for data transfer; this can be confirmed by reading the RFx flag in CCCR @0x0F. If RF = 1, then the function is ready for data transfer.
  - d. To resume transfer, use CMD52 to write the function number at FSx bits (0-3) in the CCCR register @0x0D. Form the command argument for CMD52 and write it in CMDARG @0x28; bit values are listed in Table 17-10.

| Table 17-10 | <b>CMDARG</b> | Bit Valu | es |
|-------------|---------------|----------|----|
|             |               |          |    |

| CMDARG Bits | Contents         | Value                         |
|-------------|------------------|-------------------------------|
| 31          | R/W flag         | 1                             |
| 30-28       | Function Number  | 0, for CCCR access            |
| 27          | RAW flag         | 1, read after write           |
| 26          | Don't care       | -                             |
| 25-9        | Register address | 0x0D                          |
| 8           | Don't care       | -                             |
| 7-0         | Write Data       | Function number to be resumed |

- e. Write the block size in the BLKSIZ register @0x1C; data will be transferred in units of this block size.
- Write the byte count in the BYTCNT register @0x20. This is the total size of the data; that is, the remaining bytes to be transferred. It is the responsibility of the software to handle the data.



- g. Program Command registers; similar to a block transfer. For details, refer to "Single-Block or Multiple-Block Read" and "Single-Block or Multiple-Block Write".
- h. When the Command register is programmed, the command is sent and the function resumes data transfer. Read the DF flag (Resume Data Flag). If it is 1, then the function has data for the transfer and will begin a data transfer as soon as the function or memory is resumed. If it is 0, then the function has no data for the transfer.
- If the DF flag is 0, then in case of a read, the SD/MMC Host Controller waits for data. After the data timeout period, it gives a data timeout error.

#### **Read Wait Sequence**

Read\_wait is used with only the SDIO card and can temporarily stall the data transfer- either fromfunction 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 SD/MMC 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 thisbit.
- 2. If the card supports the read\_wait signal, then assert it by setting the read\_wait (bit 6) in the CTRLregister @0x00.
- 3. Clear the read\_wait bit in the CTRL register.

## Controller/DMA/FIFO Reset Usage

Communication with the card involves the following:

- Controller Controls all functions of the SD/MMC controller.
- FIFO Holds data to be sent or received.
- DMA If DMA transfer mode is enabled, then transfers data between system memory and the FIFO.
- Controller reset Resets the controller by setting the controller reset bit (bit 0) in the 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 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.
- DMA reset Resets the internal DMA controller logic by setting the dma reset bit (bit 2) in the CTRL register, which abruptly terminates any DMA transfer in process. Since this reset bit is self-clearing, after issuing the reset, wait until this bit is cleared.

The following are recommended methods for issuing reset commands:

- Non-DMA transfer mode Simultaneously sets controller\_reset and fifo reset; clears the RAWINTS register @0x44 using another write in order to clear any resultant interrupt.
- DMA mode Sets controller reset and fifo reset; waits until dma reg goes inactive (the Status register indicates the value of this signal). Resets the FIFO again. Clears the interrupts by clearing the RAWINTS register @0x44 using another write in order to clear any resultant interrupt. You also need to reset and reprogram the channel(s) of the DMA controller that are



interfaced to the SD/MMC Host Controller.

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 underrun or overrun errors in the RAWINTS register caused by the DMA transfers after the FIFO was reset.

#### **Error Handling**

The SD/MMC controller implements error checking; errors are reflected in the RAWINTS register@0x44 and can be communicated to the software through an interrupt, or the software can poll forthese bits. Upon power-on, interrupts are disabled (int\_enable in the CTRL register is 0), and all theinterrupts are masked (bits 0-31 of the INTMASK register; default is 0).

# Error handling:

- Response and data timeout errors For response timeout, software can retry the command. Fordata timeout, the SD/MMC controller has not received the data start bit - either for the firstblock or the intermediate block - within the timeout period, so software can either retry the wholedata transfer again or retry from a specified block onwards. By reading the contents of the 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, theresponse 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 notfound, 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 ABORTcommand and retry the command for either whole data or partial data.
- Hardware locked error Set when the SD/MMC controller cannot load a command issued bysoftware. When software sets the start\_cmd bit in the CMD register, the SD/MMC controller tries to load the command. If the command buffer is already filled with a command, this error israised. The software then has to reload the command.
- FIFO underrun/overrun error If the FIFO is full and software tries to write data in the FIFO, thenan overrun error is set. Conversely, if the FIFO is empty and the software tries to read data from the FIFO, an underrun error is set. Before reading or writing data in the FIFO, the software shouldread the fifo\_empty or fifo\_full bits in the Status register.
- Data starvation by host timeout Raised when the SD/MMC controller is waiting for softwareintervention to transfer the data to or from the FIFO, but the software does not transfer within thestipulated timeout period. Under this condition and when a read transfer is in process, the softwareshould read data from the FIFO and create space for further data reception. When a transmitoperation is in process, the software should fill data in the FIFO in



order to start transferring datato the card.

CRC Error on Command – If a CRC error is detected for a command, the CE-ATA device does not end a response, and a response timeout is expected from the SD/MMC controller. The ATAlayer is notified that an MMC transport layer error occurred.

Notes: During a multiple-block data transfer, if a negative CRC status is received from thedevice, the data path signals a data CRC error to the BIU by setting the data CRC error bitin the RINTSTS register. It then continues further data transmission until all the bytes aretransmitted.

## 17.7.3 Programming SD/MMC Controller for Boot Operation

## **Boot Operation**



Fig. 17-10 Boot Operation

Fig. 17-10 illustrates timing for Boot operation.

Once the power and clocks are stable, reset\_n should be asserted (active-low) for at least two clocks of clk or cclk\_in, whichever is slower. The reset initializes the following:

- Registers
- **Ports**
- FIFO-pointers
- DMA interface controls
- State-machines in the design

After power-on reset, the software should perform the appropriate steps described in the following sections for the respective types of cards.

Following are the steps that the software driver must follow when working with eMMC cards for Boot operation.



Fig. 17-11 SD/MMC Controller Flow for Boot Operation

#### 1. The software driver is aware:

- That the card supports boot operation—BOOT\_PARTITION\_ENABLE bit set in the card.
- Of the BOOT\_SIZE\_MULT value in the card and the data bus width to use during boot operation—Extend CSD register byte[177] bit[0:1].

## 2. Set the following:

- Masks for interrupts by clearing appropriate bits in the Interrupt Mask register @0x024.
- Global int\_enable bit of the Control register @0x00.

It is recommended that you write 0xffff\_ffff to the Raw Interrupt register @0x044 and IDSTS @0x8C in order to clear any pending interrupts before



setting the int\_enable bit.

For Internal DMAC mode, the software driver needs to unmask all the relevant fields in the IDINTEN register.

- 3. Configure control register (CTRL):
  - int enable = 1'b1
  - Other fields should be 1'b0.
- 4. Change clock source assignment Set the card frequency to 400 KHz using the clock-divider and clock-source registers; for details, refer to "Clock Programming".
- 5. Set DataTimeOut = (10 \* ((TAAC \* Fop) + (100 \* NSAC)); this is NAC.
- 6. Program the BLKSIZ register with 0x200 (512 bytes).
- 7. Program the BYTCNT register with multiples of 128K bytes, as indicated by the BOOT\_SIZE\_MULT value in the card.
- 8. Program the Rx FIFO threshold value in bytes in the FIFOTH register @0x04C.Typically, the threshold value can be set to half the FIFO depth; that is, RX WMark = (FIFO DEPTH/2) - 1.
- Program the CMD register with the following fields:
  - start cmd = 1'b1
  - enable\_boot = 1'b1
  - enable\_boot\_ack depends on whether a start-acknowledge pattern is expected from the card
  - Card\_number = appropriate\_card\_number; obtained by referring to CDETECT register
  - Data\_expected = 1'b1
  - Remainder of CMD register fields = 1'b0
- 10. If enable\_boot\_ack = 1'b1, the software driver should start a timer after step #9; the terminal value is 50ms.
  - Before this timer elapses, the BAR interrupt should be received from the SD/MMC Controller. If this does not occur, the software driver must program the CMD register with the following fields:
    - start\_cmd = 1'b1
    - disable boot = 1'b1
    - $\blacksquare$  All other fields = 0

The SD/MMC Controller generates a Command Done (CD) interrupt after de-asserting the CMD line of the card.

- If the BAR interrupt is received, the software driver should clear this interrupt by writing a 1 to it. The software driver should then start another timer with a terminal value of 1 - 0.05 = 0.95 seconds. Before this timer elapses, the BDS interrupt should be received from the SD/MMC Controller. If this does not occur, the software driver must program the CMD register with the following fields:
  - start\_cmd = 1'b1
  - disable boot = 1'b1
  - $\blacksquare$  All other fields = 0



The SD/MMC Controller generates a Command Done (CD) interrupt after de-asserting the CMD line of the card.

- If the BDS interrupt is received, it indicates that the boot data is being received from the card. The software driver can then initiate a data read from the SD/MMC Controller based on the RXDR interrupt bit in the RINTSTS register. At the end of a successful boot data transfer from the card, the following interrupts are generated:
  - Command Done (CD) in RINTSTS register
  - Data Transfer Over (DTO) in RINTSTS register
- If an Error occurs in Boot Ack pattern (010) or an end bit Error occurs:
  - RTL automatically aborts boot by pulling CMD line high
  - RTL generates Command done interrupt
  - RTL does not generate BAR interrupt
  - Application aborts boot transfer
- If between data block transfers NAC is violated, DRTO (Data Read Timeout) is asserted. Apart from this, if there are errors associated with Start/End bits, SBE/EBE interrupts are also generated.
- 11. If enable boot ack = 1'b0, the software driver should start a timer after the step #9 where the terminal value is 1 second.
  - Before this timer elapses, a BDS interrupt should be received from the SD/MMC Controller. If this does not occur, the software driver must program the CMD register with the following fields:
    - $start\_cmd = 1'b1$
    - disable boot = 1'b1
    - $\blacksquare$  All other fields = 0

The SD/MMC Controller generates a Command Done (CD) interrupt after de-asserting the CMD line of the card.

If a BDS interrupt is received, it indicates that the boot data is being received from the card. The software driver can then initiate a data read from the SD/MMC Controller based on the RXDR interrupt bit in the RINTSTS register.

At the end of a successful boot data transfer from card, the following interrupts are generated.

- Command Done (CD) in RINTSTS.
- Data Transfer Over (DTO) in RINTSTS.

#### **Alternative Boot Operation**

The Alternative Boot Operation differs from the Boot Operation in that CMD0 is used to boot the card rather than holding down the CMD-line of the card. The Alternative Boot Operation can be done only if bit 0 in the extended CSD byte[228] (BOOT\_INFO) is set to 1.



# CMD1 RESP CMD2 RESP CMD3 RESP CMD0/Reset CMD DAT[0] Min 74 clocks required after power is stable to start boot

1. CMD0 with argument 0xFFFFFFFA

Fig. 17-12 Alternative Boot Opertation

Following are the steps that the software driver must follow when working with eMMC for the Alternative Boot operation.



Fig. 17-13 Host Controller Flow for Alternative Boot Mode

#### The software driver is aware:

- That the card supports the Alternative Boot operation—BOOT\_INFO bit is set in the card.
- Of the BOOT\_SIZE\_MULT value in the card and the data bus width to use during the boot operation—Extend CSD register byte[177] bit[0:1]..

# 2. Set the following:

- Masks for interrupts by clearing appropriate bits in the Interrupt Mask register @0x024
- Global int\_enable bit of the Control register @0x00 It is recommended that you write 0xffff\_ffff to the Raw Interrupt register @0x044 and IDSTS @0x8C in order to clear any pending interrupts



before setting the int enable bit.

For Internal DMAC mode, software driver needs to unmask all the relevant fields in IDINTEN register.

- 3. Configure control register (CTRL):
  - enable\_OD\_pullup = 1'b0
  - int enable = 1'b1
  - Other fields should be 1'b0
- 4. Changing clock source assignment Set the card frequency to 400 KHz using the clock-divider and clock-source registers; for details, refer to "Clock Programming". Ensure that the card clock—cclk out—is running.
- 5. Wait for a time that ensures that at least 74 card clock cycles have occurred on the card interface.
- 6. Set DataTimeOut = (10 \* ((TAAC \* Fop) + (100 \* NSAC)); this is NAC.
- 7. Program the BLKSIZ register with 0x200—512 bytes.
- 8. Program the BYTCNT register with multiples of 128K bytes, as indicated by the BOOT\_SIZE\_MULT value in the card.
- 9. Program the Rx FIFO threshold value in bytes in the FIFOTH register @0x04C.Typically, the threshold value can be set to half the FIFO depth; that is,  $RX_WMark = (FIFO_DEPTH/2) - 1$ .
- 10. Program CMDARG = 0xFFFFFFFA.
- 11. Program the CMD register with the following fields.
  - $start\_cmd = 1'b1$
  - boot mode = 1'b1
  - enable\_boot\_ack depends on whether a start-acknowledge pattern is expected from the card.
  - Card\_number appropriate\_card\_number, obtained by referring to CDETECT register
  - Data\_expected = 1'b1
  - Cmd index = 0
  - Remainder of CMD register fields = 1'b0
- 12. The software driver should wait for the Command Done (CD) interrupt.
- 13. If enable boot ack  $\neq$  1'b1 in step 11, the software driver should start a timer after the above step with a terminal value of 50ms.
  - Before this timer elapses, the BAR interrupt should be received from the SD/MMC Controller. If this does not occur, the software driver needs to infer that the start-pattern has not been received and should discontinue the boot process and start with normal enumeration.
  - If the BAR interrupt is received, the software driver should clear this interrupt by writing a 1 to it. The software driver should then start another timer with a terminal value of 1 - 0.05 = 0.95 seconds. Before this timer elapses, the BDS interrupt should be received from the SD/MMC Controller. If this does not occur, the software driver should discontinue the boot process and start with normal enumeration.
  - If the BDS interrupt is received, it indicates that the boot data is being received from the card. In non-IDMAC mode, the software driver can then initiate a data read from the SD/MMC Controller based on the RXDR interrupt bit in the RINTSTS register.
  - It is the responsibility of the software driver to terminate the boot operation by programming the SD/MMC Controller to send a CMD0 by programming the registers CMDARG = 0 and CMD = {start cmd = 1, card number = appropriate\_card\_number, cmd\_index = 0,  $all_other_fields = 0$ .



- At the end of a successful boot data transfer from the card, the following interrupts are:
  - Command Done (CD) in RINTSTS
  - Data Transfer Over (DTO) in RINTSTS
  - Receive Interrupt (RI) in IDSTS in IDMAC mode only
- If an Error occurs in Boot Ack pattern (010) or an end bit Error occurs:
  - RTL does not generate BAR interrupt
  - RTL detects Boot Data Start and generates BDS interrupt
  - RTL continues to receive Boot Data
  - Application must abort boot after receiving BDS interrupt
- If between data block transfers NAC is violated, DRTO (Data Read Timeout) is asserted. Apart from this, if there are errors associated with Start/End bits, SBE/EBE interrupts are also generated.
- 14. If enable\_boot\_ack = 1'b0 in step 11, the software driver should start a timer after step #11with a terminal value of 1 second.
  - Before this timer elapses, the BDS interrupt should be received from the SD/MMC Controller. If this does not occur, the software driver should discontinue the boot process and start with normal enumeration.
  - If the BDS interrupt is received, it indicates that the boot data is being received from the card. In non-IDMAC mode, the software driver can then initiate a data read from the SD/MMC Controller based on the RXDR (in RINTSTS) interrupt.
  - It is the responsibility of the software driver to terminate the boot operation by programming the SD/MMC Controller to send a CMD0 by programming the registers CMDARG = 0 and CMD = {start cmd=1,card number = appropriate card number, cmd index =0, rest of the fields =0}.
  - At the end of a successful boot data transfer from card, the following interrupts are generated.
    - Command Done (CD) in RINTSTS.
    - Data Transfer Over (DTO) in RINTSTS.
    - Receive Interrupt (RI) in IDSTS in IDMAC mode only.

## 17.7.4 Voltage Switching and DDR Operations

## **Voltage Switch Operation**

The Voltage Switch operation must be performed in SD mode only.



Fig. 17-14 Voltage Switching Command Flow Diagram

(stby)

CMD3

Card responds with new RCA

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 Figure 17-15.



Fig. 17-15 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 Figure 17-16.





Fig. 17-16 ACMD41 Response(R3)

- Bit 30 If set to 1'b1, card supports SDHC/SDXC; if set to 1'b0, card supports only SDSC
- Bit 24 If set to 1'b1, card supports voltage switching and is ready for the switch
- Bit 31 If set to 1'b1, initialization is over; if set to 1'b0, means initialization in process
- 4. If the card supports voltage switching, then the software must perform the steps discussed for either the "Voltage Switch Normal Scenario" or the "Voltage Switch Error Scenario".

## **Voltage Switch Normal Scenario**



Fig. 17-17 Voltage Switch Normal Scenario

- The host programs CLKENA—cclk\_low\_power register—with zero (0) for the corresponding card, which makes the host controller move to high-power mode. The application should start a timer with a recommended value of 2ms; this value of 2 ms is determined as below:Total clk required for CMD11 = 48 clks Total clk required for RESP R1 = 48 clks Maximum clk delay between MCD11 end to start of RESP1 = 60 clks Total = 48+48 + 60 = 160Minimum frequency during enumeration is 100KHz; that is, 10us Total time =  $160 * 10us = 1600us = 1.6ms \sim 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 CLKENA

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.

- 5. Program the CLKENA, cclk\_enable register, with 0 for the corresponding card; the host stops supplying SDCLK.
- 6. Program VOLT REG to the required values for the corresponding card. The application must program the newly-defined VOLT REG register to assign 1 for the bit corresponding to the card number. The application should start a timer > 5ms.
- 7. After the 5ms timer expires, the host voltage regulator is stable. Program CLKENA, cclk enable register, with 1 for the corresponding card; the host starts providing SDCLK at 1.8V; this can be at zero time after VOLT REG has been programmed. When the CLKENA register is programmed, the application should start another timer > 1ms.
- 8. 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).
- 9. 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.
- 10. 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

If the timer expires without the voltage switch interrupt (VOLT\_SWITCH\_INT), a power cycle should be performed. Program the 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.

## **Voltage Switch Error Scenario**





Fig. 17-18 Voltage Switch Error Scenario

- 1. If the interrupt (VOLT SWITCH INT) does not come, then the 2 ms timer should time out and a power cycle should be initiated. Note: Before performing a power cycle, switch off the card clock by programming 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 Figure 17-17, 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 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) in Figure 7-18.

- 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
  - If switching is not complete, the 1ms timer expires, and the card clk 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.

#### **DDR Operation**

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 VOLT\_REG 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 VOLT\_REG[31:16] register with a value of 1'b1.

- The bit that the user programs depends on which card is to be accessed in DDR mode.
- 2. To move back to SDR mode, a power cycle should be run on the card—putting the card in SDR12 mode—and only then should VOLT\_REG[31:16] be set back to 1'b0 for the appropriate card.

## 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.
  - When CMD0 is received, the card changes from DDR50 to SDR12.
- 2. Program the CLKDIV register with an appropriate value.
- 3. Set DDR REGto 0.

Note: The VOLT REG 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.

#### 17.7.5 H/W Reset Operation

When the RST in signal goes low, the card enters a pre-idle state from any state other than the inactive state.

## **H/W Reset Programming Sequence**

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- CTRL[2]
  - FIFO reset CTRL[1] bits

Note: The above steps are required only if a transfer is in process.

- 4. Program the CARD\_RESET 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 us or cclk\_in period, which ever is greater
- 6. After a minimum of 1 µs, the application should program a value of 0 into the CARD RESET 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 µs after the de-assertion of the RST in 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.

## **Chapter 18 Embedded SRAM**

## 18.1 Overview

The Embedded SRAM is the AXI slave device, which support read and write access to provide system fast access data storage.

#### 18.1.1 Features supported

- Provide 64KB access space
- Support security and non-security access
- Security or non-security space is software programmable
- Security space is 0KB,4KB,8KB,12K,16K, 20K, 24K, 28K, 32K, 36K, 40K, 44K, 48K, 52K, 56K, 60K, 64K (the whole memory space)
- Support 64bit AXI bus

## 18.1.2 Features not supported

- Don't support AXI lock transaction
- Don't support AXI exclusive transaction
- Don't support AXI cache function
- Don't support AXI protection function

## 18.2 Block Diagram



Fig. 18-1 Embedded SRAM block diagram

# **18.3 Function Description**

## 18.3.1 TZMA

Please refer to 5.3.3 for TZMA functional description.

#### 18.3.2 AXI slave interface

The AXI slave interface is bridge which translate AXI bus access to SRAM interface.

18.3.3 Embedded SRAM access path

The Embedded SRAM can only be accessed by Cortex-A9 and DMACO.

## **Chapter 19 GPU (Graphics Process Unit)**

## 19.1 Overview

The gpu is a hardware accelerator for 2D and 3D graphics systems. Its triangle rate can be 30 Mtris/s , pixel rate can be 1Gpix/s.

The GPU supports the following graphics standards:

- OpenGL ES 2.0
- OpenGL ES 1.1
- OpenVG 1.1

The GPU consists of:

- Four Pixel Processors (PPs)
- a geometry Processor (GP)
- a Level2 Cache controller (L2)
- a Memory Management Unit (MMU) for each GP and PP included in the GPU

The GPU contain a 64-bit APB bus and an 128-bit AXI bus. CPU config GPU through APB bus, GPU read and write data through AXI bus.

For detailed information about GPU(graphics process unit), please refer to **RK30xx GPU.pdf**。

# Chapter 20 VCODEC (Video encoder and decoder Unit)

## 20.1 Overview

VCODEC is composed of video decoder and video encoder. VCODEC is connected to VCODEC\_AHB bus through an AHB slave and VCODEC\_AXI through an AXI master. The register setting is configured through the AHB slave interface and the stream data is read and written through the AXI master interface.

Video decoder and video encoder share many internal memories and they also share the bus master and slave interfaces. So it prevents video decoder and video encoder from working simultaneously. Encoding and decoding now have to time-share the memory resource on a frame by frame basis.

For detailed information about VCODEC, please refer to **RK30xx VCODEC.pdf**.

## **Chapter 21 IPP (Image Post Processor)**

## 21.1 Overview

Image Post Processing (IPP) is used doing image scaler, deinterlace and rotation. Each processing can be done independently or combined with others.

## 21.1.1 Features

## ♦ Input data format

RGB888: 16x16 to 8191x8191RGB565:16x16 to 8191x8191

YUV422/YUV420: 16x16 to 8190x8190

• YUV444:16x16 to 8190x8190

#### **♦** Pre Scaler

- Down-scaling
- Integral scaling ratio, from 1/8 to 1/2
- Linear filter
- Deinterlace

#### **♦** Post Scaler

- Down-scaling and up-scaling
- Arbitrary non-integer scaling ratio, from 1/2 to 4
- 4-tap vertical, 2-tap horizontal filter
- The max output image width of post scaler is 4096

## **♦** Rotation

- 90-degree, 180-degree, 270-degree ratation
- x-mirror, y-mirror

For detailed information about IPP(Image Post Processor), please refer to **RK30xx IPP.pdf**.

## **Chapter 22 LCDC**

## 22.1 Overview

LCD Controller is the display interface from memory frame buffer to display device(LCD panel or TV set). LCDC is connected to LCDC\_AHB bus through an AHB slave and DISP\_AXI bus through an AXI master. The register setting is configured through the AHB slave interface and the display frame data is read through the AXI master interface.

There are two symmetrical LCDCs in SOC for dual panel display application.

#### 22.1.1 Features

## **♦** Display interface

- Parallel RGB LCD Interface: 24-bit(RGB888), 18-bit(RGB666), 15-bit(RGB565)
- Serial RGB LCD Interface: 3x8-bit(RGB delta support), 3x8-bit + dummy, 16-bit + 8-bit
- MCU LCD interface: i-8080(up to 24-bit RGB), Hold/Auto/Bypass modes
- TV Interface: ITU-R BT.656(8-bit, 480i/576i/1080i)

## **♦** Display process

- Background layer: programmable 24-bit color
- Win0 layer:
  - RGB888, ARGB888, RGB565, YCbCr422, YCbCr420, AYCbCr
  - Maximum resolution is 1920x1080, support virtual display
  - 1/8 to 8 scaling-down and scaling-up engine
  - 256 level alpha blending
  - Transparency color key
  - 3D display support
- Win1 layer:
  - RGB888, ARGB888, RGB565, YCbCr422, YCbCr420, AYCbCr
  - Maximum resolution is 1920x1080, support virtual display
  - 1/8 to 8 scaling-down and scaling-up engine
  - 256 level alpha blending
  - Transparency color key
- Win2 layer:
  - 1/2/4/8bpp, RGB888, ARGB888, RGB565
  - Support virtual display
  - 256 level alpha blending
  - Transparency color key
- Hardware cursor:
  - 2bpp
  - Two size mode: 32x32 and 64x64
  - 3-color and transparentmode
  - 2-color + transparency + tran\_invert mode
  - 16 level alpha blending



#### **Others**

- 3 x 256 x 8 bits display LUTs
- Win0 layer and Win1 layer overlay exchangeable
- De-flicker support for interlace output
- YCbCr2RGB(rec601-mpeg/rec601-jpeg/rec709) and RGB2YCbCr modules
- Replication(16-bit to 24-bit) and Dithering(24-bit to 16-bit/18-bit)
- Blank and black display
- Standby mode
- Auto dynamic power control

## 22.2 Block Diagram



Fig. 22-1LCDC Block Diagram



Fig. 22-2LCDC Dual LCDCs in SOC

## 22.3 Function Description

#### 22.3.1 Data Format

LCDC master read the frame data from the frame buffer in the system memory (SDR or DDR). There are total 10 formats supported in three layers.

- Win0: RGB888,ARGB888, RGB565, YCbCr422, YCbCr420, YCbCr444
- Win1: RGB888, ARGB888, RGB565, YCbCr422, YCbCr420, YCbCr444
- Win2: 1bpp, 2bpp, 4bpp, 8bpp, RGB888, ARGB888, RGB565
- Hwc: 2bpp



Fig. 22-3LCDC Frame Buffer Data Format

|      | D[31:24] | D[23:16] | D[15:8] | D[7:0] |
|------|----------|----------|---------|--------|
| 000H | P1       | P2       | P3      | P4     |
| 004H | P5       | P6       | P7      | P8     |
| 008H | P9       | P10      | P11     | P12    |
|      |          |          |         |        |



|      | D[31:28] | D[27:24] | D[23:20] | D[19:16] | D[15:12] | D[11:8] | D[7:4] | D[3:0] |
|------|----------|----------|----------|----------|----------|---------|--------|--------|
| 000H | P1       | P2       | P3       | P4       | P5       | P6      | P7     | P8     |
| 004H | P9       | P10      | P11      | P12      | P13      | P14     | P15    | P16    |
| 008H | P17      | P18      | P19      | P20      | P21      | P22     | P23    | P24    |
|      |          |          |          |          |          |         |        |        |

Fig. 22-4LCDC Win2 Palette (8bpp/4bpp)



Fig. 22-5LCDC Hwc Data Format

Table 22-1Hwc 3-color Transparency Mode

| Data[1:0] | Display Pixel color |
|-----------|---------------------|
| 00        | Cusor color 0       |
| 01        | Cusor color 1       |
| 10        | Cusor color 2       |
| 11        | Transparent         |

Table 22-2Hwc 2-color Transparency Mode

| Data[1:0] | Display Pixel color  |
|-----------|----------------------|
| 00        | Cusor color 0        |
| 01        | Cusor color 1        |
| 10        | Transparent          |
| 11        | Inverted-Transparent |

## **Data SWAP function**

There are several data-swap modes for flexible application. The register is LCDC\_SYS\_CTRL1[29:19].

All the data swap types are in the following table.

Table 22-3LCDC Data Swap of Win0, Win1 and Win2

| Data-swap | RB   | Alpha | Y-M8 | CbCr | Big-endian/Little-endian |
|-----------|------|-------|------|------|--------------------------|
|           | swap | swap  | swap | swap |                          |
| Win0      | yes  | yes   | yes  | yes  | No                       |
| Win1      | yes  | yes   | yes  | yes  | No                       |
| Win2      | yes  | yes   | No   | No   | yes                      |



## 22.3.2 Virtual display

Virtual display is supported in Win0, Win1 and Win2. The active image is part of the virtual (original) image in frame buffer memory. The virtual width is indicated by setting WIN0/WIN1/WIN2\_VIR\_STRIDE for different data format.

The virtual stride should bemultiples of word (32-bit). That means dummy bytes in the end of virtual line if the real pixels are not 32-bit aligned.



Fig. 22-6LCDC Virtual Display Mode

## 22.3.3 Scaling

The scaling operation is the imageresizing processof data transfer from the frame buffer memory toLCD panel or TV set.

The scaling units in layer Graphic (Win1) and layer Video (Win0) are independent. So Win0 and Win1's scaling can be enabled simultaneously.

Horizontal and vertical scaling factor should be set according the window scaling ratio.

## 1. Scaling factor

Because the chroma data may have different sampling rate with Luma data in the memory format of YCbCr422/YCbCr420. The scaling factor of Win0 has two couples of factor registers:

Software calculates the scaling factor value using thefollowing equations:

$$y_rgb_vertical_factor = (\frac{LCDC_WIN0\_ACT\_INFO[31:16]}{LCDC_WIN0_DSP_INFO[31:16]}) \times 2^{12}$$

$$y\_rgb\_horizontal\_factor = (\frac{LCDC\_WIN0\_ACT\_INFO[15:0]}{LCDC\_WIN0\_DSP\_INFO[15:0]}) \times 2^{12}$$

$$yuv422\_yuv444\_Cbr\_vertical\_factor = (\frac{LCDC\_WIN0\_ACT\_INFO[31:16]}{LCDC\_WIN0\_DSP\_INFO[31:16]}) \times 2^{12}$$

$$yuv420\_Cbr\_vertical\_factor = (\frac{LCDC\_WIN0\_ACT\_INFO[31:16]/2}{LCDC\_WIN0\_DSP\_INFO[31:16]}) \times 2^{12}$$

$$yuv444 \_Cbr\_horizontal\_factor = (\frac{LCDC\_WIN0\_ACT\_INFO[15:0]}{LCDC\_WIN0\_DSP\_INFO[15:0]}) \times 2^{12}$$

$$yuv422\_yuv420\_Cbr\_horizontal\_factor = (\frac{LCDC\_WIN0\_ACT\_INFO[15:0]/2}{LCDC\_WIN0\_DSP\_INFO[15:0]}) \times 2^{12}$$

## 2. Scaling start point offset

The x and y start point of the generated pixels can be adjusted, the offset value is in the range of 0 to 0.99.



Fig. 22-7LCDC Scaling Down Offset



Fig. 22-8LCDC Scaling Up Offset

| scaling down/up start     | Offset variable       | Register                |
|---------------------------|-----------------------|-------------------------|
| point offset              |                       |                         |
| Win0 YRGB                 | Win0_YRGB_vscl_offset | Win0_SCL_OFFSET [32:24] |
| vertical scaling offset   |                       |                         |
| Win0 YRGB                 | Win0_YRGB_hscl_offset | Win0_SCL_OFFSET [23:16] |
| horizontal scaling offset |                       |                         |
| Win0 Cbr                  | Win0_CBR_vscl_offset  | Win0_SCL_OFFSET [15:8]  |
| vertical scaling offset   |                       |                         |
| Win0 Cbr                  | Win0_CBR_hscl_offset  | Win0_SCL_OFFSET [7:0]   |
| horizontal scaling offset |                       | • • • •                 |

Table 22-4LCDC Scaling Start Point Offset Registers

## 3. De-flicker (Interlace vertical filtering)

It is necessary to display a non-interlaced video signal on an interlaced display (such as TV set). Thus some from of"non-interlaced-to-interlaced conversion" may be required.

The easiest approach is to throw away every other active scan line in each non-interlaced frame. Although the cost is minimal, there are problems with this approach. If there is a sharp vertical transition of color or intensity. It will flicker at one-half the refresh rate.

A better solution is to use two lines of non-interlaced data to generation one line of interlace data. Fast vertical transitions are smoothed out over several interlace lines.

The vertical filtering of two non-interlaced lines can be done by enabling the vertical scaling offset dynamic change in different field (even/odd). The dynamic change value of scaling offset is half of the scaling factor. You should enable the scaling down vertical offset in scaling down mode; enable the scaling up vertical offset in scaling up mode, or one of it in no-scaling mode.



Fig. 22-9LCDC Interlace Vertical Filtering

#### 22.3.4 3D-display

3D-display is supported in Win0 layer. There are two modes: MIX mode and Interleave mode.

3D-display merges two source images into one screen. Both images have same data format, source information (win0\_vir\_stride, win0\_act\_width, win0\_act\_height) and display information (dsp\_win0\_width, dsp\_win0\_height, dsp\_win0\_st). The second image's start address should be set in 3D-display mode.

Interlace display is not support in win0 3D-display mode.

## 1. MIX mode

There are three types of MIX 3D-display: R-GB color mix, G-RB color mix and B-RG color mix.

The scaling for two images is done individually if necessary. The scaling factor is same for two images.

For RGB format, the factor scaling setting is the same with win0 non-3D mode. For YUV format, image reading data would be duplicated to YUV444 format before RGB color mix, so the cbr scaling factor setting should be the same with yrgb scaling factor.





Fig. 22-10LCDC Mix 3D Display

## 2. Interlace mode

There are two types of interlace 3D-display: H-interlace and V-interlace.

The scaling for two images is done individually if necessary. The scaling factor is same for two images.

In H-interlace mode, the display width of each image is half of the final display width. So the display width value for horizontal scaling factor calculation should be halved.

In V-interlace mode, the display height of each image is half of the final display height. So the display height value for vertical scaling factor calculation should be halved.



Fig. 22-11LCDC Interleave 3D Display



## 22.3.5 Overlay



Fig. 22-12LCDC Overlay Block Diagram

## 1. Overlay display

There are totally 5 layers for overlay display: Background, Win0, Win1, Win2 and Hwc.

The background is a programmable solid color layer, which is always the bottom of the display screen.

Hwc is a 32x32 or 64x64 3-LUT-colors layer, which is on the top layer of the display screen.

The two middle layers are Win0 and Win1. Win1 is on the top of Win0 in default setting, setting LCDC\_DSP\_CTRL\_REG0[8] to '1' can let Win0 be on the top of Win1.





Fig. 22-13LCDC Overlay Display

## 2. Transparency color key

There are three transparency color keys Win0/Win1/Win2 layer. The two transparency color keycan be active at the same time.

The pixel color value is compared to the transparency color key before final display. The transparency color key value defines the pixel data considered asthe transparent pixel. The pixel values with the source color key value are pixels not visibleon the screen, and the under layer pixel values or solid background color are visible.

Transparency color key is done after the scaling module and before the YCbCr2RGB color space converter. So transparency color key can only be used in non-scaling mode.





Fig. 22-14LCDC Transparency Color Key

## 3. Alpha Blending

There are four alpha values for blending between five overlay layers: alpha\_win0[7:0], alpha\_win1[7:0], alpha\_win2[7:0], alpha\_hwc[3:0].

Two blending modes are supported. One is per-pixel (ARGB) mode; the other is user-specified mode. In ARGB mode, the alpha value is in the ARGB data (Win0 Win1 and Win2 normal mode only). In user-specified mode, the alpha value comes from the register (LCDC\_ALPHA\_CTRL[31: 4]).

In HWC layer, if the data of the hwc pixel is 2'b00, then this pixel is transparent (alpha = 0), regardless the alpha setting of alpha value.





Win0 on top



Fig. 22-15LCDC Alpha blending

## 4. Replication and Dithering

If the interface data bus is wider than the pixelformat size, by programming the pixel components replication active/inactive, the MSB is replicated to the LSB of the interface data bus or the LSB is filled with 0s.



Fig. 22-16LCDC Replicaiton



Dithering is an intentionally applied form of noise, used to randomize quantization error, thereby preventing large-scaling patterns such as "banding".

The pixel values are used by Dithering logic todisplay the data in a lower color depth on the LCD panel. The Dithering algorithm is based on the (x,y) pixel position and the value of removed bits. The picture qualityis improved when enabling the Dithering logic. When Dithering is notenabled, the MSBs of the pixel color components are output on the interface data bus if theinterface data bus is smaller than the pixel format size.



Fig. 22-17LCDC Dithering

## 22.4 Register Description

## 22.4.1 Register Summary

| Name                | Offset |   | Value      | Description                   |
|---------------------|--------|---|------------|-------------------------------|
| LCDC_SYS_CTRL0      | 0x0000 | W | 0×00000000 | LCDC system control register0 |
| LCDC_SYS_CTRL1      | 0x0004 | W | 0×00000000 | LCDC system control register1 |
| LCDC_DSP_CTRL0      | 0x0008 | W | 0×00000000 | Display control register0     |
| LCDC_DSP_CTRL1      | 0x000c | W | 0×00000000 | Display control register1     |
| LCDC_INT_STATUS     | 0x0010 |   | 0x00000000 | Interrupt status register     |
| LCDC_MCU_CTRL       | 0x0014 | W | 0x00711c08 | MCU mode control register     |
| LCDC_BLEND_CTRL     | 0x0018 | W | 0x00000000 | Blending control register     |
| LCDC_WIN0_COLOR_KEY | 0x001c | W | 0x00000000 | Win0 color key register       |
| LCDC_WIN1_COLOR_KEY | 0x0020 | W | 0×00000000 | Win1 color key register       |



| Name                      | Offset | Size | Reset<br>Value | Description                              |
|---------------------------|--------|------|----------------|------------------------------------------|
| LCDC_WIN2_COLOR_KEY       | 0x0024 | W    | 0x00000000     | Win2 color key register                  |
| LCDC_WIN0_YRGB_MST0       | 0x0028 | W    | 0x00000000     | Win0 YRGB<br>memory start<br>address 0   |
| LCDC_WIN0_CBR_MST0        | 0x002c | W    | 0x00000000     | Win0 Cbr<br>memory start<br>address 0    |
| LCDC_WIN0_YRGB_MST1       | 0×0030 | W    | 0×00000000     | Win0 YRGB<br>memory start<br>address 1   |
| LCDC_WIN0_CBR_MST1        | 0x0034 | W    | 0×00000000     | Win0 Cbr<br>memory start<br>address 1    |
| LCDC_WIN0_VIR             | 0x0038 | W    | 0×00000140     | Win0 virtual<br>display width            |
| LCDC_WIN0_ACT_INFO        | 0x003c | W    | 0x00ef013f     | Win0 active<br>window<br>width/height    |
| LCDC_WIN0_DSP_INFO        | 0x0040 | W    | 0x00ef013f     | Win0 display<br>width/height on<br>panel |
| LCDC_WIN0_DSP_ST          | 0x0044 | W    | 0×00000000     | Win0 display start point on panel        |
| LCDC_WIN0_SCL_FACTOR_YRGB | 0x0048 | W    | 0x10001000     | Win0 YRGB scaling factor                 |
| LCDC_WIN0_SCL_FACTOR_CBR  | 0x004c | W    | 0x10001000     | Win0 Cbr scaling factor                  |
| LCDC_WIN0_SCL_OFFSET      | 0x0050 | W    | 0×00000000     | Win0 scaling start point offset          |
| LCDC_WIN1_YRGB_MST        | 0x0054 | W    | 0×00000000     | Win1 YRGB<br>memory start<br>address     |
| LCDC_WIN1_CBR_MST         | 0x0058 | W    | 0×00000000     | Win1 Cbr<br>memory start<br>address      |
| LCDC_WIN1_VIR             | 0x005c | W    | 0x00000140     | Win1 virtual<br>display width            |
| LCDC_WIN1_ACT_INFO        | 0×0060 | W    | 0x00ef013f     | Win1 active<br>window<br>width/height    |
| LCDC_WIN1_DSP_INFO        | 0x0064 | W    | 0x00ef013f     | Win1 display<br>width/height on<br>panel |
| LCDC_WIN1_DSP_ST          | 0x0068 | W    | 0×00000000     | Win1 display start point on panel        |
| LCDC_WIN1_SCL_FACTOR_YRGB | 0x006c | W    | 0×10001000     | Win1 YRGB<br>scaling factor              |
| LCDC_WIN1_SCL_FACTOR_CBR  | 0x0070 | W    | 0×10001000     | Win1 Cbr scaling factor                  |



| Name                    | Offset | Size | Reset<br>Value | Description                                                |
|-------------------------|--------|------|----------------|------------------------------------------------------------|
| LCDC_WIN1_SCL_OFFSET    | 0x0074 | W    | 0x00000000     | Win1 scaling start point offset                            |
| LCDC_WIN2_MST           | 0x0078 | W    | 0×00000000     | Win2 memory start address                                  |
| LCDC_WIN2_VIR           | 0x007c | W    | 0x00000140     | Win2 virtual display width                                 |
| LCDC_WIN2_DSP_INFO      | 0×0080 | W    | 0x00ef013f     | Win2 display<br>width/height on<br>panel                   |
| LCDC_WIN2_DSP_ST        | 0x0084 | W    | 0×00000000     | Win2 display start point on panel                          |
| LCDC_HWC_MST            | 0x0088 | W    | 0x00000000     | Hwc memory start address                                   |
| LCDC_HWC_DSP_ST         | 0x008c | W    | 0x00000000     | Hwc display start point on panel                           |
| LCDC HWC COLOR LUTO     | 0x0090 | W    | 0x00000000     | Hwc LUT color 0                                            |
| LCDC HWC COLOR LUT1     | 0x0094 |      |                | Hwc LUT color 1                                            |
| LCDC HWC COLOR LUT2     | 0x0098 |      |                | Hwc LUT color 2                                            |
| LEBE_HWE_EGEOR_EGT2     | 0,0000 | V V  | 00000000       | Panel scanning                                             |
| LCDC_DSP_HTOTAL_HS_END  | 0x009c | w    | 0x014a000a     | horizontal width<br>and hsync pulse<br>end                 |
| LCDC_DSP_HACT_ST_END    | 0x00a0 | W    | 0x014a000a     | Panel active horizontal scanning start point and end point |
| LCDC_DSP_VTOTAL_VS_END  | 0x00a4 | W    | 0x00fa000a     | Panel scanning vertical height and vsync pulse end point   |
| LCDC_DSP_VACT_ST_END    | 0x00a8 | w    | 0x00fa000a     | Panel active vertical scanning start point and end point   |
| LCDC_DSP_VS_ST_END_F1   | 0x00ac | W    | 0x00000000     | Vsync start point and end point of filed1                  |
| LCDC_DSP_VACT_ST_END_F1 | 0x00b0 | W    | 0×00000000     | Vertical active<br>start point and<br>end point of filed1  |
| LCDC_REG_LOAD_EN        | 0x00c0 | W    | 0×00000000     | Register config<br>done flag                               |
| LCDC_MCU_BYPASS_WPORT   | 0×0100 | W    | 0x00000000     | LCDC MCU<br>bypass mode<br>data write port                 |
| LCDC_MCU_BYPASS_RPORT   | 0×0200 | W    | 0x00000000     | LCDC MCU<br>bypass mode<br>data read port                  |



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

## 22.4.2 Detail Register Description

## LCDC\_SYS\_CTRL0

Address: Operational Base + offset (0x0000)

LCDC system control register0

| LCDC system control register0 |      |             |                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------------------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                           | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                              |
| 31:3                          | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 2                             | RW   | 0x0         | hwc_load_en hardware cursor data reload enable 0 : disable 1 : enable *Setting this bit would reload the Hwc data. It would be auto cleared after reload finish.                                                                                                                                                                                                                                                         |
| 1                             | RW   | 0x0         | Icdc_standby_mode LCDC standby mode Writing "1" to turn LCDC into standby mode, all the layer would disable and the data transfer from frame buffer memory would stop at the end of current frame. The output would be blank. When writing "0" to this bit, standby mode would disable and the LCDC go back to work immediately. 0: disable 1: enable * Black display is recommended before setting standby mode enable. |
| 0                             | RW   | 0x0         | Icdc_dma_stop_mode LCDC DMA stop mode 0 : disable 1 : enable * If DMA is working, the stop mode would not be active until current bus transfer is finished.                                                                                                                                                                                                                                                              |

## LCDC\_SYS\_CTRL1

Address: Operational Base + offset (0x0004)

LCDC system control register1

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|



| Bit | Attr | Reset Value | Description                                                                                                                                              |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31  | RW   | 0x0         | dsp_lut_en Display LUT ram enable 0: disable 1: enable *This bit should be '0' when CPU updates the LUT, and should be '1' when Display LUT mode enable. |
| 30  | RW   | 0×0         | win2_lut_ram_en Win2 LUT ram enable 0: disable 1: enable *This bit should be '0' when CPU updates the LUT, and should be '1' when Win2 LUT mode enable.  |
| 29  | RW   | 0×0         | win2_endian_sel Win2 8pp palette data Big-endian/ Little-endian select 0: Big-endian 1: Little-endian                                                    |
| 28  | RW   | 0×0         | win2_alpha_swap<br>Win2 RGB alpha swap<br>0: ARGB<br>1: RGBA                                                                                             |
| 27  | RW   | 0×0         | win2_rb_swap<br>Win2 RGB Red and Blue swap<br>0: RGB<br>1: BGR                                                                                           |
| 26  | RW   | 0x0         | win1_uv_swap Win1 CbCr swap 0: CrCb 1: CbCr                                                                                                              |
| 25  | RW   | 0x0         | win1_y8_swap<br>Win1 Y middle 8-bit swap<br>0: Y3Y2Y1Y0<br>1: Y3Y1Y2Y0                                                                                   |
| 24  | RW   | 0x0         | win1_alpha_swap<br>Win1 RGB alpha swap<br>0: ARGB<br>1: RGBA                                                                                             |
| 23  | RW   | 0×0         | win1_rb_swap<br>Win1 RGB Red and Blue swap<br>0: RGB<br>1: BGR                                                                                           |
| 22  | RW   | 0×0         | win0_uv_swap<br>Win0 CbCr swap<br>0: CrCb<br>1: CbCr                                                                                                     |
| 21  | RW   | 0x0         | win0_y8_swap<br>Win0 Y middle 8-bit swap<br>0: Y3Y2Y1Y0<br>1: Y3Y1Y2Y0                                                                                   |



| Bit      | Attr | Reset Value | Description                            |
|----------|------|-------------|----------------------------------------|
|          |      |             | win0_alpha_swap                        |
| 20       | DW   | 0.40        | Win0 RGB alpha swap                    |
|          | RW   | 0x0         | 0: ARGB                                |
|          |      |             | 1: RGBA                                |
|          |      |             | win0_rb_swap                           |
|          |      |             | Win0 RGB Red and Blue swap             |
| 19       | RW   | 0x0         | 0: RGB                                 |
|          |      |             | 1: BGR                                 |
|          |      |             | win0_3d_mode                           |
|          |      |             | Win0 3D mode                           |
|          |      |             | 000: MIX mode, R-GB                    |
| 18:16    | RW   | 0x0         | 001: MIX mode, G-RB                    |
| 10.10    | 1244 | OXO         | 010: MIX mode, B-RG                    |
|          |      |             | 100: Interleave mode, horizontal       |
|          |      |             | 101: Interleave mode, Vertical         |
|          |      |             | win0_3d_en                             |
|          |      |             | Win0_3d_en                             |
| 15       | RW   | 0x0         | 0: Win0 3D mode en                     |
|          |      |             |                                        |
|          |      |             | 1: Win0 3D-display mode enable         |
|          |      |             | hwc_size                               |
| 14       | RW   | 0x0         | Hwc size select                        |
|          |      |             | 0: 32x32                               |
|          |      |             | 1: 64x64                               |
|          |      |             | hwc_mode                               |
| 13       | RW   | 0x0         | Hwc color mode                         |
|          |      | -           | 0: normal color mode                   |
|          |      |             | 1: reversed color mode                 |
|          |      |             | win2_fmt<br>Win2 source Format         |
|          |      |             |                                        |
|          |      | . ()        | 3'b000 : ARGB888<br>3'b001 : RGB888    |
| 12:10    | RW   | 0x0         | 3'b010: RGB666<br>3'b010: RGB565       |
| 12.10    | KVV  | UXU         |                                        |
|          |      |             | 3'b100: 8bpp<br>3'b101: 4bpp           |
|          |      | ( ) 7       | 3'b101: 4bpp<br>3'b110: 2bpp           |
|          | 11   |             | 3'b111: 1bpp                           |
|          |      |             | win1 fmt                               |
|          |      |             | Win1_nnt<br> Win1 source data Format   |
|          |      |             | 3'b000 : ARGB888                       |
|          |      |             | 3'b001 : RGB888                        |
| 9:7      | RW   | 0x0         | 3'b010 : RGB565                        |
| <b>y</b> |      |             | 3'b100 : YCbCr420                      |
|          |      |             | 3'b100                                 |
|          |      |             | 3'b110 : YCbCr444                      |
|          |      |             | win0 fmt                               |
|          |      |             | Win0_mit<br>Win0 source data Format    |
| 6:4      |      |             | 3'b000 : ARGB888                       |
|          |      |             | 3'b001 : RGB888                        |
|          | RW   | 0x0         | 3'b010: RGB666<br>3'b010: RGB565       |
|          |      |             | 3'b100 : YCbCr420                      |
|          |      |             | 3'b100 : YCbCr420<br>3'b101 : YCbCr422 |
|          |      |             | 3'b110 : YCbCr444                      |
|          |      |             | D NTIO ' 1CNC1444                      |



| Bit | Attr | Reset Value | Description                                                        |
|-----|------|-------------|--------------------------------------------------------------------|
| 3   | RW   | 0×0         | hwc_en Hwc enable bit 0: Hwc layer disable 1: Hwc layer enable     |
| 2   | RW   | 0x0         | win2_en Win2 enable bit 0: Win2 layer disable 1: Win2 layer enable |
| 1   | RW   | 0×0         | win1_en Win1 enable bit 0: Win1 layer disable 1: Win1 layerenable  |
| 0   | RW   | 0×0         | win0_en Win0 enable bit 0: Win0 layer disable 1: Win0 layer enable |

**LCDC\_DSP\_CTRL0**Address: Operational Base + offset (0x0008)

Display control register0

| Bit   | Attr | Reset<br>Value | Description                                                                                                                         |
|-------|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | RO   | 0x0            | reserved                                                                                                                            |
| 29    | RW   | 0x0            | dsp_ccir565_avg Cb-Cr filter in CCIR656 mode 0: drop mode 1: average mode                                                           |
| 28    | RW   | 0×0            | yuv_clip<br>YCrCb clip<br>0: disable, YCbCr no clip<br>1: enable, YCbCr clip before YCbCr2RGB<br>*Y clip: 16~235, CBCR clip: 16~239 |
| 27:26 | RW   | 0×0            | win1_csc_mode Win1 YUV2RGB Color space conversion: 2'b00: mpeg 2'b01: jpeg 2'b10: hd 2'b11: Bypass                                  |
| 25:24 | RW   | 0×0            | win0_csc_mode Win0 YUV2RGB Color space conversion: 2'b00: mpeg 2'b01: jpeg 2'b10: hd 2'b11: Bypass                                  |
| 23    | RW   | 0x0            | win2_alpha_mode Win2 alpha mode 0: user-defined alpha 1: per-pixel alpha                                                            |



| Bit | Attr | Reset<br>Value | Description                                                                                                                                                                                                  |
|-----|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22  | RW   | 0×0            | win1_alpha_mode Win1 alpha mode 0: user-defined alpha                                                                                                                                                        |
| 21  | RW   | 0x0            | 1: per-pixel alpha win0_alpha_mode Win0 alpha mode 0: user-defined alpha 1: per-pixel alpha                                                                                                                  |
| 20  | RW   | 0x0            | win1_cbr_deflick Win1 Cbr deflick mode 0: disable 1: enable                                                                                                                                                  |
| 19  | RW   | 0x0            | win1_yrgb_deflick Win1 YRGB deflick mode 0: disable 1: enable                                                                                                                                                |
| 18  | RW   | 0x0            | win0_cbr_deflick Win0 Cbr deflick mode 0: disable 1: enable                                                                                                                                                  |
| 17  | RW   | 0x0            | win0_yrgb_deflick Win0 YRGB deflick mode 0: disable 1: enable                                                                                                                                                |
| 16  | RW   | 0x0            | win2_interlace_read Win2 interlace read mode 0: disable 1: enable                                                                                                                                            |
| 15  | RW   | 0x0            | win1_interlace_read Win1 interlace read mode 0: disable 1: enable                                                                                                                                            |
| 14  | RW   | 0x0            | win0_interlace_read Win0 interlace read mode 0: disable 1: enable                                                                                                                                            |
| 13  | RW   | 0x0            | <pre>interlace_field_pol Interlace field polarity 0: normal 1: invert</pre>                                                                                                                                  |
| 12  | RW   | 0×0            | dsp_interlace Interlace display enable 0: disable 1: enable *This mode is related to the ITU-R656 output, the display timing of odd field must be set correctly. (lcdc_dsp_vs_st_end_f1/Lcdc_dsp_vCt_end_f1) |
| 11  | RW   | 0x0            | dither_down Dither-down enable 0: disable 1: enable                                                                                                                                                          |



| Bit | Attr | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10  | RW   | 0x0            | dither_down_mode Dither-down mode 0: RGB888 to RGB565 1: RGB888 to RGB666                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 9   | RW   | 0x0            | dither_up dither up RGB565 to RGB888 enable 0: disable 1: enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 8   | RW   | 0x0            | dsp_win0_top Win0 and Win1 position swap 0: win1 on the top of win0 1: win0 on the top of win1                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 7   | RW   | 0x0            | dclk_inv_en DCLK invert enable 0: normal 1: invert                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 6   | RW   | 0x0            | den_polarity DEN polarity 0: positive 1: negative                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 5   | RW   | 0x0            | vs_polarity VSYNC polarity 0: negative 1: positive                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 4   | RW   | 0x0            | hs_polarity HSYNC polarity 0: negative 1: positive                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 3:0 | RW   | 0×0            | dsp_out_mode Display output format 4'b0000: Parallel 24-bit RGB888 output     R[7:0],G[7:0],B[7:0] 4'b0001: Parallel 16-bit RGB666 output     6'b0,R[5:0],G[5:0],B[5:0] 4'b0010: Parallel 15-bit RGB565 output     8'b0,R[4:0],G[5:0],B[4:0] 4'b0100: Serial 2x16-bit RGB888x     8'b0,G[7:0],B[7:0] + 16'b0,R[7:0] 4'b0110: ITU-656 output     16'b0,pixel_data[7:0] 4'b1000: Serial 3x8-bit RGB888     16'b0, B[7:0]+16'b0,G[7:0]+16'b0,R[7:0] 4'b1100: Serial 3x8-bit RGB888 + dummy     16'b0, B[7:0]+16'b0,G[7:0]+16'b0,R[7:0] + dummy Others: Reserved. |

**LCDC\_DSP\_CTRL1**Address: Operational Base + offset (0x000c)

Display control register1

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
|-----|------|-------------|-------------|



| Bit   | Attr | Reset Value | Description                                                                                                      |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------|
| 31    | RO   | 0x0         | reserved                                                                                                         |
| 30    | RW   | 0×0         | dsp_dummy_swap Display dummy swap enable 0: B+G+R+dummy 1: dummy+B+G+R                                           |
| 29    | RW   | 0x0         | dsp_delta_swap Display delta swap enable 0: disable 1: enable *See detail description in Delta display charpter. |
| 28    | RW   | 0×0         | dsp_rg_swap Display output red and green swap enable 0: RGB 1: GRB                                               |
| 27    | RW   | 0x0         | dsp_rb_swap Display output red and blue swap enable 0: RGB 1: BGR                                                |
| 26    | RW   | 0x0         | dsp_bg_swap Display output blue and green swap enable 0: RGB 1: RBG                                              |
| 25    | RW   | 0x0         | dsp_black_en Black display mode When this bit enable, the pixel data output is all black (0x000000)              |
| 24    | RW   | 0x0         | dsp_blank_en Blank display mode When this bit enable, the hsync/vsync/den output is blank                        |
| 23:16 | RW   | 0x00        | dsp_bg_red<br>Background Red color                                                                               |
| 15:8  | RW   | 0x00        | dsp_bg_green<br>Background Green color                                                                           |
| 7:0   | RW   | 0x00        | dsp_bg_blue<br>Background Blue color                                                                             |

## LCDC\_INT\_STATUS

Address: Operational Base + offset (0x0010)

Interrupt status register

| Bit   | Attr | Reset Value | Description                                                                                                                                     |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | RO   | 0x0         | reserved                                                                                                                                        |
| 23:12 | RW   | 0×000       | dsp_line_flag_num Line number of the Line flag interrupt The display line number when the flag interrupt occur, the range is (0~ DSP_VTOTAL-1). |
| 11    | W1C  | 0x0         | bus_err_intr_en Bus error Interrupt clear (Auto clear)                                                                                          |
| 10    | W1C  | 0x0         | line_flag_intr_en<br>Line flag Interrupt clear (Auto clear)                                                                                     |



| Bit | Attr | Reset Value | Description                                   |
|-----|------|-------------|-----------------------------------------------|
| 9   | W1C  | 0x0         | fs_intr_en                                    |
|     |      |             | Frame start interrupt clear (Auto clear)      |
| 8   | W1C  | 0x0         | hs_intr_en                                    |
|     |      |             | Horizontal start interrupt clear (Auto clear) |
|     |      |             | bus_error_intr_clr                            |
| 7   | wo   | 0x0         | Bus error interrupt enable                    |
|     | 1    | OXO         | 0: disable                                    |
|     |      |             | 1: enable                                     |
|     |      |             | line_flag_intr_clr                            |
| 6   | RW   | 0.40        | Line flag Interrupt enable                    |
| O   | KVV  | 0x0         | 0: disable                                    |
|     |      |             | 1: enable                                     |
|     |      |             | fs_intr_clr                                   |
| _   | DW   | 0x0         | Frame start interrupt enable                  |
| 5   | RW   |             | 0: disable                                    |
|     |      |             | 1: enable                                     |
|     |      |             | hst_intr_clr                                  |
| 4   | RW   | 0x0         | Horizontal start interrupt enable             |
| 7   | IXVV | 0.00        | 0: disable                                    |
|     |      |             | 1: enable                                     |
| 3   | RO   | 0×0         | bus_error_intr                                |
| 3   | KU   | UXU         | Bus error Interrupt status                    |
| 2   | RO   | 0.0         | line_flag_intr                                |
| _   | KU   | O 0x0       | Line flag Interrupt status                    |
| 1   | RO   | 0×0         | fs_intr                                       |
| 1   | NU   | UXU         | Frame start interrupt status                  |
| 0   | RO   | 0×0         | hst_intr                                      |
| J   | NO   | UAU         | Horizontal start interrupt status             |

## LCDC\_MCU\_CTRL

Address: Operational Base + offset (0x0014)

MCU mode control register

| Bit   | Attr | Reset Value | Description                                                                                      |
|-------|------|-------------|--------------------------------------------------------------------------------------------------|
| 31    | RW   | 0x0         | mcu_type MCU LCD output SELECT                                                                   |
| 30    | RW   | 0x0         | mcu_bypass<br>MCU LCD BYPASS MODE Select                                                         |
| 29    | RW   | 0x0         | mcu_rs<br>MCU LCD RS Select                                                                      |
| 28    | W1C  | 0×0         | mcu_frm_st mcu frame start Write"1" :MCU HOLD Mode Frame Start Read: MCU HOLD status             |
| 27    | RW   | 0x0         | mcu_hold_mode<br>MCU HOLD Mode Select                                                            |
| 26    | RW   | 0x0         | mcu_clk_sel MCU_CLK_SEL for MCU bypass 1: MCU BYPASS sync with DCLK 0: MCU BYPASS sync with HCLK |
| 25:20 | RW   | 0x07        | mcu_rw_pend<br>MCU_RW signal end point (0-63]                                                    |



| Bit   | Attr | Reset Value | Description                                           |
|-------|------|-------------|-------------------------------------------------------|
| 19:16 | RW   | 0x1         | mcu_rw_pst<br>MCU_RW signal start point (0-15)        |
| 15:10 | RW   | 0x07        | mcu_cs_pend<br>MCU_CS signal end point (0-63)         |
| 9:6   | RW   | 0x0         | mcu_cs_pst<br>MCU_CS signal start point (0-15)        |
| 5:0   | RW   | 0x08        | mcu_pix_total MCU LCD Interface writing period (0-63) |

## LCDC\_BLEND\_CTRL

Address: Operational Base + offset (0x0018)

Blending control register

| Bit   | Attr | Reset Value | Description                                                     |
|-------|------|-------------|-----------------------------------------------------------------|
| 31:28 | RW   | 0x0         | hwc_alpha_value HWC alpha blending value                        |
| 27:20 | RW   | 0x00        | win2_alpha_value<br>Win2 alpha blending value                   |
| 19:12 | RW   | 0x00        | win1_alpha_value<br>Win1 alpha blending value                   |
| 11:4  | RW   | 0x00        | win0_alpha_value<br>Win0 alpha blending value                   |
| 3     | RW   | 0×0         | hwc_alpha_en HWC alpha blending enable 0: disable; 1: enable;   |
| 2     | RW   | 0x0         | win2_alpha_en Win2 alpha blending enable 0: disable; 1: enable; |
| 1     | RW   | 0×0         | win1_alpha_en Win1 alpha blending enable 0: disable; 1: enable; |
| 0     | RW   | 0×0         | win0_alpha_en Win0 alpha blending enable 0: disable; 1: enable; |

## LCDC\_WINO\_COLOR\_KEY

Address: Operational Base + offset (0x001c)

Win0 color key register

| Bit   | Attr | Reset Value | Description                                                           |
|-------|------|-------------|-----------------------------------------------------------------------|
| 31:25 | RO   | 0x0         | reserved                                                              |
| 24    | RW   | 111711      | win0_key_en Win0 transparency color key enable 0: disable; 1: enable; |



| Bit  | Attr | Reset Value | Description                                  |
|------|------|-------------|----------------------------------------------|
| 22.0 | 5144 |             | win0_key_color                               |
| 23:0 | RW   | 0x000000    | Win0 key color                               |
|      |      |             | Win0 key color red[7:0],green[7:0],blue[7:0] |

### LCDC\_WIN1\_COLOR\_KEY

Address: Operational Base + offset (0x0020)

Win1 color key register

| Bit   | Attr | Reset Value | Description                                                                |
|-------|------|-------------|----------------------------------------------------------------------------|
| 31:25 | RO   | 0x0         | reserved                                                                   |
| 24    | RW   | 0×0         | win1_key_en Win1 transparency color key enable 0: disable; 1: enable;      |
| 23:0  | RW   | 0x000000    | win1_key_color Win1 key color Win1 key color red[7:0],green[7:0],blue[7:0] |

### LCDC\_WIN2\_COLOR\_KEY

Address: Operational Base + offset (0x0024)

Win2 color key register

| Bit   | Attr | Reset Value | Description                                                                    |
|-------|------|-------------|--------------------------------------------------------------------------------|
| 31:25 | RO   | 0x0         | reserved                                                                       |
| 24    | RW   | 0×0         | win2_key_en Win2 transparency color key enable 0: disable; 1: enable;          |
| 23:0  | RW   | 0x000000    | win2_key_color Win2 key color red Win2 key color red[7:0],green[7:0],blue[7:0] |

### LCDC\_WINO\_YRGB\_MSTO

Address: Operational Base + offset (0x0028)

Win0 YRGB memory start address 0

| Bit  | Attr | Reset Value | Description                                                        |
|------|------|-------------|--------------------------------------------------------------------|
| 31:0 | RW   |             | win0_yrgb0_mst<br>win0 YRGB frame buffer memory start<br>address 0 |

### LCDC\_WINO\_CBR\_MSTO

Address: Operational Base + offset (0x002c)

Win0 Cbr memory start address 0

| Bit  | Attr | Reset Value | Description                                                      |
|------|------|-------------|------------------------------------------------------------------|
| 31:0 | RW   | 0×00000000  | win0_cbr0_mst<br>win0 CBR frame buffer memory start address<br>0 |

## LCDC\_WINO\_YRGB\_MST1

Address: Operational Base + offset (0x0030)

Win0 YRGB memory start address 1

|     |      |             | · <del>-</del> - |
|-----|------|-------------|------------------|
| Bit | Attr | Reset Value | Description      |



| Bit  | Attr | Reset Value | Description                                                        |
|------|------|-------------|--------------------------------------------------------------------|
| 31:0 | RW   | 0×00000000  | win0_yrgb1_mst<br>win0 YRGB frame buffer memory start<br>address 1 |

### LCDC\_WINO\_CBR\_MST1

Address: Operational Base + offset (0x0034)

Win0 Cbr memory start address 1

| Bit  | Attr | Reset Value | Description                                                      |
|------|------|-------------|------------------------------------------------------------------|
| 31:0 | RW   | 0×00000000  | win0_cbr1_mst<br>win0 CBR frame buffer memory start address<br>1 |

### LCDC\_WINO\_VIR

Address: Operational Base + offset (0x0038)

Win0 virtual display width

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                            |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                                                                                                                                                                                               |
| 15:0  | RW   | 0x0140      | win0_vir_stride Win0 Virtual Display stride Number of words of Win0 Virtual width ARGB888: win0_vir_width RGB888: (win0_vir_width*3/4) + (win0_vir_width%3) RGB565: ceil(win0_vir_width/2) YUV: ceil(win0_vir_width/4) |

### LCDC\_WINO\_ACT\_INFO

Address: Operational Base + offset (0x003c)

Win0 active window width/height

| Bit   | Attr | Reset Value                           | Description                                |
|-------|------|---------------------------------------|--------------------------------------------|
| 31:29 | RO   | 0x0                                   | reserved                                   |
|       |      | , , , , , , , , , , , , , , , , , , , | win0_act_height                            |
| 28:16 | RW   | 0x00ef                                | Win0 active(original) window height        |
|       |      |                                       | win_act_height = (win0 vertical size -1)   |
| 15:13 | RO   | 0x0                                   | reserved                                   |
|       |      | 7                                     | win0_act_width                             |
| 12:0  | RW   | 0x013f                                | Win0 active(original) window width         |
|       |      |                                       | win_act_width = (win0 horizontial size -1) |

### LCDC\_WINO\_DSP\_INFO

Address: Operational Base + offset (0x0040)

Win0 display width/height on panel

| Bit   | Attr | Reset Value | Description                                 |
|-------|------|-------------|---------------------------------------------|
| 31:27 | RO   | 0x0         | reserved                                    |
|       |      |             | dsp_win0_height                             |
| 26:16 | RW   | 0x0ef       | Win0 display window height                  |
|       |      |             | win0_dsp_height = (win0 vertical size -1)   |
| 15:11 | RO   | 0x0         | reserved                                    |
|       |      |             | dsp_win0_width                              |
| 10:0  | RW   | 0x13f       | Win0 display window width                   |
|       |      |             | win0_dsp_width = (win0 horizontial size -1) |



### LCDC\_WINO\_DSP\_ST

Address: Operational Base + offset (0x0044)

Win0 display start point on panel

| Bit   | Attr | Reset Value | Description                                 |
|-------|------|-------------|---------------------------------------------|
| 31:28 | RO   | 0x0         | reserved                                    |
|       |      |             | dsp_win0_yst                                |
| 27:16 | RW   | 0x000       | Win0 vertical start point(y) of the Panel   |
|       |      |             | scanning                                    |
| 15:12 | RO   | 0x0         | reserved                                    |
|       |      |             | dsp_win0_xst                                |
| 11:0  | RW   | 0x000       | Win0 horizontal start point(x) of the Panel |
|       |      |             | scanning                                    |

### LCDC\_WINO\_SCL\_FACTOR\_YRGB

Address: Operational Base + offset (0x0048)

Win0 YRGB scaling factor

| _     | This this state |             |                                                         |  |  |
|-------|-----------------|-------------|---------------------------------------------------------|--|--|
| Bit   | Attr            | Reset Value | Description                                             |  |  |
| 31:16 | RW              |             | win0_vs_factor_yrgb Win0 YRGB vertical scaling factor   |  |  |
| 15:0  | RW              |             | win0_hs_factor_yrgb Win0 YRGB horizontal scaling factor |  |  |

### LCDC\_WINO\_SCL\_FACTOR\_CBR

Address: Operational Base + offset (0x004c)

Win0 Cbr scaling factor

|       | Third Co. County I detail |                    |                                                          |  |  |
|-------|---------------------------|--------------------|----------------------------------------------------------|--|--|
| Bit   | Attr                      | <b>Reset Value</b> | Description                                              |  |  |
| 31:16 | RW                        | 0x1000             | win0_vs_factor_cbr<br>Win0 CBR vertical scaling factor   |  |  |
| 15:0  | RW                        | 0x1000             | win0_hs_factor_cbr<br>Win0 CBR horizontal scaling factor |  |  |

## LCDC\_WINO\_SCL\_OFFSET

Address: Operational Base + offset (0x0050)

Win0 scaling start point offset

| Bit   | Attr | Reset Value | Description                               |
|-------|------|-------------|-------------------------------------------|
|       | 41   |             | win0_vs_offset_cbr                        |
| 31:24 | RW   | 0x00        | Cbr Vertical scaling start point offset   |
|       |      |             | $(0x00\sim0xff)/0x100 = 0\sim0.99$        |
|       |      |             | win0_vs_offset_yrgb                       |
| 23:16 | RW   | 0x00        | Y Vertical scaling start point offset     |
|       |      |             | $(0x00\sim0xff)/0x100 = 0\sim0.99$        |
|       |      |             | win0_hs_offset_cbr                        |
| 15:8  | RW   | 0x00        | Cbr Horizontal scaling start point offset |
|       |      |             | $(0x00\sim0xff)/0x100 = 0\sim0.99$        |
|       |      |             | win0_hs_offset_yrgb                       |
| 7:0   | RW   | 0x00        | Y Horizontal scaling start point offset   |
|       |      |             | $(0x00\sim0xff)/0x100 = 0\sim0.99$        |

### LCDC\_WIN1\_YRGB\_MST

Address: Operational Base + offset (0x0054)

Win1 YRGB memory start address

|     |      |             | <del>-</del> |
|-----|------|-------------|--------------|
| Bit | Attr | Reset Value | Description  |



| Bit  | Attr | Reset Value | Description                                               |
|------|------|-------------|-----------------------------------------------------------|
| 31:0 | RW   |             | win1_yrgb_mst Win1 YRGB frame buffer memory start address |

### LCDC\_WIN1\_CBR\_MST

Address: Operational Base + offset (0x0058)

Win1 Cbr memory start address

| Bit  | Attr | Reset Value | Description                                             |
|------|------|-------------|---------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | win1_cbr_mst Win1 CBR frame buffer memory start address |

### LCDC\_WIN1\_VIR

Address: Operational Base + offset (0x005c)

Win1 virtual display width

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                            |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0                | reserved                                                                                                                                                                                                               |
| 15:0  | RW   | 0x0140             | win1_vir_stride Win1 Virtual Display stride Number of words of Win1 Virtual width ARGB888: win1_vir_width RGB888: (win1_vir_width*3/4) + (win1_vir_width%3) RGB565: ceil(win1_vir_width/2) YUV: ceil(win1_vir_width/4) |

### LCDC\_WIN1\_ACT\_INFO

Address: Operational Base + offset (0x0060)

Win1 active window width/height

| Bit   | Attr | Reset Value | Description                                                                                   |
|-------|------|-------------|-----------------------------------------------------------------------------------------------|
| 31:29 | RO   | 0x0         | reserved                                                                                      |
| 28:16 | RW   | 0x00ef      | win1_act_height Win1 active(original) window height win1_act_height = (win1 vertical size -1) |
| 15:13 | RO   | 0x0         | reserved                                                                                      |
| 12:0  | RW   | 0x013f      | win1_act_width Win1 active(original) window width win1_act_width = (win1 horizontial size -1) |

## LCDC\_WIN1\_DSP\_INFO

Address: Operational Base + offset (0x0064)

Win1 display width/height on panel

| Bit   | Attr | Reset Value | Description                                                                                         |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------|
| 31:27 | RO   | 0x0         | reserved                                                                                            |
|       |      |             | dsp_win1_height                                                                                     |
| 26:16 | RW   | 0x0ef       | Win1 display window height                                                                          |
|       |      |             | <pre>win1_dsp_height = (win1 dsp vertical size -1)</pre>                                            |
| 15:11 | RO   | 0x0         | reserved                                                                                            |
| 10:0  | RW   | 0×13f       | <pre>dsp_win1_width Win1 display window width win1_dsp_width = (win1 dsp horizontial size -1)</pre> |



### LCDC\_WIN1\_DSP\_ST

Address: Operational Base + offset (0x0068)

Win1 display start point on panel

| Bit   | Attr | Reset Value | Description                                 |
|-------|------|-------------|---------------------------------------------|
| 31:28 | RO   | 0x0         | reserved                                    |
|       |      |             | dsp_win1_yst                                |
| 27:16 | RW   | 0x000       | Win1 vertical start point(y) of the Panel   |
|       |      |             | scanning                                    |
| 15:12 | RO   | 0x0         | reserved                                    |
|       |      |             | dsp_win1_xst                                |
| 11:0  | RW   | 0x000       | Win1 horizontal start point(x) of the Panel |
|       |      |             | scanning                                    |

### LCDC\_WIN1\_SCL\_FACTOR\_YRGB

Address: Operational Base + offset (0x006c)

Win1 YRGB scaling factor

|       | THIS TREE Seating rascor |             |                                                         |  |  |  |
|-------|--------------------------|-------------|---------------------------------------------------------|--|--|--|
| Bit   | Attr                     | Reset Value | Description                                             |  |  |  |
| 31:16 | RW                       |             | win1_vs_factor_yrgb Win1 YRGB vertical scaling factor   |  |  |  |
| 15:0  | RW                       |             | win1_hs_factor_yrgb Win1 YRGB horizontal scaling factor |  |  |  |

### LCDC\_WIN1\_SCL\_FACTOR\_CBR

Address: Operational Base + offset (0x0070)

Win1 Cbr scaling factor

| Bit   | Attr | Reset Value | Description                                            |
|-------|------|-------------|--------------------------------------------------------|
| 31:16 | RW   | 0x1000      | win1_vs_factor_cbr<br>Win1 CBR vertical scaling factor |
| 15:0  | RW   | 0x1000      | win1_hs_factor_cbr Win1 CBR horizontal scaling factor  |

### LCDC\_WIN1\_SCL\_OFFSET

Address: Operational Base + offset (0x0074)

Win1 scaling start point offset

| Bit   | Attr | Reset Value | Description                                                                                  |
|-------|------|-------------|----------------------------------------------------------------------------------------------|
| 31:24 | RW   | 0×00        | wn1_vs_offset_cbr<br>Cbr Vertical scaling start point offset<br>(0x00~0xff)/0x100 = 0~0.99   |
| 23:16 | RW   | 0x00        | wn1_vs_offset_yrgb Y Vertical scaling start point offset (0x00~0xff)/0x100 = 0~0.99          |
| 15:8  | RW   | 0x00        | wn1_hs_offset_cbr<br>Cbr Horizontal scaling start point offset<br>(0x00~0xff)/0x100 = 0~0.99 |
| 7:0   | RW   | 0x00        | wn1_hs_offset_yrgb Y Horizontal scaling start point offset (0x00~0xff)/0x100 = 0~0.99        |

### LCDC\_WIN2\_MST

Address: Operational Base + offset (0x0078)

Win2 memory start address

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|



| Bit  | Attr | Reset Value | Description                                                                       |
|------|------|-------------|-----------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | win2_mst Win2 frame buffer memory start address *must be alianed to 8byte address |

### LCDC\_WIN2\_VIR

Address: Operational Base + offset (0x007c)

Win2 virtual display width

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                      |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                         |
| 15:0  | RW   | 0x0140             | win2_vir_stride Win2 Virtual Display stride Number of words of Win2 Virtual width ARGB888: win2_vir_width RGB888: (win2_vir_width*3/4) + (win2_vir_width%3) RGB565: ceil(win2_vir_width/2) 8BPP: ceil(win0_vir_width/4) 4BPP: ceil(win0_vir_width/8) 2BPP: ceil(win0_vir_width/16) 1BPP: ceil(win0_vir_width/32) |

### LCDC\_WIN2\_DSP\_INFO

Address: Operational Base + offset (0x0080)

Win2 display width/height on panel

| Bit   | Attr | Reset Value | Description                                   |
|-------|------|-------------|-----------------------------------------------|
| 31:27 | RO   | 0x0         | reserved                                      |
|       |      |             | dsp_win2_height                               |
| 26:16 | RW   | 0x0ef       | Win2 display window height                    |
|       |      |             | win2_dsp_height = (win2 dsp vertical size -1) |
| 15:11 | RO   | 0x0         | reserved                                      |
|       |      |             | dsp_win2_width                                |
| 10:0  | RW   |             | Win2 display window width                     |
|       |      | RW 0x13f    | win2_dsp_width = (win2 dsp horizontial size   |
|       |      |             | -1)                                           |

### LCDC\_WIN2\_DSP\_ST

Address: Operational Base + offset (0x0084)

Win2 display start point on panel

| Bit   | Attr | Reset Value | Description                                 |
|-------|------|-------------|---------------------------------------------|
| 31:28 | RO   | 0x0         | reserved                                    |
|       |      |             | dsp_win2_yst                                |
| 27:16 | RW   | 0x000       | Win2 vertical start point(y) of the Panel   |
|       |      |             | scanning                                    |
| 15:12 | RO   | 0x0         | reserved                                    |
|       |      |             | dsp_win2_xst                                |
| 11:0  | RW   | 0x000       | Win2 horizontal start point(x) of the Panel |
|       |      |             | scanning                                    |

### LCDC\_HWC\_MST

Address: Operational Base + offset (0x0088)

Hwc memory start address

| Bit Attr Reset Value | Description |
|----------------------|-------------|
|----------------------|-------------|



| Bit  | Attr | Reset Value | Description                           |
|------|------|-------------|---------------------------------------|
| 31:0 | RW   | 10>00000000 | hwc_mst HWC data memory start address |

### LCDC\_HWC\_DSP\_ST

Address: Operational Base + offset (0x008c)

Hwc display start point on panel

| Bit   | Attr | Reset Value | Description                                                           |
|-------|------|-------------|-----------------------------------------------------------------------|
| 31:28 | RO   | 0x0         | reserved                                                              |
| 27:16 | RW   | 0x000       | dsp_hwc_yst<br>HWC vertical start point(y) of the Panel<br>scanning   |
| 15:12 | RO   | 0x0         | reserved                                                              |
| 11:0  | RW   | 0x000       | dsp_hwc_xst<br>HWC horizontal start point(x) of the Panel<br>scanning |

### LCDC\_HWC\_COLOR\_LUT0

Address: Operational Base + offset (0x0090)

Hwc LUT color 0

| Bit   | Attr | Reset Value | Description                                                                                                                                                             |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | RO   | 0x0         | reserved                                                                                                                                                                |
| 23:0  | RW   | 0×000000    | hwc_color0 Hardware cursor color [23:16]: Hardware cursor color red for 2'b00 [15:8]: Hardware cursor color green for 2'b00 [7:0]: Hardware cursor color blue for 2'b00 |

## LCDC\_HWC\_COLOR\_LUT1

Address: Operational Base + offset (0x0094)

Hwc LUT color 1

| Bit   | Attr | Reset Value | Description                                  |
|-------|------|-------------|----------------------------------------------|
| 31:24 | RO   | 0x0         | reserved                                     |
|       | 41   |             | hwc_color1                                   |
|       |      | 7           | Hardware cursor color                        |
|       |      | Y           | [23:16]: Hardware cursor color red for 2'b01 |
| 23:0  | RW   | 0x000000    | [15:8] : Hardware cursor color green for     |
|       |      |             | 2'b01                                        |
|       | ~    |             | [7:0] : Hardware cursor color blue for       |
|       |      |             | 2'b01                                        |

### LCDC\_HWC\_COLOR\_LUT2

Address: Operational Base + offset (0x0098)

Hwc LUT color 2

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:24 | RO   | 0x0         | reserved    |



| Bit  | Attr | Reset Value | Description                                                                                                                                                             |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23:0 | RW   | 0×000000    | hwc_color2 Hardware cursor color [23:16]: Hardware cursor color red for 2'b10 [15:8]: Hardware cursor color green for 2'b10 [7:0]: Hardware cursor color blue for 2'b10 |

### LCDC\_DSP\_HTOTAL\_HS\_END

Address: Operational Base + offset (0x009c)

Panel scanning horizontal width and hsync pulse end

| Bit   | Attr | Reset Value | Description                                            |
|-------|------|-------------|--------------------------------------------------------|
| 31:28 | RO   | 0x0         | reserved                                               |
| 27:16 | RW   | 0x14a       | dsp_hs_end<br>Panel display scanning horizontal period |
| 15:12 | RO   | 0x0         | reserved                                               |
| 11:0  | RW   | 0x00a       | dsp_htotal<br>Panel display scanning hsync pulse width |

### LCDC\_DSP\_HACT\_ST\_END

Address: Operational Base + offset (0x00a0)

Panel active horizontal scanning start point and end point

| Bit   | Attr | Reset Value | Description                                                             |
|-------|------|-------------|-------------------------------------------------------------------------|
| 31:28 | RO   | 0x0         | reserved                                                                |
| 27:16 | RW   | 0x14a       | dsp_hact_end<br>Panel display scanning horizontal active start<br>point |
| 15:12 | RO   | 0x0         | reserved                                                                |
| 11:0  | RW   | 0x00a       | dsp_hact_st Panel display scanning horizontal active end point          |

## LCDC\_DSP\_VTOTAL\_VS\_END

Address: Operational Base + offset (0x00a4)

Panel scanning vertical height and vsync pulse end point

| Bit   | Attr | Reset Value | Description                                            |
|-------|------|-------------|--------------------------------------------------------|
| 31:28 | RO   | 0x0         | reserved                                               |
| 27:16 | RW   | 0x0fa       | dsp_vtotal Panel display scanning vertical period      |
| 15:12 | RO   | 0x0         | reserved                                               |
| 11:0  | RW   | 0x00a       | dsp_vs_end<br>Panel display scanning vsync pulse width |

### LCDC\_DSP\_VACT\_ST\_END

Address: Operational Base + offset (0x00a8)

Panel active vertical scanning start point and end point

| Bit   | Attr | <b>Reset Value</b> | Description                                                     |
|-------|------|--------------------|-----------------------------------------------------------------|
| 31:28 | RO   | 0x0                | reserved                                                        |
| 27:16 | RW   |                    | dsp_vact_end Panel display scanning vertical active start point |
| 15:12 | RO   | 0x0                | reserved                                                        |



| Bit  | Attr | Reset Value | Description                                                  |
|------|------|-------------|--------------------------------------------------------------|
| 11:0 | RW   | 0x00a       | dsp_vact_st Panel display scanning vertical active end point |

### LCDC\_DSP\_VS\_ST\_END\_F1

Address: Operational Base + offset (0x00ac) Vsync start point and end point of filed1

| Bit   | Attr | Reset Value | Description                                                                                                                                |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | RO   | 0x0         | reserved                                                                                                                                   |
| 27:16 | RW   | 0×000       | dsp_vs_end_f1<br>interlace display vs end point<br>Panel display scanning vertical vsync end point<br>of 2nd field(interlace display mode) |
| 15:12 | RO   | 0x0         | reserved                                                                                                                                   |
| 11:0  | RW   | 0×000       | dsp_vs_st_f1 interlace display vsync start point Panel display scanning vertical vsync start point of 2nd field (interlace display mode)   |

### LCDC\_DSP\_VACT\_ST\_END\_F1

Address: Operational Base + offset (0x00b0) Vertical active start point and end point of filed1

| Bit   | Attr | Reset Value | Description                                                                                                                                           |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | RO   | 0x0         | reserved                                                                                                                                              |
| 27:16 | RW   | 0×000       | dsp_vact_end_f1 interlace display vertical active end point Panel display scanning vertical active end point of 2nd field (interlace display mode)    |
| 15:12 | RO   | 0x0         | reserved                                                                                                                                              |
| 11:0  | RW   | 0x000       | dsp_vact_st_f1 interlace display vertical active start point Panel display scanning vertical active start point of 2nd field (interlace display mode) |

### LCDC\_REG\_LOAD\_EN

Address: Operational Base + offset (0x00c0)

Register config done flag

| Bit      | Attr | Reset Value | Description                                       |
|----------|------|-------------|---------------------------------------------------|
| 31:1     | RO   | 0x0         | reserved                                          |
|          | ~    |             | reg_load_en                                       |
| <b>*</b> | •    |             | LCDC register config done                         |
|          |      |             | In the first setting of the register, the new     |
| 0        | RW   | 0×0         | value was saved into the mirror register.         |
| 0        | RW   | 0.00        | When all the register config finish, writing this |
|          |      |             | register to enable the copyright of the mirror    |
|          |      |             | register to real register. Then register would    |
|          |      |             | be updated at the start of every frame.           |

### LCDC\_MCU\_BYPASS\_WPORT

Address: Operational Base + offset (0x0100)LCDC MCU bypass mode data write port

| Bit Attr Reset Value | Description |
|----------------------|-------------|
|----------------------|-------------|



| Bit   | Attr | Reset Value | Description                                                                                                                          |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | RO   | 0x0         | reserved                                                                                                                             |
| 23:0  | WO   | 0×000000    | mcu_bypass_wport<br>LCDC MCU bypass mode data write port<br>When MCU is in BYPASS Mode, BYPASS data is<br>written through this Port. |

### LCDC\_MCU\_BYPASS\_RPORT

Address: Operational Base + offset (0x0200)

LCDC MCU bypass mode data read port

| Bit   | Attr | Reset Value | Description                                                                                                                                   |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | RO   | 0x0         | reserved                                                                                                                                      |
| 23:0  | RO   |             | mcu_bypass_rport<br>LCDC MCU bypass mode data read port<br>When MCU is in BYPASS Mode, BYPASS data is<br>read through this Port (addr fixed). |

### LCDC\_Win2\_LUT\_ADDR

Address: Operational Base + offset (0x0400)

LCDC win2 lut bus access address map

| Bit   | Attr | Reset Value | Description                                                                                                    |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------|
| 31:25 | RO   | 0x0         | reserved                                                                                                       |
| 24:0  | RW   | 0x0000000   | win2_lut_addr<br>LCDC win2 lut bus access address map<br>Access entry for win2 LUT memory (word size<br>only). |

### LCDC\_DSP\_LUT\_ADDR

Address: Operational Base + offset (0x0800)

LCDC dsp lut bus access address map

| Bit   | Attr | Reset Value | Description                                                                                                |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------|
| 31:24 | RO   | 0x0         | reserved                                                                                                   |
| 23:0  | RW   |             | dsp_lut_addr<br>LCDC dsp lut bus access address map<br>Access entry for DSP LUT memory (word size<br>only) |

# 22.5 Timing Diagram



Fig. 22-18 LCDC RGB interface timing

Table 22-5 LCDC0 RGB interface signal timing constant

(VDD\_core =0.99V to 1.1V, VDD\_IO=3.0V to 3.6V , TA =  $-40^{\circ}$  ot 125°C)

| Item                              | Symbol  | Min   | Тур   | Max   | Únit |
|-----------------------------------|---------|-------|-------|-------|------|
| Display clock period              | Tdclk   | 6.64  | -     | -     | ns   |
| VSYNC setup to DCLK falling edge  | Tvsetup | 2.377 | 2.454 | 2.628 | ns   |
| VSYNC hold from DCLK falling edge | Tvhold  | 2.531 | 2.686 | 2.905 | ns   |
| HSYNC setup to DCLK falling edge  | Thsetup | 2.257 | 2.378 | 2.586 | ns   |
| HSYNC hold from DCLK falling edge | Thhold  | 2.648 | 2.754 | 2.943 | ns   |
| DEN setup to DCLK falling edge    | Tesetup | 2.291 | 2.436 | 2.637 | ns   |
| DEN hold from DCLK falling edge   | Tehold  | 2.514 | 2.672 | 2.878 | ns   |
| DATA setup to DCLK falling edge   | Tdsetup | 2.433 | 2.519 | 2.711 | ns   |
| DATA hold from DCLK falling edge  | Tdhold  | 2.248 | 2.494 | 2.750 | ns   |



### Table 22-6 LCDC1 RGB interface signal timing constant

### (VDD\_core =0.99V to 1.1V, VDD\_IO=3.0V to 3.6V , TA = -40 $^{\circ}$ ot 125 $^{\circ}$ )

| Item                              | Symbol  | Min   | Тур   | Max   | Unit |
|-----------------------------------|---------|-------|-------|-------|------|
| Display clock period              | Tdclk   | 6.64  | -     | -     | ns   |
| VSYNC setup to DCLK falling edge  | Tvsetup | 2.398 | 2.497 | 2.689 | ns   |
| VSYNC hold from DCLK falling edge | Tvhold  | 2.304 | 2.523 | 2,787 | ns   |
| HSYNC setup to DCLK falling edge  | Thsetup | 2.220 | 2.367 | 2.595 | ns   |
| HSYNC hold from DCLK falling edge | Thhold  | 2.444 | 2.625 | 2.866 | ns   |
| DEN setup to DCLK falling edge    | Tesetup | 2.216 | 2.348 | 2.571 | ns   |
| DEN hold from DCLK falling edge   | Tehold  | 2.448 | 2.636 | 2.885 | ns   |
| DATA setup to DCLK falling edge   | Tdsetup | 2.058 | 2.314 | 2.591 | ns   |
| DATA hold from DCLK falling edge  | Tdhold  | 2.368 | 2.567 | 2.801 | ns   |



Fig. 22-19 LCDC MCU interface (i80)timing

### Table 22-7 LCDC0 RGB interface signal timing constant

### (VDD\_core =0.99V to 1.1V, VDD\_IO=3.0V to 3.6V , TA = $-40^{\circ}$ ot 125°C)

| (122_0010 01331 to 1111) 123_10 0101 to 0101 / 111 10 0 011120 0) |         |       |       |        |      |  |  |
|-------------------------------------------------------------------|---------|-------|-------|--------|------|--|--|
| Item                                                              | Symbol  | Min   | Тур   | Max    | Unit |  |  |
| Internal clock period                                             | Tclk    | 6.64  | -     | -      | ns   |  |  |
| RS delay from CLK rising edge                                     | Trsd    | 4.407 | 6.605 | 9.801  | ns   |  |  |
| CSN delay from CLK rising edge                                    | Tcsd    | 5.331 | 8.070 | 12.098 | ns   |  |  |
| WEN delay from CLK rising edge                                    | Twend   | 5.383 | 8.166 | 12.269 | ns   |  |  |
| REN delay from CLK rising edge                                    | Trend   | 5.410 | 8.214 | 12.387 | ns   |  |  |
| D_out delay from CLK rising edge                                  | Tdod    | 6.988 | 8.214 | 16.135 | ns   |  |  |
| D_in setupto REN rising edge                                      | Tdsetup | 8.442 | 12.55 | 18.234 | ns   |  |  |
| D_in hold from REN rising edge                                    | Tdhold  | -13.1 | -8.57 | -6.173 | ns   |  |  |

Table 22-8 LCDC1 RGB interface signal timing constant

### (VDD\_core =0.99V to 1.1V, VDD\_IO=3.0V to 3.6V , TA = -40 $^{\circ}$ C ot 125 $^{\circ}$ C)

| Item                             | Symbol  | Min   | Тур   | Max    | Unit |
|----------------------------------|---------|-------|-------|--------|------|
| Internal clock period            | Tclk    | 6.64  | -     | -      | ns   |
| RS delay from CLK rising edge    | Trsd    | 4.377 | 6.547 | 9.775  | ns   |
| CSN delay from CLK rising edge   | Tcsd    | 5.218 | 7,953 | 12.008 | ns   |
| WEN delay from CLK rising edge   | Twend   | 5.302 | 8.073 | 12.172 | ns   |
| REN delay from CLK rising edge   | Trend   | 5.385 | 8.168 | 12.301 | ns   |
| D_out delay from CLK rising edge | Tdod    | 6.799 | 10.40 | 15.547 | ns   |
| D_in setupto REN rising edge     | Tdsetup | 7.118 | 11.41 | 17.827 | ns   |
| D_in hold from REN rising edge   | Tdhold  | -11.9 | -7.03 | -4.054 | ns   |



# 22.6 Interface Description

### 22.6.1 LCDC0 Ouputs

LCDC0 outputs are connected to two places, one is HDMI TX video input (), and the other is LCDC0 IOs. There is no IOMUX for LCDC0 IOs.

GRF\_SOC\_CON0[14] is the select bit for HDMI TX input.

GRF\_SOC\_CON0[14] = 1'b0: HDMI TX input from LCDC0;

GRF\_SOC\_CON0[14] = 1'b1: HDMI TX input from LCDC1;

### 22.6.2 LCDC1 Outputs

LCDC1 outputs are connected to two places, one is HDMI TX video input, the other is IOs. The IOMUX for LCDC1 IOs see following table.

Table 22-9LCDC1 IOMUX

| Module Pin      | Direction | Pad Name        | IOMUX Setting               |
|-----------------|-----------|-----------------|-----------------------------|
| LCDC_DCLK       | 0         | IO_GPIO2_D[0]   | GRF_GPIO2D_IOMUX[1:0]=2'b01 |
| LCDC_DEN        | 0         | IO_GPIO2_D[1]   | GRF_GPIO2D_IOMUX[3:2]=2'b01 |
| LCDC_HSYNC      | 0         | IO_GPIO2_D[2]   | GRF_GPIO2D_IOMUX[5:4]=2'b01 |
| LCDC_VSYNC      | 0         | IO_GPIO2_D[3]   | GRF_GPIO2D_IOMUX[7:6]=2'b01 |
| LCDC_DATA[23:0] | I/O       | LCDC_DATA[23:0] | GRF_GPIO2A_IOMUX[15:0]      |
|                 |           |                 | =16'h5555                   |
|                 |           |                 | GRF_GPIO2B_IOMUX[15:0]      |
|                 |           |                 | =16'h5555                   |
|                 |           |                 | GRF_GPIO2C_IOMUX[15:0]      |
|                 |           |                 | =16'h5555                   |

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

### 22.6.3 Pin Definition

Table 22-10 LCDC output pin definition

| Pin        | RGB 24-bit | RGB 18-bit | RGB 16-bit | MCU mode   | 656 mode  |
|------------|------------|------------|------------|------------|-----------|
|            | mode       | mode       | mode       |            |           |
| LCDC_DCLK  | DCLK       | DCLK       | DCLK       | RS         | DCLK      |
| LCDC_VSYNC | VSYNC      | VSYNC      | VSYNC      | CSN        | -         |
| LCDC_HSYNC | HSYNC      | HSYNC      | HSYNC      | WEN        | -         |
| LCDC_DEN   | DEN        | DEN        | DEN        | REN        | -         |
| LCDC_DATA  | DATA[23:0] | DATA[17:0] | DATA[15:0] | DATA[23:0] | DATA[7:0] |
| [23:0]     | =          | =          | =          | DATA[17:0] |           |
|            | {R8,G8,B8} | {R6,G6,B6} | {R5,G6,B5} | DATA[15:0] |           |

<sup>\*</sup>NOTE: In MCU mode, LCD\_DCLK is used as RS signal of i80 interface, others, LCD\_DCLK is used as Icdc output data clock, which can be inverted according the register setting.



Fig. 22-21 LCDC Serail RGB LCD interface

G

Serial 16x2

В

G



### 22.6.5 MCU Interface (i80)



Fig. 22-22 LCDC MCU interface timing setting

### 22.6.6 RGB Delta Interface

RGB delta LCD handles serial 8bit data. In the case of RGB 8bit serial, there are four scanning modes for the RGB delta data.



Fig. 22-23 LCDC RGB delta LCD interface

There are four setting modes for the four scanning modes of RGB delta LCD in LCD controller.

Table 22-11 LCDC delta and swap setting for RGB delta LCD

| RGB delta mode | Delta_en | Dsp_rg_swap | Dsp_rb_swap | Dsp_bg_swap |
|----------------|----------|-------------|-------------|-------------|
| CSH=1,CSV=1    | 1        | 0           | 1           | 0           |
| CSH=0,CSV=1    | 1        | 0           | 0           | 0           |
| CSH=1,CSV=0    | 1        | 0           | 0           | 1           |
| CSH=0,CSV=0    | 1        | 0           | 1           | 1           |

## **Chapter 23 RGA**

### 23.1 Overview

RGAis a separate 2D raster graphic acceleration unit. It accelerates 2D graphics operations, such aspoint/line drawing, image scaling, rotation, BitBLT, alpha blending and image blur/sharpness.

#### 23.1.1 Features

#### **♦** Data format

- Input data: ARGB/RGB888/RGB565/YUV420/YUV422
- Output data: ARGB/RGB888/RGB565 (YUV420/YUV422 for blur/sharpness)
- Pixel Format conversion, BT.601/BT.709
- Dither operation
- Max resolution: 8192x8192 source image, 2048x2048 frame buffer

#### ♦ Scaling

- Down-scaling and up-scaling
- Three sampling modes: Nearest sampling (Stretched BitBLT), Bi-linear filter or Bi-cubic filter
- Arbitrary non-integer scaling ratio, from 1/2 to 8
- Average filter pre-scaling (2's Down-scalingbypass path, not available with other 2D operation)

### **♦** Rotation

- Arbitrary rotation, minimum 1 degree step
- No per-pixel alpha in arbitrary ratation (without 90, 180, 270)
- x-mirror, y-mirror

#### ◆ BitBLT

- Block transfer
- Color palette (with transparency mode)/Color fill
- Transparency mode (color keying/stencil test, specified value/range)

#### **♦** Alpha Blending

- Per-pixel/user-specified alpha blending (Porter-duff alpha support)
- Fading
- Anti-aliasing (for rotation)

### **♦** Raster operation

- ROP2/ROP3/ROP4
- NoROP in arbitrary rotation (except90/180/270 degree)

#### Line/Point drawing

- Bresonham algorithm, Specified width
- Anti-aliasing

#### ♦ Blur/sharpness

- Bypass post processingpath (not avaliable with other 2D operation)
- Tile\_based

For detailed information about RGA, please refer to **RK30xx RGA.pdf**.



## Chapter 24 HDMI TX

#### 24.1 Overview

HDMI TX is fully compliant with HDMI 1.4a specification. It offers a simple implementation for consumer electronics like DVD/player/recorder and camcorder. HDMI TX consists of one HMDI transmitter controller and one HMDI transmitter PHY.

#### 24.1.1 Features

- ◆ HDMI version 1.4a, HDCP revision 1.4 and DVI version 1.0 compliant transmitter
- Supports DTV from 480i to 1080i/p HD resolution, and PC from VGA to UXGA
- ◆ Supports 3D and 2k x 4k video resolution output
- ◆ Programmable 2-way color space converter
- ◆ Compliant with EIA/CEA-861D
- xvYCC Enhanced Colorimetry
- ♦ Gamut Metadata transmission
- Supports RGB, YCbCr digital video input format includes ITU.656
- ◆ Supports standard SPDIF for stereo or compressed audio up to 192KHz
  - Support PCM, Dolby digital, DTS digital audio transmission through 4bits I2S up to 8 channel
  - IEC60958 or IEC61937 compatible
- ◆ Master I2C interface for DDC connection
- ◆ Configuration registers programmable via parallel interface
- ♦ Wide range channel speed up to 2.2Gbps
- Programmable PLL characteristics, channel delay, and transmitter pre-emphasis rate
- Small ISI jitter by full differential data path

# 24.2 Block Diagram



Fig. 24-1HDMI TX Block Diagram

# 24.3 Function Description

### 24.3.1 Video Data Processing

The following diagram shows video data processing path.



Fig. 24-2HDMI TXVideo Data Processing

### 23.3.1.1 Video Data Capture Logic

Video Data Capture Logic takes in uncompressed digital video through an interface from 8 to 24 bits in width. The interface has three (3) 8-bit data channels which can be configured for a number of different video formats (VID). It provides a direct connection to major MPEG decoders. The interface is configured by registers to set the bus width and format (8/10/12/16/20/24-bit) and rising/falling edge latching. The appropriate registers must be configured to describe which format of video is being input. This information is passed over the HDMI link in the CEA-861D Active Video Information (AVI) packets. It also supports dual-edge clocking using 8-18 data pins.



Table 24-1HDMI TX Supported Input Video Formats

| Input ID | Color Space | Pixel Encoding | Sync     | Clock Rate | Bit Width per Color | Pin Count |
|----------|-------------|----------------|----------|------------|---------------------|-----------|
| 1        | RGB         | 4:4:4          | Separate | 1x         | 8                   | 24        |
| 2        | RGB         | 4:4:4          | Separate | DDR        | 8                   | 12        |
| 3        | YCbCr       | 4:4:4          | Separate | 1x         | 8                   | 24        |
| 4        | YCbCr       | 4:4:4          | Separate | DDR        | 8                   | 12        |
| 5        | YCbCr       | 4:2:2          | Separate | 1x         | 12                  | 24        |
| 6        | YCbCr       | 4:2:2          | Separate | 1x         | 10                  | 20        |
| 7        | YCbCr       | 4:2:2          | Separate | 1x         | 8                   | 16        |
| 8        | YCbCr       | 4:2:2          | Separate | DDR        | 12                  | 12        |
| 9        | YCbCr       | 4:2:2          | Separate | DDR        | 10                  | 10        |
| 10       | YCbCr       | 4:2:2          | Separate | DDR        | 8                   | 8         |
| 11       | YCbCr       | 4:2:2          | Separate | 2x         | 12                  | 12        |
| 12       | YCbCr       | 4:2:2          | Separate | 2x         | 10                  | 10        |
| 13       | YCbCr       | 4:2:2          | Separate | 2x         | 8                   | 8         |
| 14       | YCbCr       | 4:2:2          | Embedded | 1x         | 12                  | 24        |
| 15       | YCbCr       | 4:2:2          | Embedded | 1x         | 10                  | 20        |
| 16       | YCbCr       | 4:2:2          | Embedded | 1x         | 8                   | 16        |
| 17       | YCbCr       | 4:2:2          | Embedded | 2x         | 12                  | 12        |
| 18       | YCbCr       | 4:2:2          | Embedded | 2x         | 10                  | 10        |
| 19       | YCbCr       | 4:2:2          | Embedded | 2x         | 8                   | 8         |
| 20       | RGB         | 4:4:4          | Separate | 1x         | 12                  | 36        |
| 21       | RGB         | 4:4:4          | Separate | 1x         | 10                  | 30        |
| 22       | RGB         | 4:4:4          | Separate | DDR        | 12                  | 18        |
| 23       | RGB         | 4:4:4          | Separate | DDR        | 10                  | 18        |
| 24       | YCbCr       | 4:4:4          | Separate | 1x         | 12                  | 36        |
| 25       | YCbCr       | 4:4:4          | Separate | 1x         | 10                  | 30        |
| 26       | YCbCr       | 4:4:4          | Separate | DDR        | 12                  | 18        |
| 27       | YCbCr       | 4:4:4          | Separate | DDR        | 10                  | 18        |
| 28       | YCbCr       | 4:2:2          | Separate | 1x         | 12                  | 24        |
| 29       | YCbCr       | 4:2:2          | Separate | 1x         | 10                  | 20        |
| 30       | YCbCr       | 4:2:2          | Separate | ITU656     | 12                  | 12        |
| 31       | YCbCr       | 4:2:2          | Separate | ITU656     | 10                  | 10        |
| 32       | YCbCr       | 4:2:2          | Separate | ITU656     | 8                   | 8         |
| 33       | YCbCr       | 4:2:2          | Embedded | ITU656     | 12                  | 12        |
| 34       | YCbCr       | 4:2:2          | Embedded | ITU656     | 10                  | 10        |
| 35       | YCbCr       | 4:2:2          | Embedded | ITU656     | 8                   | 8         |

### 1. Video input data pin assignment

The below tables show the data assignment for each input video modes. For double data rate modes, (2, 4, 8, 9, and 10), timing should be arranged so that the data on the first row (indicated with letter "R") are latched with rising edge of the clock and the data on the second row (indicated with letter "F") are latched with falling edge of the clock. Note that video data input ports colored by "gray" shall be fixed by "0".



Table 24-2HDMI TX Video Data Assignment (1-19)

| Inpu | t ID         |                         | data[23:0] ([Rs[7:0], Gs | [7:0], Bs[7:0] | 1})      |          |       |                     |      |
|------|--------------|-------------------------|--------------------------|----------------|----------|----------|-------|---------------------|------|
|      |              | 23 22 21 20 19 18 17 16 |                          |                |          | 7 6      |       |                     | 1 0  |
| 1    | R            | R[7:0]                  | G[7:                     | 0]             |          |          | B[7:0 | 0]                  |      |
| 2    | F            |                         | •                        | G[3:           | 0]       |          | B[7:0 | 0]                  |      |
|      | R            |                         |                          |                | R[       | 7:0]     |       | G[7                 | :4]  |
| 3    | R            | Cr[7:0]                 | Y[7:0                    | )]             |          |          | Cb[7: | 0]                  |      |
| 4    | F            |                         |                          | Y[3:           | 0]       |          | Cb[7: | 0]                  |      |
|      | R            |                         |                          |                | Or[      | 7:0]     |       | Y[7:                | 4]   |
| 5    | P0           | Cb0[11:4]               | Y0[11                    | :4]            |          | Сьо[3    | 3:0]  | Y0[3                | k:0] |
|      | P1           | Cr0[11:4]               | Y1[11                    |                |          | Cr0[3    | 3:0]  | Y1[3                | :0]  |
| 6    | P0           | Сь0[9:2]                | Y0[9:                    | •              |          | Cb0[1:0] |       | Y0[1:0]             |      |
|      | P1           | Cr0[9:2]                | Y1[9:                    | •              |          | Cr0[1:0] |       | Y1[1:0]             |      |
| 7    | P0           | Сь0[7:0]                | Y0[7:                    |                |          |          |       |                     |      |
|      | P1           | Cr0[7:0]                | Y1[7:                    |                |          |          |       |                     |      |
| 8    | P0-F         |                         |                          | Y0[7           |          | Сро[3    | 3:0]  | Y0[3                |      |
|      | P0-R         |                         |                          |                |          | 11:4]    |       | Y0[1                |      |
|      | P1-F         |                         |                          | Y1[7           |          | Cr0[3    | 3:0]  | Y1[3                |      |
|      | P1-R         |                         |                          |                |          | 11:4]    |       | Y1[1                | 1:8] |
| 9    | P0-F         |                         |                          | Y0[5:4]        |          | 0[3:0]   | Y0[   |                     |      |
|      | P0-R         |                         |                          |                | Cb0[9:4] |          | Y0[   | -                   |      |
|      | P1-F         |                         |                          | Y1[5:4]        |          | 0[3:0]   | Y1[   |                     |      |
|      | P1-R         |                         |                          |                | Cr0[9:4] |          | Y1[   | 9:6]                |      |
| 10   | P0-F         |                         |                          | CP0[3          |          | Y0[3     |       |                     |      |
|      | P0-R         |                         |                          | Сь0[7          |          | Y0[7     |       |                     |      |
|      | P1-F         |                         |                          | Or0[3          |          | Y1[3     |       |                     |      |
|      | P1-R         |                         |                          | Cr0[7          | [:4]     | Y1[7     | :4]   |                     |      |
| 11   | P0-R         |                         | Cb0[11                   |                |          |          |       | СР0[                |      |
|      | P0-R         |                         | Y0[11                    |                |          |          |       | Y0[3                |      |
|      | P1-R<br>P1-R |                         | Or0[11                   |                |          |          |       | Cr0[3               |      |
| 12   | P1-R<br>P0-R |                         | Y1[11                    | •              |          |          |       | Y1[3                | ::O] |
| 12   | P0-R         |                         | Cb0[9<br>Y0[9:           |                |          |          |       | Cb0[1:0]<br>Y0[1:0] |      |
|      | P1-R         |                         | To[9.                    |                |          |          |       | Cr0[1:0]            |      |
|      | P1-R         |                         | Y1[9:                    |                |          |          |       | Y1[1:0]             |      |
| 13   | P0-R         |                         | Cb0[7                    |                |          |          |       | 11[1.0]             |      |
|      | P0-R         |                         | Y017:                    |                |          |          |       |                     |      |
|      | P1-R         |                         | Cr0[7                    |                |          |          |       |                     |      |
|      | P1-R         |                         | Y1[7:                    |                |          |          |       |                     |      |
| 14   | P0           | Cb0[11:4]               | Y0[11                    |                |          | Сь0[3    | 3:01  | Y0[3                | i:01 |
|      | P1           | Cr0[11:4]               | Y1[11                    |                |          | Cr0[3    |       | Y1[3                |      |
| 15   | P0           | Cb0[9:2]                | Y0[9:                    |                |          | Cb0[1:0] |       | Y0[1:0]             |      |
|      | P1           | Cr0[9:2]                | Y1[9:                    |                |          | Cr0[1:0] |       | Y1[1:0]             |      |
| 16   | P0           | Сь0[7:0]                | Y0[7:                    |                |          |          |       |                     |      |
|      | P1           | Cr0[7:0]                | Y1[7:                    |                |          |          |       |                     |      |
| 17   | P0-R         |                         | Cb0[11                   | 1:4]           |          |          |       | Сь0[                | 3:0] |
|      | P0-R         |                         | Y0[11                    | :4]            |          |          |       | Y0[3                | :0]  |
|      | P1-R         |                         | Cr0[11                   | •              |          |          |       | Or0[3               |      |
|      | P1-R         |                         | Y1[11                    | -              |          |          |       | Y1[3                | 3:0] |
| 18   | P0-R         |                         | CP0[8                    | •              |          |          |       | Cb0[1:0]            |      |
|      | P0-R         |                         | Y0[9:                    |                |          |          |       | Y0[1:0]             |      |
|      | P1-R         |                         | Cr0[9                    |                |          |          |       | Cr0[1:0]            |      |
|      | P1-R         |                         | Y1[9:                    | •              |          |          |       | Y1[1:0]             |      |
| 19   | P0-R         |                         | Cb0[7                    | •              |          |          |       |                     |      |
|      | P0-R         |                         | Y0[7:                    |                |          |          |       |                     |      |
|      | P1-R         |                         | Cr0[7                    |                |          |          |       |                     |      |
|      | P1-R         |                         | Y1[7:                    | 0]             |          |          |       |                     |      |

Table 24-3HDMI TX Video Data Assignment (20-29)

| Input | ID |         |         | data[35:0] ([D | CR[3:0], DCG[3:0], DCB[3:0 | , Rs[ | 7:0], Gs[7:0 | ], Bs[7:0]}) |         |    |         |
|-------|----|---------|---------|----------------|----------------------------|-------|--------------|--------------|---------|----|---------|
|       |    | 35~32   | 31~28   | 27~24          | 23~16                      |       |              | 15~8         |         |    | 7~0     |
| 20    | R  | R[3:0]  | G[3:0]  | B[3:0]         | R[11:4]                    |       |              | G[11:4]      |         | В  | [11:4]  |
| 21    | R  | R[1:0]  | G[1:0]  | B[1:0]         | R[9:2]                     |       |              | G[9:2]       |         | E  | 3[9:2]  |
| 22    | F  |         |         |                | G[1:                       | )]    | B[3:         | 0]           | G[7:4]  | В  | [11:4]  |
|       | R  |         |         |                |                            | R[3:  |              | G[3:2]       | R[11:4  |    | G[11:8] |
| 23    | F  |         |         |                |                            |       | B[1:0]       |              | G[5:2]  | E  | [9:2]   |
|       | R  |         |         |                | R[1:0                      |       |              | G[1:0]       | R[9:2]  |    | G[9:6]  |
| 24    | R  | Or[3:0] | Y[3:0]  | Cb[3:0]        | Or[11:4]                   |       |              | Y[11:4]      |         | C  | [11:4]  |
| 25    | R  | Cr[1:0] | Y[1:0]  | Cb[1:0]        | Cr[9:2]                    |       |              | Y[9:2]       |         | О  | b[9:2]  |
| 26    | F  |         |         |                | Y[1:0                      | 1     | Cb[3         | k:0]         | Y[7:4]  | Ct | [11:4]  |
|       | R  |         |         |                |                            | Cr[3: | :0]          | Y[3:2]       | Cr[11:4 | 4] | Y[11:8] |
| 27    | F  |         |         |                |                            |       | Cb[1:0]      |              | Y[5:2]  | C  | b[9:2]  |
|       | R  |         |         |                | Cr[1:                      | וו    |              | Y[1:0]       | Cr[9:2  |    | Y[9:6]  |
| 28    | P0 |         | Y0[3:0] | Cb[3:0]        |                            |       | Y0[11:4]     |              |         | Ct | [11:4]  |
|       | P1 |         | Y1[3:0] | Or[3:0]        |                            |       |              | Y1[11:4]     |         | O  | r[11:4] |
| 29    | PO |         | Y0[1:0] | Cb[1:0]        |                            |       |              | Y0[9:2]      |         | C  | b[9:2]  |
|       | Ē  |         | Y1[1:0] | Cr[1:0]        |                            |       |              | Y1[9:2]      |         | C  | r[9:2]  |



Table 24-4HDMI TX Video Data Assignment (30-35)

| Inpu | t ID |    |    |    |    |    |    |    |    | data      | [23:0] | ([Rs[] | 7:0], G | [7:0], E | 3s[7:0]) | ) |   |          |     |       |   |         |       |      |        |
|------|------|----|----|----|----|----|----|----|----|-----------|--------|--------|---------|----------|----------|---|---|----------|-----|-------|---|---------|-------|------|--------|
|      |      | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15        | 14     | 13     | 12      |          | 10       | 9 | 8 | 7        | 6   | 5     | 4 | 3       | 2     | 1    | 0      |
| 30   | P0-R |    |    |    |    |    |    |    |    |           |        |        |         | 11:4]    |          |   |   |          |     |       |   |         | Сь0[  |      |        |
|      | P0-R |    |    |    |    |    |    |    |    | Y0[11:4]  |        |        |         |          |          |   |   | Y0[3:0]  |     |       |   |         |       |      |        |
|      | P1-R |    |    |    |    |    |    |    |    | Cr0[11:4] |        |        |         |          |          |   |   | Cr0[3:0] |     |       |   |         |       |      |        |
|      | P1-R |    |    |    |    |    |    |    |    |           |        |        |         | 11:4]    |          |   |   |          |     |       |   | Y1[3:0] |       |      |        |
| 31   | P0-R |    |    |    |    |    |    |    |    | Cb0[9:2]  |        |        |         |          |          |   |   |          | СРО | [1:0] |   |         |       |      |        |
|      | P0-R |    |    |    |    |    |    |    |    |           |        |        | Y0      | 9:2]     |          |   |   |          |     |       |   | Y0      | [1:0] |      |        |
|      | P1-R |    |    |    |    |    |    |    |    |           |        |        |         | [9:2]    |          |   |   |          |     |       |   |         | [1:0] |      |        |
|      | P1-R |    |    |    |    |    |    |    |    |           |        |        | Y1      | 9:2]     |          |   |   |          |     |       |   | Y1      | [1:0] |      |        |
| 32   | P0-R |    |    |    |    |    |    |    |    |           |        |        | Cb0     | [7:0]    |          |   |   |          |     |       |   |         |       |      |        |
|      | P0-R |    |    |    |    |    |    |    |    |           |        |        |         | 7:0]     |          |   |   |          |     |       |   |         |       |      |        |
|      | P1-R |    |    |    |    |    |    |    |    |           |        |        | Cr0     | [7:0]    |          |   |   |          |     |       |   |         |       |      |        |
|      | P1-R |    |    |    |    |    |    |    |    |           |        |        | Y1      | 7:0]     |          |   |   |          |     |       |   |         |       |      |        |
| 33   | P0-R |    |    |    |    |    |    |    |    |           |        |        | Cb0     | 11:4]    |          |   |   |          |     |       |   |         | Ср0[  | 3:0] |        |
|      | P0-R |    |    |    |    |    |    |    |    |           |        |        | Y0[     | 11:4]    |          |   |   |          |     |       |   |         | Y0[3  | :0]  |        |
|      | P1-R |    |    |    |    |    |    |    |    |           |        |        | Cr0[    | 11:4]    |          |   |   |          |     |       |   |         | Cr0[3 | 3:0] |        |
|      | P1-R |    |    |    |    |    |    |    |    |           |        |        |         | 11:4]    |          |   |   |          |     |       |   |         | Y1[3  | :0]  | $\neg$ |
| 34   | P0-R |    |    |    |    |    |    |    |    |           |        |        | Cb0     | [9:2]    |          |   |   |          |     |       |   | СРО     | [1:0] |      |        |
|      | P0-R |    |    |    |    |    |    |    |    |           |        |        | Y0      | 9:2]     |          |   |   |          |     |       |   | Y0      | [1:0] |      |        |
|      | P1-R |    |    |    |    |    |    |    |    |           |        |        | Cr0     | [9:2]    |          |   |   |          |     |       |   | Cr0     | [1:0] |      |        |
|      | P1-R |    |    |    |    |    |    |    |    |           |        |        | Y1      | 9:2]     |          |   |   |          |     |       |   | Y1      | [1:0] |      |        |
| 35   | P0-R |    |    |    |    |    |    |    |    |           |        |        | СЬО     | [7:0]    |          |   |   |          |     |       |   |         |       |      |        |
|      | P0-R |    |    |    |    |    |    |    |    |           |        |        | Y0      | 7:0]     |          |   |   |          |     |       |   |         |       |      | $\neg$ |
|      | P1-R |    |    |    |    |    |    |    |    |           |        |        | Cr0     | [7:0]    |          |   |   |          |     |       |   |         |       |      |        |
|      | P1-R |    |    |    |    |    |    |    |    |           |        |        | Y1      | 7:0]     |          |   |   |          |     |       |   |         |       |      |        |



Fig. 24-3HDMI TX Video Input Timing ID.1



Fig. 24-4HDMI TX Video Input Timing ID.3

### 2. Video control register settings

- (1) Audio/Video Setting.1 (#54h) and Video Setting.3 (#350h) register It controls Data capture logics, 422 to 444 pixel encoding converter and Extract embedded Sync.
- (2) Video Setting.1 (#58h)
- It controls Data capture logics, YCbCr to RGB color space converter, Extract embedded Sync.
- (3) Deep Color Modes (#5Ch)
  - It controls Deep color FIFO.
- (4) Color space conversion configuration.1(#34Ch)
  - It controls Data capture logics and YCbCr to RGB color space converter.

Table 24-5HDMI TX control register settings for each video input ID.

| ID | Input Format                              | Output Format | 15h | 16h | 17h | D3h          | D4h |
|----|-------------------------------------------|---------------|-----|-----|-----|--------------|-----|
| 1  | RGB 4:4:4, Separate SYNC, 1x clk, 8 bit   | RGB 4:4:4     | 00h | 34h | 20h | 81h          | 00h |
|    |                                           | YCbCr 4:4:4   | 00h | 74h | 20h | *1           | 00h |
|    |                                           | YCbCr 4:2:2   | 00h | B4h | 20h | *1           | 00h |
| 2  | RGB 4:4:4, Separate SYNC, DDR, 8 bit      | RGB 4:4:4     | 0Ah | 34h | 20h | 81h          | 00h |
|    |                                           | YCbCr 4:4:4   | 0Ah | 74h | 20h | *1           | 00h |
|    |                                           | YCbCr 4:2:2   | 0Ah | B4h | 20h | *1           | 00h |
| 3  | YCbCr 4:4:4, Separate SYNC, 1x clk, 8 bit | YCbCr 4:4:4   | 00h | 75h | 20h | 81h          | 00h |
|    |                                           | RGB 4:4:4     | 00h | 35h | 20h | 81h          | 00h |
|    |                                           | YCbCr 4:2:2   | 00h | B5h | 20h | 81h          | 00h |
| 4  | YCbCr 4:4:4, Separate SYNC, DDR, 8 bit    | YCbCr 4:4:4   | 0Ah | 75h | 20h | 81h          | 00h |
|    |                                           | RGB 4:4:4     | 0Ah | 35h | 20h | 81h          | 00h |
|    |                                           | YCbCr 4:2:2   | 0Ah | B5h | 20h | 81h          | 00h |
|    |                                           | <u> </u>      | •   | :   |     | <del>'</del> | ٠.  |

<sup>\*1 :</sup> Color space conversion from RGB to YCbCr is not automatically. To convert the colors, set appropriate coefficients into 18h~2Ch and set bit0 of 3Bh to turn on color conversion.



When the manual CSC is performed, auto bit (bit7 of D3h) must be cleared.

\*2: ITU656 stream is taken from any of the 3 channels. The value is specified in bit 3:2 in 16h register. The default (and also this example) uses ch1 (D8-D15).

### 23.3.1.2 Setting Video ID (VID) in CEA-861D

There are two methods to specify VID.

1. Using external video parameter setting registers.

HDMI TX supports any type of video format by setting appropriate values to External video parameter

Registers as below.

Address C0h External video parameter settings

Address C4h External horizontal total (LSB)

Address C8h External horizontal total (MSB)

Address CCh External horizontal blank (LSB)

Address D0h External horizontal blank (MSB)

Address D4h External horizontal delay (LSB)

Address D8h External horizontal delay (MSB)

Address DCh External horizontal duration (LSB)

Address E0h External horizontal duration (MSB)

Address E4h External vertical total (LSB)

Address E8h External vertical total (MSB)

Address F4h External vertical blank

Address F8h External vertical delay

Address FCh External vertical duration

In order to activate these register values, bit.0 in External video parameter settings register shall be set. Refer to diagram below for each parameters correspondence at video format.



Fig. 24-5HDMI TXExternal Video Parameter Setting

& Address 32h
External horizontal total (MSB)

### External video parameter setting value

#### Example for VID2





Fig. 24-6HDMI TXExternal Video SettingParameters Diagram



Table 24-6HDMI TX External Video Setting Example

The following is an example of external video parameter registers.

| Addr. | Register Name                         | VID7 | VID3 | VID10 | VID14<br>VID15 | VID18 | VID22 | MD25<br>MD26 | VID29<br>VID30 | VID35<br>VID36 | VID37<br>VID38 |
|-------|---------------------------------------|------|------|-------|----------------|-------|-------|--------------|----------------|----------------|----------------|
| #30h  | External video parameter<br>settings  | 33h  | 61h  | 33h   | 61h            | 01h   | 03h   | 03h          | 01h            | 61h            | 01h            |
| #31h  | External horizontal total (LSB)       | B4h  | 5Ah  | 68h   | B4h            | 60h   | C0h   | 80h          | C0h            | 68h            | 80h            |
| #32h  | External horizontal total (MSB)       | 06h  | 03h  | 0Dh   | 06h            | 03h   | 06h   | 0Dh          | 06h            | 0Dh            | 0Dh            |
| #33h  | External horizontal blank (LSB)       | 14h  | 8Ah  | 28h   | 14h            | 90h   | 20h   | 40h          | 20h            | 28h            | 40h            |
| #34h  | External horizontal blank<br>(MSB)    | 01h  | 00h  | 02h   | 01h            | 00h   | 01h   | 02h          | 01h            | 02h            | 02h            |
| #35h  | External horizontal delay (LSB)       | EEh  | 7Ah  | DCh   | F4h            | 84h   | 08h   | 10h          | 08h            | E8h            | 10h            |
| #36h  | External horizontal delay (MSB)       | 00h  | 00h  | 01h   | 00h            | 00h   | 01h   | 02h          | 01h            | 01h            | 02h            |
| #37h  | External horizontal duration<br>(LSB) | 7Ch  | 3Eh  | F8h   | 7Ch            | 40h   | 7Eh   | FCh          | 80h            | F8h            | 00h            |
| #38h  | External horizontal duration<br>(MSB) | 00h  | 00h  | 00h   | 00h            | 00h   | 00h   | 00h          | 00h            | 00h            | 01h            |
| #39h  | External vertical total (LSB)         | 0Dh  | 0Dh  | 0Dh   | 0Dh            | 71h   | 71h   | 71h          | 71h            | 0Dh            | 71h            |
| #3Ah  | External vertical total (MSB)         | 02h  | 02h  | 02h   | 02h            | 02h   | 02h   | 02h          | 02h            | 02h            | 02h            |
| #3Dh  | External vertical blank               | 16h  | 2Dh  | 16h   | 2Dh            | 31h   | 18h   | 18h          | 31h            | 2Dh            | 31h            |
| #3Eh  | External vertical delay               | 15h  | 2Ah  | 15h   | 2Ah            | 2Ch   | 16h   | 16h          | 2Ch            | 2Ah            | 2Ch            |
| #3Fh  | External vertical duration            | 03h  | 06h  | 03h   | 06h            | 05h   | 03h   | 03h          | 05h            | 06h            | 05h            |

Additionally, appropriate data shall be set into AVI InfoFrame data buffer including VID.

#### Special video format (1)

The following special video format can also be supported by using external video parameter settings. Note that "virtual VID" is just for simulation purpose and not compliant with CEA861D.

|           |       |                | iubic 2    | 7 / 110    | 111 17 5    | peciai v    | riaco i    | ormac      |                |                    |
|-----------|-------|----------------|------------|------------|-------------|-------------|------------|------------|----------------|--------------------|
| metho     | d     | Vertial<br>VID | H<br>total | V<br>total | H<br>active | V<br>active | H<br>blank | V<br>blank | V Freq<br>(Hz) | Pixel<br>Freq(MHz) |
| 480i60Hz  | Field |                | 858        | 1050       | 720         | 240 x4      | 138        | 22         | 29.97          | 27                 |
|           |       | Code106        | 000        |            |             |             | 130        |            |                |                    |
| 576i50Hz  | alt.  | Code121        | 864        | 1250       | 720         | 288 x4      | 144        | 24         | 25             | 27                 |
| 1080i60Hz |       | Code105        | 2200       | 2250       | 1920        | 540 x4      | 280        | 22         | 30(29.97)      | 148.5(148.351)     |
| 1080i50Hz |       | Code139        | 2304       | 2500       | 1920        | 540 x4      | 384        | 85         | 25             | 144                |
| 1080i50Hz |       | Code120        | 2640       | 2250       | 1920        | 540 x4      | 720        | 22         | 25             | 148.5              |
| 480p60Hz  | Frame | Code102        | 858        | 1050       | 720         | 480 x2      | 138        | 45         | 59.94          | 54                 |
| 576p50Hz  | alt   | Code117        | 864        | 1250       | 720         | 576 x2      | 144        | 49         | 50             | 54                 |
| 720p60Hz  |       | Code104        | 1650       | 1500       | 1280        | 720 x2      | 370        | 30         | 60(59.94)      | 148.5(148.351)     |
| 720p50Hz  | ]     | Code119        | 1980       | 1500       | 1280        | 720 x2      | 700        | 30         | 59             | 148.5              |
| 720p24Hz  |       | Code160        | 3300       | 1500       | 1280        | 720 x2      | 2020       | 30         | 24(23.976)     | 118.8(118.681)     |
| 1080p24Hz | ]     | Code132        | 2750       | 2250       | 1920        | 1080 x2     | 830        | 45         | 24(23.976)     | 148.5(148.351)     |

Table 24-7HDMI TX Special video format

The following is table of external video parameter registers for special video formats.

Table 24-8HDMI TX External Video ParameterSetting for Special video format



| Addr. | Register Name                      | Code<br>106 | Code<br>121 | Code<br>105 | Code<br>139 | Code<br>120 | Code<br>102 | Code<br>117 | Code<br>104 | Code<br>119 | Code<br>160 | Code<br>132 |
|-------|------------------------------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|
| #30h  | External video parameter settings  | 01h         | 01h         | 0Dh         | 05h         | 0Dh         | 01h         | 01h         | 0Dh         | 0Dh         | 0Dh         | 0Dh         |
| #31h  | External horizontal total (LSB)    | 5Ah         | 60h         | 98h         | 00h         | 50h         | 5Ah         | 60h         | 72h         | BCh         | E4h         | BEh         |
| #32h  | External horizontal total (MSB)    | 03h         | 03h         | 08h         | 09h         | 0Ah         | 03h         | 03h         | 06h         | 07h         | 0Ch         | 0Ah         |
| #33h  | External horizontal blank (LSB)    | 8Ah         | 90h         | 18h         | 80h         | D0h         | 8Ah         | 90h         | 72h         | BCh         | E4h         | 3Eh         |
| #34h  | External horizontal blank (MSB)    | 00h         | 00h         | 01h         | 01h         | 02h         | 00h         | 00h         | 01h         | 02h         | 07h         | 03h         |
| #35h  | External horizontal delay (LSB)    | 77h         | 84h         | C0h         | 60h         | C0h         | 7Ah         | 84h         | 04h         | 04h         | 04h         | C0h         |
| #36h  | External horizontal delay (MSB)    | 00h         | 00h         | 00h         | 01h         | 00h         | 00h         | 00h         | 01h         | 01h         | 01h         | 00h         |
| #37h  | External horizontal duration (LSB) | 3Eh         | 3Fh         | 2Ch         | A8h         | 2Ch         | 3Eh         | 40h         | 28h         | 28h         | 28h         | 2Ch         |
| #38h  | External horizontal duration (MSB) | 00h         |
| #39h  | External vertical total (LSB)      | 1Ah         | E2h         | CAh         | C4h         | CAh         | 1Ah         | E2h         | DCh         | DCh         | DCh         | CAh         |
| #3Ah  | External vertical total (MSB)      | 04h         | 04h         | 08h         | 09h         | 08h         | 04h         | 04h         | 05h         | 05h         | 05h         | 08h         |
| #3Dh  | External vertical blank            | 16h         | 18h         | 16h         | 55h         | 16h         | 2Dh         | 31h         | 1Eh         | 1Eh         | 1Eh         | 2Dh         |
| #3Eh  | External vertical delay            | 12h         | 16h         | 14h         | 55h         | 14h         | 24h         | 2Ch         | 19h         | 19h         | 1Eh         | 29h         |
| #3Fh  | External vertical duration         | 03h         | 03h         | 05h         | 05h         | 05h         | 06h         | 05h         | 05h         | 05h         | 05h         | 05h         |

#### (2) Vertical blanking insertion

Maximun 3 of vertical blanking duration can be inserted at any position during vertical active video line. It works with external DE input mode, i.e. bit.0 of #54h shall be set.

The start vertical line number and blanking duration shall be specified by #3CCh - #3ECh registers. Refer to 1.4 for detail. External DE input shall be toggled by exact timing according to register settings.

### Support variable duration of HSYNC/VSYNC input

In order to allow variable duration of HSYNC/VSYNC input signaling, Video input option register (#3F0h) settings are required. Refer to 1.4 for detail.

#### 2. Using pre-programmed VID

HDMI TX has pre-programmed VID settings internally for basic video formats as below.

| VID | Horizontal total | Vertical total | Progressive/Interlace | Pixel clock (MHz) | V freq. (Hz) |
|-----|------------------|----------------|-----------------------|-------------------|--------------|
| 1   | 640              | 480            | P                     | 25.20/25.175      | 60/59.94     |
| 2   | 720              | 480            | P                     | 27.027/27.00      | 60/59.94     |
| 4   | 1280             | 720            | P                     | 74.25/74.176      | 60/59.94     |
| 5   | 1920             | 1080           | 1                     | 74.25/74.176      | 60/59.94     |
| 6   | 1440             | 480            | I                     | 27.027/27.00      | 60/59.94     |
| 16  | 1920             | 1080           | P                     | 148.5/148.352     | 60/59.94     |
| 17  | 720              | 576            | P                     | 27.00             | 50           |
| 19  | 1280             | 720            | P                     | 74.25             | 50           |
| 20  | 1920             | 1080           | I                     | 74.25             | 50           |
| 21  | 1440             | 576            | I                     | 27.00             | 50           |
| 31  | 1920             | 1080           | Р                     | 148.5             | 50           |
| 32  | 1920             | 1080           | P                     | 74.25             | 24           |

Table 24-9HDMI TX External Video ParameterSetting for Special video format

Host controller shall set just appropriate VID to AVI InfoFrame data buffer for PB4, i.e. #19Ch(PB4) with index register #17Ch=06h(AVI InfoFrame) for pre-programmed VID. Also, bit.0 in External video parameter settings register (#C0h) shall be reset. Other external video setting register value shall be ignored.



### 23.3.1.3 Embedded Sync. Extraction

DE, HSYNC and VSYNC signals may be extracted from the start of active video (SAV) and end of active video (EAV) codes within the 656 video stream. Refer to a diagram as below for sync. extraction parameters.



Fig. 24-7HDMI TXEmbedded Sync. Extraction Parameters Diagram

### 23.3.1.4 Data Enable (DE) Generator

HDMI TX has DE signal generator by incoming HSYNCs, VSYNCs and idclk. External DE is optional and selected by appropriate register settings. This feature is particularly useful when interfacing to MPEG decoders that do not provide a specific DE output signal.

### 23.3.1.5 Color Space Converter

Color space converter (CSC) is available to interface to several MPEG decoders like with YCbCr-only outputs, and to provide full DVI 1.0 backwards compatibility.

### 1. Input/Output format

Color space: RGB or YCbCr

Pixel encoding: 4:4:4 Bit width: 8,10,12bit

### 2. Register settings

Refer to Register Settings for Each Video Formats table for detail.

3. Register Setting for coefficients of Color Space Conversion Color space conversion is supported via 3x3 matrix calculations. Predefined



coefficients are prepared for convenience, but users can modify the coefficients via register access. The predefined values are set as recommended in ITU-R BT 601.5 for SDTV and ITU-R BT 709.5 for HDTV and are only available for color conversion from YCbCr to RGB.

The predefined coefficients are loaded based on the following equations.

```
480p, 480i, 576p, 576i, 240p, and 288p - limited range (a)
```

R: Y + 1.403(Cr-128)

G: Y - 0.714(Cr-128) - 0.344(Cb-128)

B: Y + 1.773(Cb-128)

VGA - full range (b)

R: 1.164(Y-16) + 1.596(Cr-128)

G: 1.164(Y-16) - 0.813(Cr-128) - 0.391(Cb-128)

B: 1.164(Y-16) + 2.018(Cb-128)

1080i, 1080p, and 720p - limited range 60Hz (c)

R: Y + 1.5748(Cr-128)

G: Y - 0.4681(Cr-128) - 0.1873(Cb-128)

B: Y + 1.8556(Cb-128)

1080i, 1080p, and 720p - limited range 50Hz (d)

R: Y + 1.403(Cr-128)

G: Y - 0.714(Cr-128) - 0.344(Cb-128)

B: Y + 1.773(Cb-128)

The equation to calculate CSC is defined as follows:

R: (C0\*Y + C1\*Cr + C2\*Cb) / 1024 + C3

G: (C4\*Y + C5\*Cr + C6\*Cb) / 1024 + C7

B: (C8\*Y + C9\*Cr + C10\*Cb) / 1024 + C11

The value C0 is {csc\_coeff\_hi[3:0], csc\_coeff\_lo[7:0]} of 60h and 64h registers. The value C1 is {csc\_coeff\_hi[3:0], csc\_coeff\_lo[7:0]} of 68h and 6Ch registers and so on. The value C3 is {csc\_coeff\_hi[0], csc\_coeff\_lo[7:0]} of 78h and 7Ch registers.

To use custom coefficient values, first clear csc auto bit in 34Ch register. Then write values into csc coeff registers. To enable CSC, set csc en bit in ECh register.

#### 4. CSC Coefficient Register Values

When auto CSC bit is set (it is set by default), CSC coefficients registers are loaded automatically to YCbCr to RGB conversion value. The values depend on the current video format in AVI InfoFrame. There are 4 types of CSC coefficients as described in the previous section. When AVI InfoFrame is not



set, the default format, SDTV limited range (a), is loaded. As soon as a valid AVI InfoFrame is written, the register values get overwritten by appropriate coefficients. The table below shows the pre-defined register values to be loaded into CSC coefficient registers.

Table 24-10HDMI TX CSC coeffcients Values

| CSC Register Addr | (a) SDTV limited range | (b) SDTV full range | (c) HDTV 60Hz | (d) HDTV 50Hz |
|-------------------|------------------------|---------------------|---------------|---------------|
| 18h               | 04                     | 04                  | 04            | 04            |
| 19h               | 00                     | A8                  | 00            | 00            |
| 1Ah               | 05                     | 06                  | 06            | 05            |
| 1Bh               | 9D                     | 62                  | 4D            | 9D            |
| 1Ch               | 00                     | 00                  | 00            | 00            |
| 1Dh               | 00                     | 00                  | 00            | 00            |
| 1Eh               | 02                     | 02                  | 02            | 02            |
| 1Fh               | B4                     | DF                  | CA            | B4            |
| 20h               | 04                     | 04                  | 04            | 04            |
| 21h               | 00                     | A8                  | 00            | 00            |
| 22h               | 12                     | 13                  | 11            | 12            |
| 23h               | DB                     | 41                  | DF            | DB            |
| 24h               | 11                     | 11                  | 10            | 11            |
| 25h               | 60                     | 90                  | C0            | 60            |
| 26h               | 00                     | 00                  | 00            | 00            |
| 27h               | 88                     | 87                  | 54            | 88            |
| 28h               | 04                     | 04                  | 04            | 04            |
| 29h               | 00                     | A8                  | 00            | 00            |
| 2Ah               | 00                     | 00                  | 00            | 00            |
| 2Bh               | 00                     | 00                  | 00            | 00            |
| 2Ch               | 07                     | 08                  | 07            | 07            |
| 2Dh               | 18                     | 12                  | 6C            | 18            |
| 2Eh               | 02                     | 03                  | 02            | 02            |
| 2Fh               | E3                     | 15                  | EE            | E3            |

### 23.3.1.6 Pixel Encoding Converter

HDMI TX has two kind of pixel encoding converter, up sampler and down sampler.

### 1. Input/Output format

4:2:2 to up sampler or 4:4:4 to down sampler

Output: 4:4:4 from up sampler or 4:2:2 from down sampler

### 2. Register settings

Refer to Register Settings for Each Video Formats table for detail.

### 23.3.1.7 HDCP Authentication

HDMI TXhas a capability for HDCP authentication by hardware. The following is state diagram of HDCP authentication.



Fig. 24-8 HDMI TX HDCP Authentication State Diagram

- Red task will be done by software that is initial command to start HDCP authentication.
- After green line that is error case or authentication done state, software gets interrupt from IP core.
- Violet states will be repeated during normal HDCP transmission.

### 23.3.1.8 HDCP Cipher Encryption

HDCP Cipher Encryption Block is compliant with HDCP 1.4 specification. Upon request via configuration register,



HDCP block can authenticate a connected device(s) and send encrypted data over HDMI. This block has following features.

Authenticate up to 2 receivers and repeaters with maximum cascade of 7.

Advanced Cipher Mode support.

Enhanced Link Verification support.

DVI Mode support.

Requires system software to check for Bksv revocation list.

23.3.1.9 HDCP key

HDCP key shall be stored in external memory. HDMI TX provides an interface to this memory and read key at beginning of HDCP authentication. Purchasing HDCP keys, programming and security are customer's responsibility.

#### 23.3.1.10 TMDS encoder

TMDS encoder performs 8-to-10-bit TMDS encoding on the audio/video/aux data received from the HDCP XOR mask. This data is output onto three TMDS differential data lines along with a TMDS differential clock. A resister tied to the REXT pin is used to control the TMDS swing amplitude.

#### 24.3.2 Audio Data Processing

HDMI TX supports digital audio over either SPDIF and four(4) I2S inputs.

### 23.3.2.1 SPDIF

SPDIF stream can carry 2-channel uncompressed PCM data (IEC 60958) or a compressed bit stream for multi-channel (IEC 61937) formats. The audio data capture logic forms the audio data into packets in accordance with the HDMI specification. SPDIF input supports audio sampling rates from 32 to 192kHz. The following shows the SPDIF audio formats that are supported for each of the video formats.

Table 24-11HDMI TX Supported SPDIF Sampling frequency at each video format

| Video Format        | 32kHz | 44.1kHz | 48kHz | 88.2kHz | 96kHz | 176.4kHz | 192kHz |
|---------------------|-------|---------|-------|---------|-------|----------|--------|
| 720x480p/720x576p   | Yes   | Yes     | Yes   | Yes     | Yes   | No       | No     |
| 1440x480i/1440x576i | Yes   | Yes     | Yes   | Yes     | Yes   | No       | No     |
| 720p                | Yes   | Yes     | Yes   | Yes     | Yes   | Yes      | Yes    |
| 1080i               | Yes   | Yes     | Yes   | Yes     | Yes   | Yes      | Yes    |
| 1080p               | Yes   | Yes     | Yes   | Yes     | Yes   | Yes      | Yes    |

#### 23.3.2.2 I2S

Four(4) I2S inputs also allow transmission of DVD-Audio and decoded Dolby Digital to A/V Receivers and high-end displays. The interface supports from 2-channel to 8-channel audio up to 192 kHz. The I2S pins must also be coherent with MCLK. The appropriate registers must be configured to describe the format of audio being input. This information is passed over the HDMI link in the CEA-861D Audio Info (AI) packets. Table shows the I2S 8 channel audio formats that are supported for each of the video formats.



Table 24-12HDMI TX Supported I2S 2Ch Audio Sampling frequency at each video format

| Video Format        | 32kHz | 44.1kHz | 48kHz | 88.2kHz | 96kHz | 176.4kHz | 192kHz |
|---------------------|-------|---------|-------|---------|-------|----------|--------|
| 720x480p/720x576p   | Yes   | Yes     | Yes   | Yes     | Yes   | Yes      | Yes    |
| 1440x480i/1440x576i | Yes   | Yes     | Yes   | Yes     | Yes   | Yes      | Yes    |
| 720p                | Yes   | Yes     | Yes   | Yes     | Yes   | Yes      | Yes    |
| 1080i               | Yes   | Yes     | Yes   | Yes     | Yes   | Yes      | Yes    |
| 1080p               | Yes   | Yes     | Yes   | Yes     | Yes   | Yes      | Yes    |

Table 24-13HDMI TX Supported I2S 8Ch Audio Sampling frequency at each video format

| Video Format        | 32kHz | 44.1kHz | 48kHz | 88.2kHz | 96kHz | 176.4kHz | 192kHz |
|---------------------|-------|---------|-------|---------|-------|----------|--------|
| 720x480p/720x576p   | Yes   | Yes     | Yes   | No      | No    | No       | No     |
| 1440x480i/1440x576i | Yes   | Yes     | Yes   | Yes     | No    | No       | No     |
| 720p                | Yes   | Yes     | Yes   | Yes     | Yes   | Yes      | Yes    |
| 1080i               | Yes   | Yes     | Yes   | Yes     | Yes   | Yes      | Yes    |
| 1080p               | Yes   | Yes     | Yes   | Yes     | Yes   | Yes      | Yes    |

### 1. Variable word length

HDMI TX supports variable word length, 16bits to 32bits for I2S audio inputs. Note that 32bits word lengthis not supported at Right-justified mode. It shall be controlled by bit.3-0 of Source number/Word length register (#54h).

#### 2. Interface modes

There are three (3) I2S input modes supported. These modes shall be controlled by bit.1-0 of I2S audio setting register (#30h).



Fig. 24-9HDMI TX I2S input timing at Standard I2S mode



Fig. 24-10HDMI TX I2S input timing at Left justified mode



#### 23.3.2.3 High Bit Rate Audio (HBR)

SPDIF stream can carry 2-channel uncompressed PCM data (IEC 60958) or a compressed bit stream for multi-channel (IEC 61937) formats. The audio data capture logic forms the audio data into packets in accordance with the HDMI specification. SPDIF input supports audio sampling rates from 32 to 192kHz. The following shows the SPDIF audio formats that are supported for each of the video formats.



Fig. 24-11 HDMI TX HBR data stream input ordering

#### 24.3.3 Controller Interface

#### 23.3.3.1 Interrupt Signals

intr n pin outputs a signal to interrupt the microcontroller based on the following conditions.

- Monitor Detect (either from the HPD input level, or from the Receiver Sense)
- VSYNC (It helps for host controller to synchronize with vertical timing interval)
- Error conditions like Audio FIFO overflow, HDCP authentication failure

Its active level can be configured by int\_omode signals.

The following shows the sheme of interrupt signaling.





Fig. 24-12 HDMI TXInterrupt Signaling Block Diagram

The source of interrupt signaling is varied depending on power save mode.

At power save mode a, the source of interrupt signaling is hot plug or msens input from external of HDMI TX which are asynchronous inputs. Interrupt status register shall not get set by them because clock for registers (i.e. DDC CK) is not active in power save mode a.

Host controller shall move to power save mode\_b once it gets interrupted in power save mode\_a. In power save mode\_b/d/e, the source of inpterrupt signaling shall be switched to wired-or signal of interrupt status register outputs. The interrupt status registers shall get set by hot plug and msens input in mode\_b/d/e because clock for registers (i.e. DDC\_CK) now becomes active in this power save mode. Refer to HOT PLUG DETECTION SEQUENCES for detail.

#### 23.3.3.2 DDC Master I2C Interface

HDMI TX has I2C Master Interface for DDC transactions. It enables for host controller to read EDID, HDCP authentication by issuing simple register access. The I2C bus speed is limited by DDC specification. DDC bus access frequency can be controlled by register #204h and #208h. Refer to register detail descriptions.

### 1. Access frequency

DDC bus access frequency can be programmed by registers. Refer to register detail descriptions for details.

#### 2. Access override

DDC bus access can be overrided by bus control registers. Refer to register detail descriptions for details.

### 3. SOC integration example

The following diagram shows an example of SOC integration related with DDC bus.





Fig. 24-13 HDMI TXintegration example diagram related with DDC bus

### 24.3.4 HDCP Key Memory Interface

HDCP in the external memory must be stored in the following manner. The table below shows a HDCP key as provided by DCP LLC.

- The first 4 bytes of the data "01 00 00 00" indicates that this file contains keys for TX side. The next 5 bytes of data "11 22 33 44 55" is the KSV example of 1st key.
- The next 3 bytes of data "00 00 00" are inserted as a place holder.
- The next 280 bytes of data starting at address 00Ch and ending at 123h is the private key example.
- The next 20 bytes of data starting at 124h and ending at 137h is hash value example of the key and this is the end of the 1st key.
- The next 5 bytes starting at 138h and ending at 13Ch is the next KSV and continues until the end of file.



| addr | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | Α  | В  | C  | D  | Ε  | F  |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 000h | 01 | 00 | 00 | 00 | 11 | 22 | 33 | 44 | 55 | 00 | 00 | 00 | 01 | 02 | 03 | 04 |
| 010h | 05 | 06 | 07 | 08 | 09 | 0a | 0b | 0c | 0d | 0e | Of | 10 | 11 | 12 | 13 | 14 |
| 020h | 15 | 16 | 17 | 18 | 19 | 1a | 1b | 1c | 1d | 1e | 1f | 20 | 21 | 22 | 23 | 24 |
| 030h | 25 | 26 | 27 | 28 | 29 | 2a | 2b | 2c | 2d | 2e | 2f | 30 | 31 | 32 | 33 | 34 |
| 040h | 35 | 36 | 37 | 38 | 39 | 3a | 3b | 3c | 3d | 3e | 3f | 40 | 41 | 42 | 43 | 44 |
| 050h | 45 | 46 | 47 | 48 | 49 | 4a | 4b | 4c | 4d | 4e | 4f | 50 | 51 | 52 | 53 | 54 |
| 060h | 55 | 56 | 57 | 58 | 59 | 5a | 5b | 5c | 5d | 5e | 5f | 60 | 61 | 62 | 63 | 64 |
| 070h | 65 | 66 | 67 | 68 | 69 | 6a | 6b | 6c | 6d | 6e | 6f | 70 | 71 | 72 | 73 | 74 |
| 080h | 75 | 76 | 77 | 78 | 79 | 7a | 7b | 7c | 7d | 7e | 7f | 80 | 81 | 82 | 83 | 84 |
| 090h | 85 | 86 | 87 | 88 | 89 | 8a | 8b | 8c | 8d | 8e | 8f | 90 | 91 | 92 | 93 | 94 |
| 0A0h | 95 | 96 | 97 | 98 | 99 | 9a | 9b | 9c | 9d | 9e | 9f | a0 | a1 | a2 | a3 | a4 |
| 0B0h | a5 | a6 | a7 | a8 | a9 | aa | ab | ac | ad | ae | af | b0 | b1 | b2 | b3 | b4 |
| 0C0h | b5 | b6 | b7 | b8 | b9 | ba | bb | bc | bd | be | bf | cO | c1 | c2 | c3 | c4 |
| 0D0h | c5 | c6 | c7 | с8 | с9 | ca | cb | CC | cd | ce | cf | d0 | d1 | d2 | d3 | d4 |
| 0E0h | d5 | d6 | d7 | d8 | d9 | da | db | dc | dd | de | df | e0 | e1 | e2 | e3 | e4 |
| 0F0h | e5 | e6 | e7 | e8 | e9 | ea | eb | ec | ed | ee | ef | f0 | f1 | f2 | f3 | f4 |
| 100h | f5 | f6 | f7 | f8 | f9 | fa | fb | fc | fd | fe | ff | 00 | 01 | 02 | 03 | 04 |
| 110h | 05 | 06 | 07 | 08 | 09 | 0a | 0b | 0c | 0d | 0e | Of | 10 | 11 | 12 | 13 | 14 |
| 120h | 15 | 16 | 17 | 18 | 00 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | 08 | 09 | 0a | 0b |
| 130h | 0c | 0d | 0e | Of | 10 | 11 | 12 | 13 | aa | bb | CC | dd | ee | 00 | 00 | 00 |

Table 24-14HDMI TX HDCP key map example as provided by DCP LLC

#### 24.3.5 Power Save Mode

HDMI TX supports multiple power save modes that realize most efficient power control. Table shows the summary of power save modes. Note that 1-10ms waiting time between each power save mode transition is required for stable PHY functions. The source signal of interrupt is varied depending on each power save mode. Refer to 1.3.3.1 Interrupt signaling for details.

| power save mode | idclk<br>input  | Clock<br>tree | TMDS<br>driver | Descriptions                                                                                                                                                                                                                                                                                | Active modules                                                                                                                                       |
|-----------------|-----------------|---------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| mode_a          | Not<br>required | OFF           | OFF            | Minimum power consumption Only power save mode register can be accessed.                                                                                                                                                                                                                    | slishdmi13t_ps_mode_reg                                                                                                                              |
| mode_b          | Required        | OFF           | OFF            | DDC I2C active  After PHY parameter settings, DDC_CK equals to idclk input.                                                                                                                                                                                                                 | slishdmi13t_ps_mode_reg<br>slishdmi13t_regs<br>slishdmi13t_l2c_edid<br>slishdmi13t_hot_plug<br>Note that clock tree for other<br>modules is inactive |
| mode_d          | Required        | ON            | OFF            | Internal clock tree active All logics except for control registers are under synchronous reset. Any unstable input signals shall not be propagated into logics.                                                                                                                             | Same as mode_b  Note that clock tree for all  modules is active                                                                                      |
| mode_e          | Required        | ON            | ON             | All functions are active It is prohibited for host controller to change some register settings under mode_e. It might cause functions unstable. Host controller shall get back to mode_d when it is required to change these register settings. Refer to 9.3 Register access rules chapter. | All modules                                                                                                                                          |

Table 24-15HDMI TX Power save mode summary

#### 24.3.6 Clock Distribution

#### 23.3.6.1 Input Clocks form Controller

- idclk (sc\_clk) MAX. Freq. = 148.5MHz at normal video input mode. It shall be provided by host controller. All video input data shall be synchronized with it. It is fed to all of HDMI TX logics at SCAN test mode.
- cpu clk



It shall be provided by host controller. It is required to access Power save mode register (Address.00h).

#### hdcp mem clk

It shall be provided by host controller. It is required to load HDCP key into HDMI TX.

#### mclk

MAX. Freq. = 73.728MHz

It shall be provided by audio source devices and shall be coherence with audio data input.

#### sclk

MAX. Freq. = 25MHz

It shall be provided by audio source devices and synchronized with sd[3:0] or dsd I[3:0]/dsd r[3:0] audio input data.

#### 23.3.6.2 Clocks from PHY to Controller

#### ■ IDCKX2

MAX. Freq. = 148.5MHz

Its frequency is double of idclk. It is fed for audio sampling modules. It is available at mode d/mode e in power save mode.

MAX. Freq. = 222.75MHz at deep color 12bit mode, 0r 148.5MHz at 8bit color depth

It is identical to TXC/TXC N on TMDS bus. Video input signals with idclk input are synchronized with TMDS CK by deep color.v module. It is available at mode d/mode e in power save mode.

#### DDC CK

MAX. Freq. = 148.5MHz

Its frequency depends on power save mode. Basically, DDC CK equals to idclk input once PHY parameters have been set.

#### LB CK

MAX. Freq. = 222.75MHz at deep color 12bit mode, 0r 148.5MHz at 8bit color depth

It is for loopback test mode. lb\_data[2:0] are synchronized with it.

#### FBCK A

MAX. Freq. = 148.5MHz

It is for PLL frequency test. It is generated by PLL\_A feedback clock.

#### FBCK B

MAX. Freq. = 222.75MHz at deep color 12bit mode, 0r 148.5MHz at 8bit color depth

It is for PLL frequency test. It is generated by PLL\_B feedback clock.



## 24.4 Register Description

24.4.1 Register Summary

24.4.2 Detail Register Description

Refer to 《RK30xx HDMI TX Register Description》



## 24.5 Interface Description

## 24.5.1 Video Input Source

In RK30xx, the HDMI TX video source comes from LCDC0 or LCDC1.

GRF\_SOC\_CON0[14] is the select bit for HDMI TX input.

GRF\_SOC\_CON0[14] = 1'b0: HDMI TX input from LCDC0;

GRF\_SOC\_CON0[14] = 1'b1: HDMI TX input from LCDC1;

#### 24.5.2 Audio Input Source

In RK30xx, the HDMI TX audio source comes from I2S\_8CH.

## 24.6 Programming Guide

## 24.6.1 Main Sequence

The following diagram shows video data processing path.



Fig. 24-14HDMI TX Software Main Sequence Diagram



In this diagram, "PS mode" means Power save mode and "#xxh" means register address xxh. Software works based on interrupt signaling from HDMI TX. After power on reset, host controller waits interrupt which indicates normally hot plug in and MSENS in. Once it is detected, host controller shall change power save mode of HDMI TX to mode\_b in order to access all of registers. Then, it starts to read EDID from receiver. Based on EDID information, host controller shall set video/audio parameters as well as PHY parameters. Then it will start TMDS transmitting by change power save mode, mode\_b->mode\_d-> mode\_e. Note that at entering into mode\_d, host controller shall clear bit.2 in #00h, then clear bit.3 in #00h to release reset of PLLA and PLLB. If HDCP encryption is required, host controller shall start HDCP authentications. The followings are more detail of each sub sequences.

Note that idclk clock input shall be stable at PHY parameter settings in mode b. Also, Video/Audio input shall be stable before entering PS mode d. And After setting Video/Audio/PHY parameter and entering into mode\_e, host controller shall set and clear bit2 in #114, for Audio reset.

When HDCP is required, it is recommended that host controller disable Video/Audio output before entering to mode e by setting bit.0-1 of #114 register that makes black video output and no audio output. Then, host controller resets these bits after HDCP authentication has been completed and encryption has started. These sequences prevent none encrypted Video/Audio are displayed until HDCP authentication has been completed.

When hot plug interrupt by unplug is detected in "TX start"/"TX start with encryption" state, it is required to write 11b to #114[1:0] to disable video/audio output first. Also, required to write 1b to #114[2] to do audio reset. Then PS mode shall move to mode d followed by mode b, mode a sequentially. Afer that, the state will return to "idle".

When video/audio settings need to be changed in "TX start"/"TX start with encryption" state, it is also required to write 11b to #114[1:0] to disable video/audio output first. Also, required to write 1b to #114[2] to do audio reset. Then PS mode shall move to mode\_d followed by mode\_b sequentially. Afer that, the state will return to "video settings".

Note that audio reset sequence (i.e. write 1b to #114[2]) is required just before getting out of power save mode\_e.

### 24.6.2 Hot Plug Detection Sequences



Fig. 24-15HDMI TX Hot Plug Sequence Diagram

When the host controller detects an interrupt at idle state (i.e. power save mode\_a), it shall change the power save mode to mode\_b and read interrupt status registers. If not hot plug interrupt, it shall change power save mode back to mode\_a and wait for the next interrupt. When hot plug interrupt is detected, wait for 10 ms in order to give sufficient time to get MSENS condition, then read



DFh register for hot plug and MSENS status (bit 7 and 6). If those two bits are high, move to the Reading EDID sequence.

Note that the source of interrupt signaling is varied depending on power save mode. Refer to 1.3.3.1 Interrupt signaling for detail.

#### 24.6.3 Reading EDID Sequence



Fig. 24-16HDMI TX Software EDID Read Sequence Diagram



EDID reading sequence needs to be repeated several times in order to read all EDID blocks from the connected device. After setting EDID interrupt enable, set EDID word address and segment pointer to select which EDID block to read. Writing segment pointer at register C4h starts the EDID reading. When EDID is read correctly, EDID\_RDY interrupt is generated. Otherwise, EDID\_ERR interrupt is generated and host shall retry EDID reading by setting the same word address and segment pointer. If successful, move to the next EDID block until it reads all blocks, and then disable the EDID interrupt.

## 24.6.4 TX Setting Sequence



Fig. 24-17HDMI TX Software TX SettingSequence Diagram

#### 23.6.4.1 Register Setting Summary for Video

The following registers shall be set to enable video input. Refer to each



register description for its detail function.

Table 24-16HDMI TX Register Setting Summary for Video

| Register               | Bit                                             | Setting value explanation                                                                                                          | Е                                | xample sett                      | ings                             |
|------------------------|-------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|----------------------------------|----------------------------------|
| address                |                                                 |                                                                                                                                    | 480p                             | 720p                             | 1080                             |
| #54h                   | [3:1]                                           | Input video format<br>Internal/External DE select                                                                                  | 3°5000                           | 3'b000<br>1'b0                   | 3'5000<br>1'50                   |
| #58h                   | [7:6]<br>[5:4]<br>[3:2]<br>[0]                  | Video output format<br>Input video data width<br>EAV/SAV location if embedded sync video input selected<br>Video input color space | 2'b00<br>2'b11<br>3'b010<br>1'b0 | 2'b00<br>2'b11<br>3'b010<br>1'b0 | 2'b00<br>2'b11<br>3'b010<br>1'b0 |
| #5Ch                   | [7:6]                                           | Deep color mode                                                                                                                    | 2'600                            | 2'b00                            | 2'600                            |
| #60 - #BC              | [7:0]                                           | Color space conversion parameters if required                                                                                      | N.A.                             | N.A.                             | N.A.                             |
| #C0 - #E8<br>#F4 - #FC | [7:0]                                           | External video parameter settings if it is enable by #30[0], i.e. non-preprogrammed VID used.                                      | #30[0]=1<br>Other bit            | 'b0<br>s are N.A.                |                                  |
| #ECh                   | [0]                                             | CSC enable if required                                                                                                             | 1'60                             | 1'60                             | 1'60                             |
| #114h                  | [7:6]                                           | AV mute control if required                                                                                                        | 2'600                            | 2'b00                            | 2'b00                            |
| #148-#154              | [7:0]                                           | SYNC placement it ITU656 video input mode selected                                                                                 | N.A.                             | N.A.                             | N.A.                             |
| #17C-#1F8              | I7C - #1F8 [7:0] Appropriate AVI InfoFrame data |                                                                                                                                    | 1,000,000,000                    | AVI InfoFrar                     |                                  |
| #34C                   | [7:0]                                           | CSC configuration if required                                                                                                      | N.A.                             | N.A.                             | N.A.                             |
| #350                   | [7:4]                                           | ITU656 control if required                                                                                                         | N.A.                             | N.A.                             | N.A.                             |

Note that example setting conditions are as below.

480p: 720x480p@59.94Hz(VID=2), Pre-programmed VID used, 8bit color depth, RGB input/output, CSC diable, I2S audio, fs=48KHz, 2Ch

720p: 1280x720p@60Hz(VID=4), Pre-programmed VID used, 8bit color depth, RGB input/output, CSC diable, I2S audio, fs=48KHz, 2Ch

1080i: 1920x1080i@60Hz(VID=5), Pre-programmed VID used, 8bit color depth, RGB input/output, CSC diable, I2S audio, fs=48KHz, 6Ch

#### 23.6.4.2 Register Setting Summary for Audio

The following registers shall be set to enable audio input. Refer to each register description for its detail function.

Bit Setting value explanation Example settings audio source 480p 1080i 720p 0h L/R data swap control if required All #04 [3:0]appropriate N[19:16] 0h 0h 0h #08 [7:0] All 18h appropriate N[15:8] 18h 18h #0C appropriate N[7:0] All 00h 00h 00h #1C [3:0] static CTS[19:16] All N.A. N.A. N.A. if external CTS is selected by bit.7 of #0A register #20 [7:0] static CTS[15:8] All N.A. N.A. if external CTS is selected by bit.7 of #0A register #24 static CTS[7:0] [7:0] All N.A. N.A. N.A. if external CTS is selected by bit.7 of #0A register #28 [7] set "1" 1'b0 1'b0 1'b0 if external CTS shall be used. [6:5] 12S/SPDIF(LPCM) N.A. N.A. N.A. set required down sampling rate if required [4:3] set required audio source 2'b00 2'b00 2'b00 set "1" 1'b0 1'b0 1'b0 [2] if MCLK shall be used for CTS calculation [1:0] set input MCLK ratio if bit.2 is set by "1" All N.A. N.A. N.A. #2C I2S/HBR/ [3:0] 0h 0h 0h set sending channel number for channel status (LPCM down sampling) #30 [5:2] set valid I2S source input pin I2S/HBR 1h 1h 7h set input I2S source mode I2S/HBR 2'b00 [1:0] 2'b00 2'b00 [7:4] set valid DSD source input pin 0h #34 DSD 0h 0h I2S/HBR #40 [7:0] set appropriate I2S input pin swap settings if 0h 0h 0h required DS/HBR/ 1'b0 [7] set validity bit for channel status 1'b0 1'b0 SPDIF [3:0] set original sample frequency for channel 0h 0h 0h (LPCM down sampling) status #48 [7] set value for channel status bit.1 1'b0 1'b0 1'b0 1'b0 1'b0 1'b0 [6] set value for channel status bit.0 [5] set copyright bit for channel status 1'b0 1'b0 1'b0 [4:2] 0h 0h 0h set additional information for channel status [1:0] set clock accuracy for channel status 2'b00 2'b00 2'b00 [7:0] 00h 00h 00h #40 set category code for channel status [7:4] 0h set source number for channel status 0h 0h [3:0] 0h 0h 0h set word length for channel status #54 2h [7:4] set sample frequency for channel status 2h 2h #17C [7:0] All Refer to Audio InfoFrame Appropriate Audio InfoFrame data

Table 24-17HDMI TX Register Setting Summary for Audio

Note that example setting conditions are as below.

480p: 720x480p@59.94Hz(VID=2), Pre-programmed VID used, 8bit color depth, RGB input/output, CSC diable, I2S audio, fs=48KHz, 2Ch

720p :-1280x720p@60Hz(VID=4), Pre-programmed VID used, 8bit color depth, RGB input/output, CSC diable, I2S audio, fs=48KHz, 2Ch

1080i: 1920x1080i@60Hz(VID=5), Pre-programmed VID used, 8bit color depth, RGB input/output, CSC diable, I2S audio, fs=48KHz, 6Ch

#### 23.6.4.3 PHY parameter settings

Host controller shall set appropriate PHY parameters into the following registers in power save mode b based on required pixel clock frequency and color depth. Refer to 1.4 for detail phy parameter registers. Note that PHY parameter setting values shall be varied depending on process technology.

descriptions in 861D spec



#### Table 24-18HDMI TX PHY Parameter Setting

#### PHY parameters for TSMC65G/55G process

|                | Example             |        |               | Register address |      |      |      |      |      |      |      |      |      |
|----------------|---------------------|--------|---------------|------------------|------|------|------|------|------|------|------|------|------|
| Color<br>depth | Video<br>Resolution |        | Freq<br>[MHz] | #5Ch             | #158 | #15C | #160 | #164 | #168 | #16C | #170 | #174 | #178 |
|                | 480p, 480i, 576p    | 27.00  | 27.00         | 22               | 11   | 00   | 00   | 44   | 32   | 4B   | 0E   | 70   | 00   |
| 8bit           | 1080i, 720p         | 74.25  | 74.25         | 22               | 19   | 00   | 00   | 44   | 32   | 48   | 0E   | 70   | 00   |
|                | 1080p               | 148.50 | 148.50        | 22               | 1D   | 00   | 00   | 4C   | 1E   | 47   | 0E   | 70   | 00   |
|                | 480p, 480i, 576p    | 27.00  | 33.75         | 62               | 15   | 00   | 00   | 48   | 32   | 46   | 0E   | 70   | 00   |
| 10bit          | 1080i, 720p         | 74.25  | 92.81         | 62               | 19   | 00   | 00   | 44   | 32   | 48   | 0E   | 70   | 00   |
|                | 1080p               | 148.50 | 185.63        | 62               | 1D   | 00   | 00   | 4C   | 1E   | 48   | 0E   | 70   | 00   |
|                | 480p, 480i, 576p    | 27.00  | 40.50         | A2               | 15   | 00   | 00   | 48   | 32   | 48   | 0E   | 70   | 00   |
| 12bit          | 1080i, 720p         | 74.25  | 111.38        | A2               | 19   | 00   | 00   | 44   | 32   | 4B   | 0E   | 70   | 00   |
|                | 1080p               | 148.50 | 222.75        | A2               | 1D   | 04   | 00   | 4C   | 1E   | 7F   | 0E   | 72   | 00   |

The following indicates PHY parameter setting sequences.

(1) Write 20h to register #00. (i.e. power save mode\_b).

If the current power save mode is mode b, it can be omitted. At this point, a stable idclk input is required.

- (2) Write appropriate parameter value to register #158 according to output video resolution.
  - (3) Write 2Ch to register #00 (i.e. PLLA/B reset) and wait 100us.
- (4) Write 20h to register #00 (i.e. PLLA/B reset release) and wait 1ms for PLL lock.
  - (5) Repeat above (2) (4) for register #160.
  - (6) Repeat above (2) (4) for register #164.
  - (7) Repeat above (2) (4) for register #168.
  - (8) Repeat above (2) (4) for register #16C.
  - (9) Repeat above (2) (4) for register #170.
  - (10) Repeat above (2) (4) for register #174.
  - (11) Repeat above (2) (4) for register #178.
- (12) Write appropriate parameter value to register #158 according to output video resolution.
  - (13) Change idclk input frequency if changing output video resolution.
  - (14) Write 2Ch to register #00 (i.e. PLLA/B reset) and wait 100us.
- (15) Write 20h to register #00 (i.e. PLLA/B reset release) and wait 1ms for PLL lock.
  - (16) Write 4Ch to register #00. (i.e. power save mode d with PLLA/B reset)

and wait 100us.

- (17) Write 48h to register #00. (i.e. power save mode\_d with PLLB reset) and wait 100us.
  - (18) Write 40h to register #00. (i.e. power save mode\_d) and wait 100us.

#### 24.6.5 Control Packet



Fig. 24-18HDMI TX Software Control Packet Sequence Diagram

There are two controls to send control packets.

- (1) Controll packets shall be sent once at every vertical sync. Host controller shall program it to #104h in setting sequences as above.
- (2) Control packet can be sent once manually. Host controller can set bits in #100h to send a packet manually at any timing in power save mode\_e if packet data is prepared.

#### 24.6.6 Loading HDCP Key

For preparing HDCP authentication, HDCP key shall be loaded from external HDCP memory.



Fig. 24-19HDMI TX Loading HDCP Key Sequence Diagram

# 24.6.7 Hardware HDCP Authentication



Fig. 24-20HDMI TX Hardware HDCP Authentication Sequence Diagram

#### 24.6.8 Software HDCP Authentication

#### 23.6.8.1 Enabling Software HDCP Authentication

To enable software authentication, set en\_soft\_auth (268h bit7) bit. HW will generate sf\_mode\_ready interrupt (260h bit7) to notify software that it is ready to start software authentication.

#### 23.6.8.2 First Part of Authentication

Software sequences the authentication process by reading from and writing to receiver to HDCP port via DDC accesses. DDC accesses are performed by accessing I2C registers (278h-2B8h).

For example, to read Ri via DDC, set i2c\_length(278h) to 2, i2c\_offset(280h)



to 8, and i2c\_read(284h bit0) to 1. A successful completion is notified by i2c\_ack interrupt (264h bit 7) and a failure generates i2c\_err\_ack interrupt (264h bit 6). When the interrupt is generated, Ri is available from i2c\_rd\_buf registers (288h-28Ch).

For another example, to write Aksv via DDC, set i2c\_length(278h) to 5, i2c\_offset(280h) to 10h, load Aksv contents to i2c\_wr\_buf(29Ch-2ACh), and set i2c\_write(284H bit2) to 1. A successful completion is notified by i2c\_ack interrupt (264h bit 7) and a failure generates i2c\_err\_ack interrupt (264h bit 6).

In the first part of authentication, software needs to read Bksv and Bcaps from DDC. After obtaining these values, they need to be written back into registers, 38Ch-39Ch and 380h respectively. Also, depending on Bcaps value, set\_repeater bit in 268h may be set.

To send An, a random number must be generated using cipher by setting prep\_an bit in 268h register.

To generate the first Ri, set start\_auth bit in 268h after loading Bksv, Bcaps, set\_repeater bit, and generating An. If start\_auth bit is set before any of these values are set, a wrong Ri will be generated and the authentication will result in failure.

According to HDCP specification, Ri must not be read within 100ms of writing Aksv. Therefore, the S/W sequencer shall implement a timer to wait for 100ms before reading Ri via DDC.

If for some reason, the S/W sequencer determines that the authentication has failed, S/W sequencer shall clear all bits in Software HDCP Control (268h) register including en\_soft\_auth bit (bit7), return to the idle state, and retry the authentication.

#### 23.6.8.3 Second Part of Authentication

A 5 second timer shall be implemented by S/W sequencer to time out from waiting for READY bit in Bcaps register. S/W sequencer shall retry reading Bcaps until either the READY bit is set or the 5 seconds has passed.

What software does for the second part of authentication is very similar to the first part. When software reads Bstatus, the value needs to be written into the register (384h-388h). Also, num\_devices (370h) needs to be written as well.

After reading Bstatus, software reads KSV List via DDC. Because the size of KSV List is much larger than i2c\_rd\_buf can take, set i2c\_no\_read bit as well as i2c\_read bit in A1h register. When the DDC access is complete, KSV List is ready for block read out via 200h register. Software needs to set calc sha1 bit in 268h to enable hash calculation. Hash values will be loaded into SHA0~SHA4 registers when they are ready (sha1 ready interrupt in 260h).



Use sha1\_index (360h) to read out values from the registers.

#### 23.6.8.4 Third Part of Authentication

There are 2 ways to perform the 3rd part of authentication. The simplest way is to use the frame counter implemented in the hardware. The frame counter is a counter that keeps track of when to update Ri and Pj values for link integrity checks.

#### 1. Hardware Frame Counter

The hardware maintains a frame counter and is displayed at 270h, although, software may not need to read this value at all. In this mode, software must enable ri\_save\_ready and pj\_save\_ready interrupts. The software may disable ri\_ready, pj\_ready, enc\_en, enc\_dis\_avmute, enc\_dis\_no\_avmute, fr\_cnt\_update interrupts as they are not used in this mode.

When set\_auth bit in 268h is set, the hardware generates ri\_save\_ready interrupt when Ri gets updated at 128th frame. The hardware also generates pj\_save\_ready interrupt when Pj gets updated at 16th frame. When ri\_save\_ready interrupt is generated, software shall read Ri\_save register and Ri value from the receiver and compare them. If they do not match, the software shall clear set\_auth and en\_soft auth bits and re-authentication from the beginning. When pj\_save\_ready interrupt is generated, software shall read Pj\_save register and Pj value from the receiver and compare them.

ri\_save\_ready interrupt is generated at every 128th frame regardless of RiFrameCount (2C8h) register value and Ri\_save (364h-368h) remains unchanged for 128 frames. The S/W sequencer shall check for Ri values within the 128 frame window. For 60Hz systems, 128 frames give about 2 seconds for progressive video formats and 1 second for interlaced video formats.

Similarly, pj\_save\_ready interrupt is generated at every 16th frame. The S/W sequencer shall check for Pj values within the 16 frame window.

#### 2. Software Frame Counter

In this mode, software must enable ri\_ready, pj\_ready, enc\_en, enc\_dis\_avmute, and enc\_dis\_no\_avmute interrupts. The software may disable ri\_save\_ready, pj\_save\_ready, and fr\_cnt\_update interrupts.

In this mode, software keeps track of frame counter by counting number of enc\_en, enc\_dis\_avmute, and enc\_dis\_no\_avmute interrupts.

When set\_auth bit in 268h is set, the hardware generates ri\_ready interrupt when Ri gets updated every frame.

Software keeps the 128th Ri for the next 128 frames for comparison with the receiver. Also, the software keeps the 16th Pj for the next 16 frames for



comparison.

In this mode, the S/W HDCP sequencer's behavior is more flexible. S/W sequencer must save and keep Ri values for 128 frames, but it may check for Ri at any frame.

## **Chapter 25 Camera Interface**

#### 25.1 Overview

The Camera interface, receives the data from Camera or CCIR656 encoder, and transfers the data into system main memory by AXI bus.

The features of camera interface are as follow:

- Support YCbCr422 input
- Support Raw8/10/12 bit input
- Support CCIR656(PAL/NTSC) input
- Support JPEG input
- Support YCbCr422/420 output
- Support UYVY/VYUY/YUYV/YVYU configurable
- Support up to 8192x8192 resolution source
- Support picture in picture
- Support arbitrary size window crop
- Support scale range from 1/8 to 8, and destination width up to 1920
- Support SCM with configurable statistics cycles
- Support white balance
- Support error/terminate interrupt and combined interrupt output
- Support clk/vsync/href polarity configurable
- Support one frame stop/ping-pong/line loop mode

## 25.2 Block Diagram



Fig. 25-1CIF block diagram

The CIF comprises with:

- AHB Slave
  - Host configure the registers via the AHB Slave
- AXI Master
  - Transmit the data to chip memory via the AXI Master
- INTERFACE
  - Translate the input video data into the requisite data format
- CROP
  - Bypass or crop the source video data to a smaller size destination
- ISP
  - Modify the pixel value for more good visual effect
- SCM



Collect the statistics of the pixel value

- **SCALE** 
  - Scale up or down the input video data
- **DMA** Control the operation of AXI Master

## 25.3 Function description

This chapter is used to illustrate the operational behavior of how CIF works. CIF receive the sensor, ccir656 signal from external devices and translate it into YUV422/420 data, separate the data to Y and UV data, then store them to different memory via AXI bus separately.

#### **Input data format**

The CIF module support the 8bit YUV422 and CCIR656, 10/12-bit raw data input.

- 1. Support Vsync high active or low active
  - Vsync Low active as below:

#### Vertical sensor timing (line by line)



Fig. 25-2 Timing diagram for CIF when vsync low active



Fig. 25-3Timing diagram for CIF when vsync high active

2. Support href high active or low active



Fig. 25-4Timing diagram for CIF when href high active



Fig. 25-5Timing diagram for CIF when href low active





Fig. 25-6Timing diagram for CIF when Y data first



Fig. 25-7Timing diagram for CIF when U data first

3. Support CCIR656 (NTSC and PAL)



Fig. 25-8CCIR656 timing

4. Support Raw data(10/12-bit) or JPEG

Pixel Data Timing Example



Fig. 25-9Raw Data or JPEG Timing

CIF module can work in three modes: one frame stop mode, ping-pong mode and Line Loop mode.

#### One frame stop mode

In this mode, configure the parameter WORK\_MODE to one frame stop mode. After one frame captured, CIF will automatic stop. After capturing, the image Y, UV data will be stored at main memory location defined by CIF\_FRM0\_ADDR\_Y, FRM0\_ADDR\_UV separately.

#### **Ping-Pong mode**



After one frame(F1) captured, CIF will start to capture the next frame(F2) automatically, and host must assign new address pointer of frame1 and clear the frame1 status, thus CIF will capture the third frame automatically(by new F1 address) without any stop and so on for the following frames. But if host did not update the frame buffer address, the CIF will cover the pre-frame data stored in the memory with the following frame data.

#### **Line Loop mode**

In this mode, LINE LOOP NUM can be set to decide when to switch the ping-pang buffer address at the middle of a frame. For example, if this parameter is equal to ten, the first ten lines is written to FRMO\_ADDR\_Y and FRM0\_ADDR\_UV. And the second ten lines are written to FRM1\_ADDR\_Y and FRM1\_ADDR\_UV.The third ten lines, the fourth ten lines, it runs like this in circulations.

Assume that there are 384 lines in the frame, the FRAME\_END\_SWITCH can be set to switch the frame buffer address at the end of the frame although less than ten lines written in the frame buffer. But if the FRAME END SWITCH bit is not set, the address switching operation will occur after the first six lines in the next frame are written in the current frame buffer.

The current line number of the frame can be writtten to LIN\_NUM\_ADDR if ISSUE\_LINE\_NUM\_MODE is enabled.

#### Storage

Difference between the YUV mode and raw mode is that in the YUV mode or ccir656 mode, data will be storage in the Y data buffer and UV data buffer; but in the raw or jpeg mode, RGB data will be storage in the same buffer. In addition, in the yuv mode, the width of Y, U or V data is a byte in memory; in Raw or JPEGE mode, the width is a halfword no matter the data source is 8 bit, 10 bit or 12 bit.

#### **CROP**

The parameter START\_Y and START\_X defines the coordinate of crop start point. And the frame size after cropping is following the value of SET WIDTH and SET HEIGHT.

#### **ISP**

The ISP LUT RAM address offset is range from 0x1000 to 0x13FC and bits [1:0] must be 2'b0. There are 256 RAM entries and [23:16], [15:8], [7:0] bits of data in each entry correspond to Y, U, V separately.

The function of ISP operation is mapping the input YUV value to output YUV value based on the ISP LUT RAM. The input YUV value is the address of LUT RAM. and the ouput value is the data in the input address. After reset, there are invalid values in LUT RAM. It is recommend to initialize the LUT RAM before doing ISP operation.

The configuration flow is the following. Firstly, set the ISP INIT LD bit and initialize the ISP LUT RAM for the pixel value mapping. The ISP EN can be set only if the initializing operation is ready.

#### **SCM**

Just like the ISP operation flow, the first task of SCM operation is writing 1 to SCM INIT LD bit. Next, it is recommended to initialize the SCM RAM to all zero. After that, SCM EN can be enabled to start to collect the statistics of the pixel value.

The SCM frequency is also configurable. The frequency of pixel is controlled by



PIX\_SAMPLE\_FREQ.And the frequency of frame is controlled by FRM SAMPLE FREQ.

The SCM result can be read by AXI Master or AHB Slave. In AHB Slave mode, only one frame can be collected and the result will be absolutely right. But if the AXI Master mode is selected, SCM error maybe occur when the SCM information of previous frame is not reading completely but current frame is coming.

The SCM RAM address is word address and the offset is the following:

Y: 0x400~0x7FC U: 0x800~0xBFC V: 0xC00~0xFFC

#### **WBC**

When all of the following conditions is true, the pixels will be counted in the resiter WBC\_CNT.

MAX\_Y < y value < MIN\_Y MAX U < u value < MIN U MAX\_V < v value < MIN\_V

#### **SCALE**

The scale source size is SET\_WIDTH and SET\_HEIGHT, the scale destination size is SCL\_WIDTH and SCL\_HEIGHT. And the scale factor must be set correctly ,or scale error may be occurred.

 $SCL_HOR_FCT = ((src_width-1)/(dst_width-1)) * 2^{12}$ SCL\_VER\_FCT =((src\_height-1)/(dst\_height -1)) \* 2<sup>12</sup>

## 25.4 Register description

#### 25.4.1 Register Summary

| Name                   | Offset | Size | <b>Reset Value</b> | Description             |
|------------------------|--------|------|--------------------|-------------------------|
| CIF_CIF_CTRL           | 0x0000 | W    | 0x00007000         | CIF control             |
| CIF_CIF_INTEN          | 0x0004 | W    | 0x0000000          | CIF interrupt enable    |
| CIF_CIF_INTSTAT        | 0x0008 | W    | 0x0000000          | CIF interrupt status    |
| CIF_CIF_FOR            | 0x000c | W    | 0x0000000          | CIF format              |
| CIF_CIF_LINE_NUM_ADDR  | 0x0010 | W    | 0x0000000          | CIF line number address |
| CIF_CIF_FRM0_ADDR_Y    | 0x0014 | W    | 0x0000000          | CIF frame0 y address    |
| CIF_CIF_FRM0_ADDR_UV   | 0x0018 | W    | 0x0000000          | CIF frame0 uv address   |
| CIF_CIF_FRM1_ADDR_Y    | 0x001c | W    | 0x0000000          | CIF frame1 y address    |
| CIF_CIF_FRM1_ADDR_UV   | 0x0020 | W    | 0x0000000          | CIF frame1 uv address   |
| CIF_CIF_VIR_LINE_WIDTH | 0x0024 | W    | 0x0000000          | CIF virtual line width  |
| CIF_CIF_SET_SIZE       | 0x0028 | W    | 0x01e002d0         | CIF frame set size      |
| CIF_CIF_SCM_ADDR_Y     | 0x002c | W    | 0x0000000          | CIF scm y data address  |
| CIF_CIF_SCM_ADDR_U     | 0x0030 | W    | 0x0000000          | CIF scm u data address  |
| CIF_CIF_SCM_ADDR_V     | 0x0034 | W    | 0x0000000          | CIF scm v data address  |
| CIF_CIF_WB_UP_FILTER   | 0x0038 | W    | 0x00000000         | CIF white balance up    |
|                        |        | -    |                    | filter                  |
| CIF_CIF_WB_LOW_FILTER  | 0x003c | W    | 0x00000000         | CIF white balance low   |
|                        |        |      |                    | filter                  |



| Name                   | Offset | Size | Reset Value | Description             |
|------------------------|--------|------|-------------|-------------------------|
| CIF_CIF_WBC_CNT        | 0x0040 | W    | 0x0000000   | CIF white balance count |
| CIF_CIF_CROP           | 0x0044 | W    | 0x0000000   | CIF crop start point    |
| CIF_CIF_SCL_CTRL       | 0x0048 | W    | 0x00000000  | CIF scale control       |
| CIF CIF SCL DST        | 0x004c | ۱۸/  | 0x00000000  | CIF scale destination   |
| CII_CII_SCL_D31        | 0,0040 | VV   | 020000000   | frame size              |
| CIF_CIF_SCL_FCT        | 0x0050 | W    | 0x20002000  | CIF scale factor        |
| CIF_CIF_SCL_VALID_NUM  | 0x0054 | W    | 0x00000000  | CIF scale valid number  |
| CIF_CIF_LINE_LOOP_CTRL | 0x0058 | W    | 0x00000000  | CIF line loop control   |
| CIF_CIF_FRAME_STATUS   | 0x0060 | W    | 0x0000000   | CIF frame status        |
| CIE CIE CUD DST        | 0x0064 | ١٨/  | 0x00000000  | CIF current destination |
| CIF_CIF_CUR_DST        | 00004  | VV   | 0x0000000   | address                 |
| CIF CIF LAST LINE      | 0x0068 | ١٨/  | 0×00000000  | CIF last frame line     |
| CIF_CIF_LAST_LINE      | UXUUO8 | VV   | 0x00000000  | number                  |
| CIE CIE LAST DIV       | 0x006c | ۱۸/  | 0x00000000  | CIF last line pixel     |
| CIF_CIF_LAST_PIX       | UXUUUC | VV   | 0.000000000 | number                  |

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

## 25.4.2 Detail Register Description

## CIF\_CIF\_CTRL

Address: Operational Base + offset (0x0000)

CIF control

| Bit   | Attr   | Reset Value | Description           |
|-------|--------|-------------|-----------------------|
| 31:18 | RO     | 0x0         | reserved              |
|       |        |             | SCM_INIT_LD           |
| 17    | DW     | 0x0         | scm sram initial load |
| 1 /   | RW     | UXU         | 0-disable             |
|       |        |             | 1-load enable         |
| 16    | RO     | 0x0         | reserved              |
|       |        | 7           | AXI_BURST_TYPE        |
| 15:12 | RW     | 0x7         | axi master burst type |
|       |        |             | 0-15 : burst1~16      |
| 12    |        |             | WBC_EN                |
| 11    | RW     | 0×0         | white balance collect |
| 111   | IX V V | OXO         | 0-disable             |
|       |        |             | 1-enable              |
|       |        |             | ISP_EN                |
| 10    | RW     | 0×0         | isp enable            |
|       | 1700   |             | 0-disable             |
|       |        |             | 1-enable              |



| Bit | Attr | Reset Value | Description                                |
|-----|------|-------------|--------------------------------------------|
|     |      |             | ISP_INIT_LD                                |
|     | DW   | 0x0         | isp lut initial enable                     |
| 9   | RW   |             | 0-disable                                  |
|     |      |             | 1-load enable                              |
|     |      |             | SCM_RD_MODE                                |
|     |      |             | scm read mode                              |
| 0   | DW   | 0.40        | 0-AXI master                               |
| 8   | RW   | 0x0         | 1-AHB slave                                |
|     |      |             | Note: when in slave mode, only collect one |
|     |      |             | frame.                                     |
|     |      |             | PIX_SAMPLE_FRQ                             |
|     | RW   |             | pixel scm sample frequency                 |
| 7:6 |      | 0×0         | 00 - none                                  |
| 7:0 |      | UXU         | 01 - every 1 uv/2 y                        |
|     |      |             | 10 - every 2 uv/4 y                        |
|     |      |             | 11 - every 4 uv/8 y                        |
|     |      |             | FRM_SAMPLE_FRQ                             |
|     |      |             | frame SCM sample frequency                 |
| 5:4 | RW   | 0×0         | 000 - every 1 frame                        |
| 3.4 | KVV  | 0.00        | 001 - every 2 frame                        |
|     |      |             | 010 - every 3 frame                        |
|     |      |             | 011 - every 4 frame                        |
|     |      |             | SCM_EN                                     |
| 3   | RW   | 0×0         | SCM enable                                 |
|     | IXVV | 0.00        | 0-SCM disable                              |
|     |      | 1,5         | 1-SCM enable                               |
|     |      |             | WORK_MODE                                  |
|     |      |             | Working Mode                               |
| 2:1 | RW   | 0×0         | 00-one frame stop mode                     |
| 2.1 | KVV  | UXU         | 01-ping-pong mode                          |
|     |      |             | 02-line loop mode                          |
|     |      |             | 03-reserved                                |
|     |      |             | CAP_EN                                     |
| 0   | RW   | 0×0         | capture enable                             |
|     | 1200 | 0x0         | 0-disable                                  |
|     |      |             | 1-enable                                   |

## CIF\_CIF\_INTEN

Address: Operational Base + offset (0x0004)

CIF interrupt enable

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:8 | RO   | 0x0         | reserved    |



| Bit | Attr   | Reset Value | Description                                    |
|-----|--------|-------------|------------------------------------------------|
|     |        |             | SCL_ERR_EN                                     |
| 7   | DW     | 0.40        | scale error                                    |
| 7   | RW     | 0x0         | 0-disable                                      |
|     |        |             | 1-enable                                       |
|     |        |             | BUS_ERR_EN                                     |
|     |        |             | bus error                                      |
| 6   | RW     | 0x0         | axi master or ahb slave response error         |
|     |        |             | 0-disable                                      |
|     |        |             | 1-enable                                       |
|     |        |             | SCM_ERR_EN                                     |
|     |        |             | scm error                                      |
| 5   | RW     | 0×0         | scm start when the last scm data have not be   |
| 3   |        | OXO         | send                                           |
|     |        |             | 0-disable                                      |
|     |        |             | 1-enable                                       |
|     |        |             | LINE_BUF_OVER_EN                               |
| 4   | RW     | 0×0         | line buffer overflow                           |
| T   |        | 0.00        | 0-disable                                      |
|     |        |             | 1-enable                                       |
|     |        |             | PIX_ERR_EN                                     |
|     |        |             | pixel err interrupt enable                     |
| 3   | RW     | 0x0         | the pixel number of last line not equal to the |
|     |        | o x o       | set height                                     |
|     |        |             | 0-disable                                      |
|     |        | . 1         | 1-enable                                       |
|     |        |             | LINE_ERR_EN                                    |
|     |        |             | line err interrupt enable                      |
| 2   | RW     | 0x0         | the line number of last frame not equal to the |
|     | 1      |             | set height                                     |
|     |        | 7           | 0-disable                                      |
|     |        |             | 1-enable                                       |
|     | $\cup$ |             | LINE_END_EN                                    |
| 1   | RW     | 0x0         | line end interrupt enable                      |
| 7   |        |             | 0-disable                                      |
|     |        |             | 1-enable                                       |
|     |        |             | FRAME_END_EN                                   |
|     | 514    |             | frame end interrupt enable                     |
| 0   | RW     | 0x0         | after dma transfer the frame data              |
|     |        |             | 0-disable                                      |
|     |        |             | 1-enable                                       |

## CIF\_CIF\_INTSTAT



Address: Operational Base + offset (0x0008)

CIF interrupt status

| Bit  | Attr    | Reset Value | Description                                    |
|------|---------|-------------|------------------------------------------------|
| 31:8 | RO      | 0x0         | reserved                                       |
|      |         |             | SCL_ERR                                        |
| _    |         |             | scale error                                    |
| 7    | W1C     | 0x0         | 0-no interrupt                                 |
|      |         |             | 1-interrupt                                    |
|      |         |             | BUS_ERR                                        |
|      |         |             | bus error                                      |
| 6    | W1C     | 0x0         | axi master or ahb slave response error         |
|      |         |             | 0-no interrupt                                 |
|      |         |             | 1-interrupt                                    |
|      |         |             | SCM_ERR                                        |
|      |         |             | scm error                                      |
| _    | \\\\1 C | 00          | scm start when the last scm data have not be   |
| 5    | W1C     | 0x0         | send                                           |
|      |         |             | 0-no interrupt                                 |
|      |         |             | 1-interrupt                                    |
|      |         |             | LINE_BUF_OVER                                  |
| 4    | W1C     | 1C 0x0      | line buffer overflow                           |
| 4    | WIC     |             | 0-no interrupt                                 |
|      |         |             | 1-interrupt                                    |
|      |         |             | PIX_ERR                                        |
|      |         |             | pixel err interrupt                            |
| 3    | W1C     | 0x0         | the pixel number of last line not equal to the |
| 3    | WIC     | UXU .       | set height                                     |
|      |         | VO X        | 0-no interrupt                                 |
|      |         |             | 1-interrupt                                    |
|      | A 1     | U'          | LINE_ERR                                       |
|      |         | 7           | line err interrupt                             |
| 2    | W1C     | 0×0         | the line number of last frame not equal to the |
|      | VVIC    | 0.00        | set height                                     |
|      |         |             | 0-no interrupt                                 |
|      |         |             | 1-interrupt                                    |
|      |         |             | LINE_END                                       |
| 1    | W1C     | 0×0         | line end interrupt enable                      |
| •    | ,,,,    |             | 0-no interrupt                                 |
|      |         |             | 1-interrupt                                    |
|      |         |             | FRAME_END                                      |
|      |         |             | frame end interrupt                            |
| 0    | W1C     | 0x0         | after dma transfer the frame data              |
|      |         |             | 0-no interrupt                                 |
|      |         |             | 1-interrupt                                    |



Address: Operational Base + offset (0x000c)

CIF format

| Bit   | Attr  | Reset Value | Description                                |
|-------|-------|-------------|--------------------------------------------|
| 31:20 | RO    | 0x0         | reserved                                   |
|       |       |             | UV_STORE_ORDER                             |
| 1.0   | 514   | 0×0         | UV storage order                           |
| 19    | RW    |             | 0 - UVUV                                   |
|       |       |             | 1 - VUVU                                   |
|       |       |             | RAW_END                                    |
| 1.0   | DW    |             | raw data endian                            |
| 18    | RW    | 0x0         | 0 - little end                             |
|       |       |             | 1 - big end                                |
|       |       |             | OUT_420_ORDER                              |
|       |       |             | output 420 order                           |
| 17    | RW    | 0x0         | 00 - UV in the even line                   |
|       |       |             | 01 - UV in the odd line                    |
|       |       |             | Note: The first line is even line(line 0). |
|       |       |             | OUTPUT_420                                 |
| 1.0   | DW    | 0×0         | output 420 or 422                          |
| 16    | RW    |             | 0 - output is 422                          |
|       |       |             | 1 - output is 420                          |
| 15    | RO    | 0x0         | reserved                                   |
|       |       |             | MIPI_MODE                                  |
|       |       | . ()        | mipi mode                                  |
| 14:13 | RW    | 0.40        | 00 - bypass                                |
| 14:13 | KVV   | 0x0         | 01 - rgb                                   |
|       |       |             | 10 - yuv                                   |
|       | 11    |             | 11- reserved                               |
|       |       | 7           | RAW_WIDTH                                  |
|       |       |             | raw data width                             |
| 12:11 | RW    | 0×0         | 00 - raw8                                  |
| 12.11 | KVV   | UXU         | 01 - raw10                                 |
| 7     |       |             | 10 - raw12                                 |
|       |       |             | 11 - reserved                              |
|       |       |             | JPEG_MODE                                  |
| 10    | RW    | 0×0         | JPEG mode                                  |
| 10    | IZVV  | UXU         | 0 - other mode                             |
|       |       |             | 1 - mode1                                  |
|       |       |             | FIELD_ORDER                                |
| 9     | RW    | 0×0         | ccir input order                           |
| ]     | IL VV | 0.00        | 0-odd field first                          |
|       |       |             | 1-even field first                         |



| Bit | Attr  | Reset Value | Description                                |
|-----|-------|-------------|--------------------------------------------|
|     |       |             | IN_420_ORDER                               |
|     |       |             | 420 input order                            |
| 8   | RW    | 0x0         | 00 - UV in the even line                   |
|     |       |             | 01 - UV in the odd line                    |
|     |       |             | Note: The first line is even line(line 0). |
|     |       |             | INPUT_420                                  |
| 7   | DW    | 0.40        | input 420 or 422                           |
| 7   | RW    | 0x0         | 0 - 422                                    |
|     |       |             | 1 - 420                                    |
|     |       |             | YUV_IN_ORDER                               |
|     |       |             | YUV input order                            |
| 6:5 | RW    | 0.40        | 00 - UYVY                                  |
| 0.5 | KVV   | 0x0         | 01 - YVYU                                  |
|     |       |             | 10 - VYUY                                  |
|     |       |             | 11 - YUYV                                  |
|     |       |             | INPUT_MODE                                 |
|     |       |             | input mode                                 |
|     |       |             | 000 - YUV                                  |
|     |       |             | 010 - PAL                                  |
| 4:2 | RW    | W 0×0       | 011 - NTSC                                 |
|     |       |             | 100 - RAW                                  |
|     |       |             | 101 - JPEG                                 |
|     |       |             | 110 - MIPI                                 |
|     |       |             | Other - invalid                            |
|     |       | . ()        | HREF_POL                                   |
| 1   | RW    | 0x0         | href input polarity                        |
| 1   | I XVV | 0,0         | 0-high active                              |
|     |       |             | 1-low active                               |
|     | 11    |             | VSYNC_POL                                  |
| 0   | RW    | 0x0         | vsync input polarity                       |
| ,   |       |             | 0-;ow active                               |
|     |       |             | 1-high active                              |

## CIF\_CIF\_LINE\_NUM\_ADDR

Address: Operational Base + offset (0x0010)

CIF line number address

| Bit  | Attr | Reset Value | Description         |
|------|------|-------------|---------------------|
| 31:0 | RW   | 0,,000,000  | LIN_NUM_ADDR        |
| 31.0 | KVV  | 0x00000000  | line number address |

#### CIF\_CIF\_FRMO\_ADDR\_Y

Address: Operational Base + offset (0x0014)

CIF frame0 y address



## CIF\_CIF\_FRMO\_ADDR\_UV

Address: Operational Base + offset (0x0018)

CIF frame0 uv address

| Bit  | Attr | Reset Value | Description       |
|------|------|-------------|-------------------|
| 31:0 | RW   | 0×00000000  | FRM0_ADDR_UV      |
| 31.0 | KVV  | 000000000   | frame0 uv address |

#### CIF\_CIF\_FRM1\_ADDR\_Y

Address: Operational Base + offset (0x001c)

CIF frame1 y address

| Bit  | Attr | Reset Value | Description      |
|------|------|-------------|------------------|
| 31:0 | RW   | 0×00000000  | FRM1_ADDR_Y      |
| 31.0 | KVV  | 000000000   | frame1 y address |

#### CIF\_CIF\_FRM1\_ADDR\_UV

Address: Operational Base + offset (0x0020)

CIF frame1 uv address

| Bit  | Attr | Reset Value | Description                       |
|------|------|-------------|-----------------------------------|
| 31:0 | RW   | 10x00000000 | FRM1_ADDR_UV<br>frame1 uv address |

#### CIF\_CIF\_VIR\_LINE\_WIDTH

Address: Operational Base + offset (0x0024)

CIF virtual line width

| Bit   | Attr | Reset Value | Description        |
|-------|------|-------------|--------------------|
| 31:15 | RO   | 0x0         | reserved           |
| 14:0  | RW   | 0,40000     | VIR_LINE_WIDTH     |
|       |      | 0x0000      | virtual line width |

#### CIF\_CIF\_SET\_SIZE

Address: Operational Base + offset (0x0028)

CIF frame set size

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:29 | RO   | 0x0         | reserved    |
| 20.16 | RW   | 0x01e0      | SET_HEIGHT  |
| 28:16 |      |             | set height  |
| 15:13 | RO   | 0x0         | reserved    |
| 12:0  | RW   | RW 10x02d0  | SET_WIDTH   |
|       |      |             | set width   |



#### CIF\_CIF\_SCM\_ADDR\_Y

Address: Operational Base + offset (0x002c)

CIF scm y data address

| Bit  | Attr  | Reset Value | Description     |
|------|-------|-------------|-----------------|
| 31:0 | RW    | 0×00000000  | FRM_ADDR_Y      |
| 31.0 | IK VV | 000000000   | frame y address |

### CIF\_CIF\_SCM\_ADDR\_U

Address: Operational Base + offset (0x0030)

CIF scm u data address

| Bit  | Attr | Reset Value | Description     |
|------|------|-------------|-----------------|
| 31:0 | RW   | 0×00000000  | FRM_ADDR_U      |
| 31.0 | KVV  | 000000000   | frame u address |

### CIF\_CIF\_SCM\_ADDR\_V

Address: Operational Base + offset (0x0034)

CIF scm v data address

| Bit  | Attr | Reset Value | Description                |
|------|------|-------------|----------------------------|
| 31:0 | RW   | 0×00000000  | FRM_ADDR_V frame v address |

#### CIF\_CIF\_WB\_UP\_FILTER

Address: Operational Base + offset (0x0038)

CIF white balance up filter

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:24 | RO   | 0x0         | reserved    |
| 23:16 | RW   | 0x $0$ 0    | MAX_Y       |
| 23.10 |      |             | max y value |
| 15:8  | RW   | 0×00        | MAX_U       |
| 13.6  | KVV  | 0000        | max u value |
| 7:0   | RW   | 10x00       | MAX_V       |
|       |      |             | max v value |

## CIF\_CIF\_WB\_LOW\_FILTER

Address: Operational Base + offset (0x003c)

CIF white balance low filter

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:24 | RO   | 0x0         | reserved    |
| 23:16 | RW   | 0x00        | MIN_Y       |
| 23:16 |      |             | min y value |
| 15:8  | RW   | 0x00        | MIN_U       |
|       |      |             | min u value |



| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
| 7:0 | RW   | 0×00        | MIN_V       |
| 7.0 | KVV  | 0000        | min v value |

## CIF\_CIF\_WBC\_CNT

Address: Operational Base + offset (0x0040)

CIF white balance count

| Bit   | Attr | Reset Value | Description         |
|-------|------|-------------|---------------------|
| 31:24 | RO   | 0x0         | reserved            |
| 22.0  | D.O. | 0,,000,000  | WBC_CNT             |
| 23:0  | RO   | 0x000000    | white balance count |

## CIF\_CIF\_CROP

Address: Operational Base + offset (0x0044)

CIF crop start point

| Bit   | Attr | Reset Value | Description   |
|-------|------|-------------|---------------|
| 31:29 | RO   | 0x0         | reserved      |
| 20.16 | DW   | 0x0000      | START_Y       |
| 28:16 | RW   |             | start y point |
| 15:13 | RO   | 0x0         | reserved      |
| 12:0  | RW   | 0×0000      | START_X       |
|       |      |             | start x point |

## CIF\_CIF\_SCL\_CTRL

Address: Operational Base + offset (0x0048)

CIF scale control

| Bit  | Attr | Reset Value | Description       |
|------|------|-------------|-------------------|
| 31:7 | RO   | 0x0         | reserved          |
|      | A 1  |             | B32_BP            |
| 6    | RW   | 0×0         | 32bit bypass      |
| 0    | KVV  | UXU         | 0-no bypass       |
|      |      |             | 1-bypass          |
|      | )    | 0x0         | RAW_16B_BP        |
| 5    | RW   |             | raw 16 bit bypass |
| 3    |      |             | 0-no bypass       |
|      |      |             | 1-bypass          |
|      |      |             | YUV_16B_BP        |
| 4    | RW   | 0×0         | YUV 16 bit bypass |
|      | KVV  |             | 0-no bypass       |
|      |      |             | 1-bypass          |
| 3:2  | RO   | 0x0         | reserved          |



| Bit | Attr | Reset Value | Description        |
|-----|------|-------------|--------------------|
|     |      | 0x0         | SCL_UP_EN          |
| 1   | RW   |             | scale up enable    |
| 1   | KVV  |             | 0:disable          |
|     |      |             | 1:enable           |
| 0   | RW   |             | SCL_DOWN_EN        |
|     |      |             | scale down control |
|     |      |             | 0:disable          |
|     |      |             | 1:enable           |

## CIF\_CIF\_SCL\_DST

Address: Operational Base + offset (0x004c)

CIF scale destination frame size

| Bit   | Attr | Reset Value | Description  |
|-------|------|-------------|--------------|
| 31:27 | RO   | 0x0         | reserved     |
| 26:16 | RW   | 0x000       | SCL_HEIGHT   |
|       |      |             | scale height |
| 15:11 | RO   | 0x0         | reserved     |
| 10.0  | DW   | 0,000       | SCL_WIDTH    |
| 10:0  | RW   | 0x000       | scale width  |

## CIF\_CIF\_SCL\_FCT

Address: Operational Base + offset (0x0050)

CIF scale factor

| Bit   | Attr   | Reset Value | Description                                     |
|-------|--------|-------------|-------------------------------------------------|
|       |        | • 1         | SCL_VER_FCT                                     |
| 21.16 | RW     | 0. 2000     | vertical scale factor                           |
| 31:16 | KVV    | 0×2000      | vrt_scl_fct =((src_height-1)/(dst_height -1)) * |
|       |        |             | 2 <sup>13</sup>                                 |
|       |        | (           | SCL_HOR_FCT                                     |
| 15:0  | RW     | 0x2000      | horizontal scale factor                         |
| 15:0  | KW     | UX2000      | hrz_scl_fct = ((src_width-1)/(dst_width -1)) *  |
|       | $\cup$ |             | $2^{13}$                                        |

## CIF\_CIF\_SCL\_VALID\_NUM

Address: Operational Base + offset (0x0054)

CIF scale valid number

| <u> </u> | or some valia mamber |             |                              |  |
|----------|----------------------|-------------|------------------------------|--|
| Bit      | Attr                 | Reset Value | Description                  |  |
| 31:15    | RO                   | 0x0         | reserved                     |  |
|          |                      |             | SCL_VALID_NUM_UV             |  |
| 14:8     | RW                   | 0x00        | scale valid number in Y FIFO |  |
|          |                      |             | write 0 clear                |  |
| 7        | RO                   | 0x0         | reserved                     |  |



| Bit | Attr | Reset Value | Description                  |
|-----|------|-------------|------------------------------|
|     |      |             | SCL_VALID_NUM_Y              |
| 6:0 | RO   | 0x00        | scale valid number in Y FIFO |
|     |      |             | write 0 clear                |

#### CIF\_CIF\_LINE\_LOOP\_CTRL

Address: Operational Base + offset (0x0058)

CIF line loop control

| Bit  | Attr | Reset Value | Description             |
|------|------|-------------|-------------------------|
| 31:6 | RO   | 0x0         | reserved                |
|      |      |             | ISSUE_LINE_NUM_MODE     |
| 5    | RW   | 0×0         | issue line num mode     |
| 3    | KVV  | UXU         | 0-diable                |
|      |      |             | 1-enable                |
|      |      | W 0x0       | FRAME_END_SWITCH        |
| 4    | DW   |             | frame end switch enable |
| 4    | KVV  |             | 0-disable               |
|      |      |             | 1-enable                |
|      |      |             | LINE_LOOP_NUM           |
| 3:0  | RW   | 0x0         | line loop num           |
|      |      |             | 1~16                    |

## CIF\_CIF\_FRAME\_STATUS

Address: Operational Base + offset (0x0060)

CIF frame status

| Bit   | Attr | Reset Value | Description           |
|-------|------|-------------|-----------------------|
|       |      | A A Y       | FRAME_NUM             |
| 31:16 | RO   | 0x0000      | complete frame number |
|       |      |             | write 0 to clear      |
| 15:2  | RO   | 0x0         | reserved              |
|       |      | Y           | F1_STS                |
|       |      |             | frame 0 status        |
| 1     | RO   | 0x0         | 0- frame 1 not ready  |
|       | V    |             | 1- frame 1 ready      |
|       |      |             | write 0 clear         |
|       |      |             | F0_STS                |
|       |      |             | frame 0 status        |
| 0     | RO   | 0x0         | 0- frame 0 not ready  |
|       |      |             | 1- frame 0 ready      |
|       |      |             | write 0 clear         |

## CIF\_CIF\_CUR\_DST

Address: Operational Base + offset (0x0064)



CIF current destination address

| Bit  | Attr | Reset Value | Description                               |
|------|------|-------------|-------------------------------------------|
| 31:0 | RO   | 0×00000000  | CUR_DST                                   |
|      |      |             | current destination address               |
|      |      |             | May be not the current, because the clock |
|      |      |             | synchronization.                          |

#### CIF\_CIF\_LAST\_LINE

Address: Operational Base + offset (0x0068)

CIF last frame line number

| Bit     | Attr   | Reset Value   | Description               |  |  |
|---------|--------|---------------|---------------------------|--|--|
| 31:14   | RO     | 0x0           | reserved                  |  |  |
| 13:0 RO | 0×0000 | LAST_LINE_NUM |                           |  |  |
|         | RO     | 00000         | line number of last frame |  |  |

## CIF\_CIF\_LAST\_PIX

Address: Operational Base + offset (0x006c)

CIF last line pixel number

| Bit   | Attr | Reset Value | Description                            |
|-------|------|-------------|----------------------------------------|
| 31:15 | RO   | 0x0         | reserved                               |
| 14:0  | RO   | 0×0000      | LAST_PIX_NUM pixel number of last line |

## 25.5 Timing Diagram



Table 25-1CIF0 Timing

| Symbol Parameter | best | Typ. | worst | unit |
|------------------|------|------|-------|------|
|------------------|------|------|-------|------|



|                   |                                                  | case  | case  | case |    |
|-------------------|--------------------------------------------------|-------|-------|------|----|
| t <sub>HSUP</sub> | Input HREF setup time to CIF_CLKIN rising edge   | 0.24  | 0.23  | 0.12 | ns |
| t <sub>HHP</sub>  | Input HREF hold time to CIF_CLKIN rising edge    | 0     | 0     | 0    | ns |
| t <sub>VSUP</sub> | Input VSYNC setup time to CIF_CLKIN rising edge  | 0.17  | 0.27  | 0.12 | ns |
| t <sub>VHP</sub>  | Input VSYNC hold time to CIF_CLKIN rising edge   | 0     | 0     | 0    | ns |
| t <sub>DSUP</sub> | Input DATAIN setup time to CIF_CLKIN rising edge | 0.661 | 0.975 | 1.34 | ns |
| t <sub>DHP</sub>  | Input DATAIN hold time to CIF_CLKIN rising edge  | 0     | 0     | 0    | ns |

x=0

Table 25-2CIF1 Timing

|                   |                                                  | _            | 0         |               |      |
|-------------------|--------------------------------------------------|--------------|-----------|---------------|------|
| Symbol            | Parameter                                        | best<br>case | Typ. case | worst<br>case | unit |
| t <sub>HSUP</sub> | Input HREF setup time to CIF_CLKIN rising edge   | 0.26         | 0.34      | 0.02          | ns   |
| t <sub>HHP</sub>  | Input HREF hold time to CIF_CLKIN rising edge    | 0            | 0         | 0             | ns   |
| t <sub>VSUP</sub> | Input VSYNC setup time to CIF_CLKIN rising edge  | 0.28         | 0.10      | 0             | ns   |
| t <sub>VHP</sub>  | Input VSYNC hold time to CIF_CLKIN rising edge   | 0            | 0         | 0.07          | ns   |
| t <sub>DSUP</sub> | Input DATAIN setup time to CIF_CLKIN rising edge | 0.90         | 1.29      | 1.50          | ns   |
| t <sub>DHP</sub>  | Input DATAIN hold time to CIF_CLKIN rising edge  | 0            | 0         | 0             | ns   |

# 25.6 Interface description

| <b>Module Pin</b> | Direction | Pad Name       | IOMUX Setting             |  |  |
|-------------------|-----------|----------------|---------------------------|--|--|
| CIF0              |           |                |                           |  |  |
| cif0_clkout       | 0         | GPIO1_B[3]     | GRF_GPIO1B_IOMUX[ 6]=1'b1 |  |  |
| cif0_clkin        | I         | CIF0_CLKIN     | N/A                       |  |  |
| cif0_href         | I         | CIF0_HREF      | N/A                       |  |  |
| cif0_vsync        | I         | CIF0_VSYNC     | N/A                       |  |  |
| cif0_data0        | I         | GPIO1_B[4]     | GRF_GPIO1B_IOMUX[ 8]=1'b1 |  |  |
| cif0_data1        | I         | GPIO1_B[5]     | GRF_GPIO1B_IOMUX[10]=1'b1 |  |  |
| cif0_data2        | I         | CIF0_DATAIN[2] | N/A                       |  |  |
| cif0_data3        | I         | CIF0_DATAIN[3] | N/A                       |  |  |
| cif0_data4        | I         | CIF0_DATAIN[4] | N/A                       |  |  |
| cif0_data5        | I         | CIF0_DATAIN[5] | N/A                       |  |  |
| cif0_data6        | I         | CIF0_DATAIN[6] | N/A                       |  |  |
| cif0_data7        | I         | CIF0_DATAIN[7] | N/A                       |  |  |
| cif0_data8        | I         | CIF0_DATAIN[8] | N/A                       |  |  |
| cif0_data9        | I         | CIF0_DATAIN[9] | N/A                       |  |  |
| cif0_data10       | I         | GPIO1_B[6]     | GRF_GPIO1B_IOMUX[12]=1'b1 |  |  |
| cif0_data11       | I         | GPIO1_B[7]     | GRF_GPIO1B_IOMUX[14]=1'b1 |  |  |
| CIF1              |           |                |                           |  |  |



|             |   |            | ·                          |
|-------------|---|------------|----------------------------|
| cif1_clkout | 0 | GPIO1_D[7] | GRF_GPIO1D_IOMUX[14]=1'b1  |
| cif1_clkin  | I | GPIO1_D[2] | GRF_GPIO1D_IOMUX[4]=1'b1   |
| cif1_href   | I | GPIO1_D[1] | GRF_GPIO1D_IOMUX[2]=1'b1   |
| cif1_vsync  | I | GPIO1_D[0] | GRF_GPIO1D_IOMUX[0]=1'b1   |
| cif1_data0  | I | GPIO1_D[3] | GRF_GPIO1D_IOMUX[6]=1'b1   |
| cif1_data1  | I | GPIO1_D[4] | GRF_GPIO1D_IOMUX[8]=1'b1   |
| cif1_data2  | I | GPIO1_C[0] | GRF_GPIO1C_IOMUX[1:0]=2'b1 |
| cif1_data3  | I | GPIO1_C[1] | GRF_GPIO1C_IOMUX[3:2]=2'b1 |
| cif1_data4  | I | GPIO1_C[2] | GRF_GPIO1C_IOMUX[5:4]=2'b1 |
| cif1_data5  | I | GPIO1_C[3] | GRF_GPIO1C_IOMUX[7:6]=2'b1 |
| cif1_data6  | I | GPIO1_C[4] | GRF_GPIO1C_IOMUX[9:8]=2'b1 |
| cif1_data7  | I | GPIO1_C[5] | GRF_GPIO1C_IOMUX[11:10]=2' |
|             |   |            | b1                         |
| cif1_data8  | I | GPIO1_C[6] | GRF_GPIO1C_IOMUX[13:12]=2' |
|             |   |            | b1                         |
| cif1_data9  | I | GPIO1_C[7] | GRF_GPIO1C_IOMUX[15:14]=2' |
|             |   |            | b1                         |
| cif1_data10 | I | GPIO1_D[5] | GRF_GPIO1D_IOMUX[10]=1'b1  |
| cif1_data11 | I | GPIO1_D[6] | GRF_GPIO1D_IOMUX[12]=1'b1  |

The valid data bits of different widths are the following:

8 bit: data2~data9; 10bit: data0~data9: 12bit: data0~data11;

## 25.7 Application Notes

There are two operations strongly depend on the configuration order: SCM and ISP.

The SCM configuration flow is:

- a. Write 1 to SCM\_INIT\_LD bit to make sure the SCM RAM can be written;
- b. Initialize all zero to the three 256x23 bit SCM RAM for Y/U/V statistics collection:
- c. Set SCM EN to announce SCM configuration is ready.

The ISP configuration is is very similar with SCM:

- a. Write 1 to ISP INIT LD bit bit to make sure the ISP RAM can be written;
- b. Initialize the ISP lut RAM for pixel value mapping.
- c. Set ISP EN to announce ISP configuration is ready.

The biggest configuration requirement of all operations is the CAP EN bit must be set after all the mode selection is ready. The configuration order of the input/output data format, YUV order, the address ,frame size/width , AXI burst length and other options do not need to care.

There are many debug registers to make it easy to read the internal operation information of CIF. The valid pixel number of scale result in FIFO can be known by readCIF CIF SCL VALID NUM. The line number of last frame and the pixel number of last line can be also known by read the CIF CIF LAST LINE and CIF\_CIF\_LAST\_PIX.

# **Chapter 26 USB Host2.0**

## 26.1 Overview

USB HOST2.0 supports host functions and is fully compliant with USB2.0 specification, and support

high-speed(480Mbps),full-speed(12Mbps),low-speed(1.5Mbps) transfer. USB HOST 2.0supports high-speed(480Mbps), full-speed(12Mbps), low-speed (1.5Mbps) transfer. It is optimized for point-to-point applications (no hub, direct connection to device).

#### 26.1.1 Features

- Compliant with the USB2.0 Specification
- Operates in host mode
- Operates in High-Speed and Full-Speed mode
- Support 16 channels in host mode
- Built-in one 840x35 bits FIFO
- Internal DMA with scatter/gather function

# 26.2 Block Diagram



Fig. 26-1USB HOST 2.0 Architecture

Fig.26-1 shows the architecture of USB HOST 2.0. It is broken up into two separate units: USB HOST 2.0 controller and USB HOST 2.0 PHY. The two units are interconnected with UTMI interface.

#### 26.2.1 USB HOST 2.0 Controller Function

The USB HOST 2.0 Controller controlsSIE(Serial Interface Engine) Logic , the Channel logic and the internal DMA logic.

The SIElogic contains the USB PID and address recognition logic, and other sequencingand state machine logic to handle USB packets and transactions.

The Channel Logic contains the channel tasks schedule, FIFOs and FIFO control, etc.

The internal DMA logic controls data trasaction between system memory and USB FIFOs.

#### 26.2.2 USB HOST 2.0 PHY Function

The USB HOST 2.0 PHY handles the low level USB protocol and signaling. This



includes features such as; dataserialization and deserialization, bit stuffing and clock recovery and synchronization. The primary focus ofthis block is to shift the clock domain of the data from the USB 2.0 rate to the frequency of UTMI clock which is 30MHz.

## 26.3 USB Host2.0 Controller

USB HOST Controller is a usb host controller, which supports both high-speed(480Mbps), full-speed(12Mbps) and is fully compliant with USB2.0 specification. This controller will support UTMI+ Level 3 PHY interface. It connects to the industry-standard AMBA AHB for communication with the application and system memory. And it is optimized for portable electronic device and point-to-point applications (no hub, direct connection to device) .

Fig.26-2 shows the architecture of USB HOST 2.0 Controller.

The host uses one transmit FIFO for all non-periodic OUT transactions and one transmit FIFO for all periodic OUT transactions. These transmit FIFOs are used as transmit buffers to hold the data (payload of the transmit packet) to be transmitted over USB. The host pipes the USB transactions through Request queues (one for periodic and one for non-periodic). Each entry in the Request queue holds the IN or OUT channel number along with other information to perform a transaction on the USB. The order in which the requests are written into the gueue determines the sequence of transactions on the USB. The host processes the periodic Request queue first, followed by the non-periodic Request queue, at the beginning of each (micro)frame. The host uses one receive FIFO for all periodic and non-periodic transactions. The FIFO is used as a receive buffer to hold the received data (payload of the received packet) from the USB until it is transferred to the system memory. The status of each packet received also goes into the FIFO. The status entry holds the IN channel number along with other information, such as received byte count and validity status, to perform a transaction on the AHB.



Fig. 26-2 USB HOST 2.0 Controller Architecture

## 26.4 USB Host2.0 PHY

The USB HOST 2.0 PHY connects a host controller to a USB system. It is a complete mixed-signal IP designed to implement USB connectivity in a System-on-Chip(SOC) design targeted to a specific fabrication process using core and 2.5-V thick-oxide devices. The USB 2.0 PHY supports the USB2.0 480-Mbps protocol and data rate, and is backward compatible with the USB 1.1 1.5-Mbps and 12-Mbps protocol and data rates.



### 26.4.1 Block Diagram

Fig.27-13 shows the USB HOST 2.0 PHY functional block diagram for a one-port macro.



Fig. 26-3 USB HOST 2.0 PHY Architecture

The USB HOST 2.0 PHY consists of three basic components: the Common block and Transceiver block.

- Common block: This block contains design components that can be reused for multiple transceivers.
- Transceiver block: This block contains the bulk of USB HOST 2.0 PHY circuitry for data processingand transfers.

# 26.5 Register description

## 26.5.1 Registers Summary

| Name              | Offset | Size                                    | Reset<br>Value | Description                    |
|-------------------|--------|-----------------------------------------|----------------|--------------------------------|
| HOST20_GOTGCTL    | 0x0000 | W                                       | 0x00000000     | Control and Status<br>Register |
| HOST20_GOTGINT    | 0x0004 | W                                       | 0x00000000     | Interrupt Register             |
| HOST20_GAHBCFG    | 0x0008 | w                                       | 0x00000000     | AHB Configuration              |
| 1103120_6/1110613 | σχοσσο | • • • • • • • • • • • • • • • • • • • • | 00000000       | Register                       |
| HOST20 GUSBCFG    | 0x000c | ۱۸/                                     | 0x00001400     | USB Configuration              |
| 1103120_0030610   | OXOOOC | * *                                     | 000001400      | Register                       |
| HOST20_GRSTCTL    | 0x0010 | W                                       | 0x80000000     | Reset Register                 |
| HOST20_GINTSTS    | 0x0014 | W                                       | 0x00000000     | Interrupt Register             |
| HOST20_GINTMSK    | 0x0018 | W                                       | 0x00000000     | Interrupt Mask Register        |



| Name             | Offset | Size | Reset<br>Value | Description                                            |
|------------------|--------|------|----------------|--------------------------------------------------------|
| HOST20_GRXSTSR   | 0x001c | W    | 0x00000000     | Receive Status Debug<br>Read                           |
| HOST20_GRXSTSP   | 0x0020 | W    | 0x00000000     | Receive Status Debug<br>Pop                            |
| HOST20_GRXFSIZ   | 0x0024 | W    | 0x00000000     | Receive FIFO Size<br>Register                          |
| HOST20_GNPTXFSIZ | 0x0028 | W    | 0×00000000     | Non-Periodic Transmit<br>FIFO Size Register            |
| HOST20_GNPTXSTS  | 0x002c | W    | 0×00000000     | Non-Periodic Transmit<br>FIFO/Queue Status<br>Register |
| HOST20_GI2CCTL   | 0x0030 | W    | 0x11000000     | I2C Address Register                                   |
| HOST20_GPVNDCTL  | 0x0034 | W    | 0x00000000     | PHY Vendor Control<br>Register                         |
| HOST20_GGPIO     | 0x0038 | W    | 0×00000000     | General Purpost<br>Input/Output Register               |
| HOST20_GUID      | 0x003c | W    | 0x0000000      | User ID Register                                       |
| HOST20_GSNPSID   | 0x0040 | W    | 0x00004f54     | Vendor ID Register                                     |
| HOST20_GHWCFG1   | 0x0044 | W    | 0x00000000     | User HW Config1<br>Register                            |
| HOST20_GHWCFG2   | 0x0048 | W )  | 0x00000000     | User HW Config2<br>Register                            |
| HOST20_GHWCFG3   | 0x004c | W    | 0×00000000     | User HW Config3<br>Register                            |
| HOST20_GHWCFG4   | 0x0050 | W    | 0×00000000     | User HW Config4<br>Register                            |
| HOST20_GLPMCFG   | 0x0054 | W    | 0×00000000     | Core LPM Configuration<br>Register                     |
| HOST20_GPWRDN    | 0x0058 | W    | 0x00000000     | Global Power Down<br>Register                          |
| HOST20_GDFIFOCFG | 0x005c | W    | 0x00000000     | Global DFIFO Software<br>Config Register               |
| HOST20_GADPCTL   | 0x0060 | W    | 0×00000000     | ADP Timer,Control and<br>Status Register               |
| HOST20_HPTXFSIZ  | 0x0100 | W    | 0×00000000     | Host Periodic Transmit<br>FIFO Size Register           |
| HOST20_DIEPTXFn  | 0x0104 | W    | 0x00000000     | Device Periodic Transmit<br>FIFO-1 Size Register       |
| HOST20_HCFG      | 0x0400 | W    | 0x00000000     | Host Configuration<br>Register                         |



| Name             | Offset | Size | Reset<br>Value | Description                                              |
|------------------|--------|------|----------------|----------------------------------------------------------|
| HOST20_HFIR      | 0x0404 | W    | 0×00000000     | Host Frame Interval<br>Register                          |
| HOST20_HFNUM     | 0×0408 | W    | 0x0000ffff     | Host Frame<br>Number/Frame Time<br>Remaining Register    |
| HOST20_HPTXSTS   | 0x0410 | W    | 0×00000000     | Host Periodic Transmit<br>FIFO/Queue Status<br>Register  |
| HOST20_HAINT     | 0x0414 | W    | 0x00000000     | Host All Channels<br>Interrupt Reigster                  |
| HOST20_HAINTMSK  | 0x0418 | W    | 0x00000000     | Host All Channels<br>Interrupt Mask Register             |
| HOST20_HPRT      | 0x0440 | W    | 0x00000000     | Host Port Control and<br>Status Register                 |
| HOST20_HCCHARn   | 0x0500 | W    | 0x00000000     | Host Channel-n<br>Characteristics Register               |
| HOST20_HCSPLTn   | 0x0504 | W    | 0x00000000     | Host Channel-n Split<br>Control Register                 |
| HOST20_HCINTn    | 0x0508 | W    | 0x00000000     | Host Channel-n<br>Interrupt Register                     |
| HOST20_HCINTMSKn | 0x050c | W )  | 0x00000000     | Host Channel-n<br>Interrupt Mask Register                |
| HOST20_HCTSIZn   | 0x0510 | W    | 0x00000000     | Host Channel-n Transfer<br>Size Register                 |
| HOST20_HCDMAn    | 0x0514 | W    | 0x00000000     | Host Channel-n DMA<br>Address Register                   |
| HOST20_HCDMABn   | 0x051c | W    | 0x00000000     | Host Channel-n DMA<br>Buffer Address Register            |
| HOST20_DCFG      | 0x0800 | W    | 0x08200000     | Device Cconfiguration<br>Register                        |
| HOST20_DCTL      | 0x0804 | W    | 0x00002000     | Device Control Register                                  |
| HOST20_DSTS      | 0x0808 | W    | 0x00000000     | Device Status Register                                   |
| HOST20_DIEPMSK   | 0x0810 | W    | 0x00000000     | Device IN Endpoint<br>common interrupt mask<br>register  |
| HOST20_DOEPMSK   | 0x0814 | W    | 0x00000000     | Device OUT Endpoint<br>common interrupt mask<br>register |
| HOST20_DAINT     | 0x0818 | W    | 0x00000000     | Device All Endpoints interrupt register                  |



| Name                     | Offset  | Size | Reset<br>Value | Description                                 |
|--------------------------|---------|------|----------------|---------------------------------------------|
| HOST20_DAINTMSK          | 0x081c  | W    | 0×00000000     | Device All Endpoint interrupt mask register |
|                          |         |      |                | Device IN token                             |
| HOST20_DTKNQR1           | 0x0820  | w    | 0×00000000     | sequence learning queue                     |
|                          |         |      |                | read register1                              |
|                          |         |      |                | Device IN token                             |
| HOST20_DTKNQR2           | 0x0824  | W    | 0×00000000     | sequence learning queue                     |
|                          |         |      |                | read register2                              |
| LIOCTAO DVIDUCDIC        | 00020   | ١٨/  | 000000505      | Device VBUS discharge                       |
| HOST20_DVBUSDIS          | 0x0828  | VV   | 0x00000b8f     | time register                               |
| LIOCTAO DVIDLICIULI CE   | 0x082c  | ١٨/  | 0x00000000     | Device VBUS Pulsing                         |
| HOST20_DVBUSPULSE        | UXU82C  | VV   |                | Timer Register                              |
| HOCTOD DTHRCTI           | 0x0830  | ١٨/  | 0x08100020     | Device Threshold Control                    |
| HOST20_DTHRCTL           | UXU63U  | VV   | 0x08100020     | Register                                    |
|                          |         |      |                | Device IN endpoint FIFO                     |
| HOST20_DIEPEMPMSK        | 0x0834  | W    | 0x00000000     | empty interrupt mask                        |
|                          |         |      | $C^{\Lambda}$  | register                                    |
| HOST20_DEACHINT          | 0x0838  | ۱۸/  | 0×00000000     | Device each endpoint                        |
| TIOSTZU_DLACITINT        | 0.0030  | VV   | 0x00000000     | interrupt register                          |
| HOST20_DEACHINTMSK       | 0x083c  | w/   | 0×00000000     | Device each endpoint                        |
| TIOSTZO_DEACHINTINSK     | UXUUJE  | VV   | 0,00000000     | interrupt register mask                     |
| HOST20_DIEPEACHMSKn      | 0x0840  | W    | 0x00000000     | Device each IN endpoint                     |
| TIOSTZO_DIEI EACHIIISKII | 070040  | ٧٧   | 020000000      | -n interrupt Register                       |
| •                        | ~       |      |                | Device each out                             |
| HOST20_DOEPEACHMSKn      | 0x0880  | W    | 0x00000000     | endpoint-n interrupt                        |
|                          |         |      |                | register                                    |
|                          |         |      |                | Device control IN                           |
| HOST20_DIEPCTL0          | 0x0900  | W    | 0x00008000     | endpoint 0 control                          |
|                          |         |      |                | register                                    |
| HOST20_DIEPINTn          | 0x0908  | w    | 0x00000000     | Device Endpoint-n                           |
| TIOSTEO_DIETITATI        | 0,000   | **   | 020000000      | Interrupt Register                          |
| HOST20_DIEPTSIZn         | 0x0910  | W    | 0x00000000     | Device endpoint n                           |
| TIOSTEO_DIETTOIETT       | 0,00010 | **   | 020000000      | transfer size register                      |
| HOST20_DIEPDMAn          | 0x0914  | w    | 0x00000000     | Device endpoint-n DMA                       |
|                          | 370714  | * *  | 2,0000000      | address register                            |
|                          |         |      |                | Device IN endpoint                          |
| HOST20_DTXFSTSn          | 0x0918  | W    | 0x00000000     | transmit FIFO status                        |
|                          |         |      |                | register                                    |
| HOST20_DIEPDMABn         | 0x091c  | w    | 0x00000000     | Device endpoint-n DMA                       |
|                          | 3,0310  |      | 2,0000000      | buffer address register                     |



|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Name               | Offset     | Size                                         | Reset<br>Value | Description              |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|------------|----------------------------------------------|----------------|--------------------------|
| HOST20_DOEPCTL0  0x0b00 W  0x000000000  Device control OUT endpoint 0 control register  Device endpoint n control register  Device endpoint n transfer size register  Device endpoint n transfer size register  Device endpoint n transfer size register  Device endpoint-n control register  Device endpoint n transfer size register  Device endpoint-n DMA Address Register  Device endpoint-n DMA buffer address register  Device endpoint-n control register  Device endpoint-n transfer size register  Device endpoint-n control register  Device endpoint-n transfer size register  Device endpoint-n control register  Device endpoint-n transfer size register  Device endpoint-n control register  Device endpoint-n transfer size register  Device endpoint-n control register  Device endpoint-n transfer size register  Device endpoint-n control register  Device endpoint-n transfer size register  Device endpoint-n control register  Device endpoint-n transfer size register  Device endpoint-n control register  Device endpoint-n transfer size register  Device endpoint-n control register  Device endpoint n transfer size register  Device endpoint-n control register  Device endpoint n transfer size register  Device endpoint-n control register  Device endpoint n transfer size register  Device endpoint n control register  Device endpoint n transfer size register  Device endpoint n control register  Device endpoint n transfer size register  Device endpoint n control register  Device endpoint o n control register  Device endpoint n control register  Device endpoint o n control regis | HOST20 DIEPCTI n   | 0>0920     | ۱۸/                                          | 0×00000000     | Device endpoint-n        |
| HOST20_DOEPCTLO  0x0b00 W  0x000000000   Device endpoint 0 control register  Device endpoint n control register  Device endpoint n transfer size register  Device endpoint-n DMA Address Register  Device endpoint-n DMA buffer address register  Device endpoint-n DMA buffer address register  Device endpoint-n control register  Device endpoint 1 Device endpoint n DMA buffer address register  Device endpoint 1 / host out channel 3 address  Device endpoint 1 / host out channel 4 address  Device endpoint 4 / host out channel 5 address  Device endpoint 5 / host out channel 6 address  Device endpoint 6 / host out channel 7 address  Device endpoint 8 / host out channel 8 address  Device endpoint 9 / host out channel 8 address  Device endpoint 10 / host out channel 9 address  Device endpoint 10 / host out channel 10                                                                                                                                                                                                                               | TIOSTZO_DIET CTEIT | 070720     | VV                                           | 020000000      | control register         |
| HOST20_DOEPINTN  0x0b08 W  0x000000000  Device endpoint n transfer size register  Device Endpoint n DMA Address Register  Device endpoint n transfer size register  Device Endpoint n DMA Address Register  Device endpoint n DMA buffer address register  Power and clock gating control register  Device endpoint 0 / host out channel 0 address  Device endpoint 1 / host out channel 1 address  Device endpoint 2 / host out channel 1 address  Device endpoint 2 / host out channel 2 address  Device endpoint 3 / host out channel 3 address  Device endpoint 4 / host out channel 4 address  HOST20_EPBUF4  0x5000 W  0x00000000  Device endpoint 5 / host out channel 5 address  HOST20_EPBUF5  0x6000 W  0x00000000  Device endpoint 7 / host out channel 6 address  HOST20_EPBUF7  0x8000 W  0x00000000  Device endpoint 8 / host out channel 7 address  Device endpoint 9 / host out channel 9 address  Device endpoint 9 / host out channel 9 address  Device endpoint 9 / host out channel 9 address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                    |            |                                              |                | Device control OUT       |
| HOST20_DOEPINTN  Ox0b08 W  Dx000000000  Device endpoint-n control register  Device endpoint n transfer size register  HOST20_DOEPDMAN  Ox0b14 W  Dx000000000  Device endpoint n transfer size register  HOST20_DOEPDMABN  Ox0b1c W  Dv000000000  Device endpoint-n DMA Address Register  Device endpoint-n DMA buffer address register  HOST20_DOEPCTLN  Ox0b20 W  Dv000000000  Device endpoint-n DMA buffer address register  Ox0b24 W  Ox200b8000  Device endpoint-n control register  Power and clock gating control register  HOST20_EPBUF0  Ox1000 W  Ox000000000  Device endpoint 0 / host out channel 0 address  Device endpoint 1 / host out channel 1 address  Device endpoint 2 / host out channel 2 address  HOST20_EPBUF3  Ox4000 W  Ox00000000  Device endpoint 3 / host out channel 3 address  HOST20_EPBUF4  Ox5000 W  Ox00000000  Device endpoint 4 / host out channel 3 address  HOST20_EPBUF5  Ox6000 W  Ox00000000  Device endpoint 5 / host out channel 5 address  HOST20_EPBUF6  Ox7000 W  Ox00000000  Device endpoint 6 / host out channel 5 address  HOST20_EPBUF7  Ox8000 W  Ox00000000  Device endpoint 7 / host out channel 6 address  HOST20_EPBUF8  Ox9000 W  Ox00000000  Device endpoint 7 / host out channel 7 address  HOST20_EPBUF8  Ox9000 W  Ox00000000  Device endpoint 9 / host out channel 8 address  Device endpoint 9 / host out channel 9 address  Device endpoint 9 / host out channel 9 address  Device endpoint 10 / host out channel 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | HOST20_DOEPCTL0    | 0x0b00     | W                                            | 0x00000000     | endpoint 0 control       |
| HOST20_DOEPININ  OXOBOS W  OXODO000000  Control register  Device endpoint n transfer size register  Device Endpoint-n DMA Address Register  Device endpoint-n DMA Address Register  HOST20_DOEPDMABN  OXOB02 W  OXODO000000  HOST20_DOEPCTLN  OX0b20 W  OXOD0000000  Device endpoint-n DMA buffer address register  Device endpoint 0 / host out channel 0 address  Device endpoint 1 / host out channel 1 address  Device endpoint 2 / host out channel 1 address  Device endpoint 3 / host out channel 2 address  Device endpoint 3 / host out channel 3 address  Device endpoint 4 / host out channel 3 address  Device endpoint 5 / host out channel 4 address  Device endpoint 5 / host out channel 5 address  Device endpoint 6 / host out channel 5 address  Device endpoint 7 / host out channel 6 address  HOST20_EPBUF6  OX7000 W  OX00000000  Device endpoint 6 / host out channel 6 address  Device endpoint 7 / host out channel 7 address  Device endpoint 8 / host out channel 7 address  Device endpoint 8 / host out channel 8 address  Device endpoint 9 / host out channel 8 address  Device endpoint 9 / host out channel 8 address  Device endpoint 9 / host out channel 9 address  Device endpoint 10 / host out channel 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                    |            |                                              |                | register                 |
| HOST20_DOEPTSIZN  0x0b10 W  0x000000000  Device endpoint n transfer size register  Device Endpoint-n DMA Address Register  Device endpoint-n DMA Device endpoint Device endpoint Device endpoint DMA Device endpoint Device endp | HOSTON DOEDINTS    | nynhne     | ۱۸/                                          | 0×0000000      | Device endpoint-n        |
| HOST20_DOEPTS12N                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 1103120_DOLFINIII  | UXUDUO     | VV                                           | 020000000      | control register         |
| HOST20_DOEPDMAN  Ox0b14 W  Ox00000000  Device Endpoint-n DMA Address Register  Device endpoint-n DMA buffer address register  Device endpoint-n control register  Device endpoint 0 / host out channel 0 address  Power and clock gating control register  Device endpoint 1 / host out channel 1 address  Device endpoint 1 / host out channel 1 address  Device endpoint 2 / host out channel 2 address  Device endpoint 3 / host out channel 3 address  Device endpoint 3 / host out channel 3 address  Device endpoint 4 / host out channel 4 address  Device endpoint 5 / host out channel 5 address  HOST20_EPBUF5  Ox6000 W  Ox00000000  Device endpoint 6 / host out channel 5 address  Device endpoint 7 / host out channel 6 address  Device endpoint 7 / host out channel 6 address  Device endpoint 7 / host out channel 6 address  Device endpoint 6 / host out channel 7 address  Device endpoint 7 / host out channel 7 address  Device endpoint 8 / host out channel 7 address  Device endpoint 8 / host out channel 8 address  Device endpoint 9 / host out channel 9 address  Device endpoint 9 / host out channel 9 address  Device endpoint 10 / host out channel 9 address  Device endpoint 10 / host out channel 9 address  Device endpoint 10 / host out channel 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | HOST20 DOEDTSIZE   | 0v0b10     | ۱۸/                                          | 0×00000000     | Device endpoint n        |
| HOST20_DOEPDMABN  Ox0b1c W Ox00000000  HOST20_DOEPCTLN  Ox0b20 W Ox00000000  HOST20_PCGCR  Ox0b24 W Ox200b8000  HOST20_EPBUF0  Ox1000 W Ox00000000  HOST20_EPBUF1  Ox2000 W Ox00000000  HOST20_EPBUF1  Ox2000 W Ox00000000  HOST20_EPBUF2  Ox3000 W Ox00000000  HOST20_EPBUF3  Ox4000 W Ox00000000  HOST20_EPBUF4  Ox5000 W Ox00000000  HOST20_EPBUF5  Ox6000 W Ox00000000  HOST20_EPBUF5  Ox6000 W Ox00000000  HOST20_EPBUF6  Ox7000 W Ox00000000  HOST20_EPBUF7  Ox6000 W Ox00000000  HOST20_EPBUF7  Ox6000 W Ox00000000  HOST20_EPBUF7  Ox6000 W Ox00000000  HOST20_EPBUF7  Ox6000 W Ox00000000  HOST20_EPBUF7  Ox8000 W Ox00000000  HOST20_EPBUF7  Ox8000 W Ox00000000  HOST20_EPBUF7  Ox8000 W Ox00000000  Device endpoint 6 / host out channel 5 address out channel 5 address out channel 5 address out channel 6 address out channel 7 address out channel 8 address out channel 9 address out channel 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                    | OXODIO     | VV                                           | 0x0000000      | transfer size register   |
| HOST20_DOEPDMABN  Ox0b1c W 0x00000000  HOST20_DOEPCTLN  Ox0b20 W 0x000000000  HOST20_PCGCR  Ox0b24 W 0x200b8000  HOST20_EPBUF0  Ox1000 W 0x000000000  HOST20_EPBUF1  Ox2000 W 0x000000000  HOST20_EPBUF2  Ox3000 W 0x00000000  HOST20_EPBUF3  Ox4000 W 0x00000000  Ox00000000  HOST20_EPBUF4  Ox5000 W 0x00000000  Ox00000000  HOST20_EPBUF5  Ox6000 W 0x00000000  HOST20_EPBUF6  Ox7000 W 0x00000000  HOST20_EPBUF7  Ox8000 W 0x00000000  HOST20_EPBUF7  Ox8000 W 0x00000000  Device endpoint 4 / host out channel 5 address out channel 6 address out channel 6 address out channel 6 address out channel 7 address out channel 8 address out channel 9 address out channel 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | HOCTOO DOEDDMA     | 0v0h14     | ١٨/                                          | 0,0000000      | Device Endpoint-n DMA    |
| HOST20_DOEPDMABN    DX0b1c   W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | HOSTZU_DOEPDMAN    | UXUD14     | VV                                           |                | Address Register         |
| HOST20_PCGCR  Ox0b24 W  Ox200b8000  Device endpoint-n control register  Power and clock gating control register  Device endpoint 0 / host out channel 0 address  Device endpoint 1 / host out channel 1 address  Power and clock gating control register  Power and clock gating control perice endpoint 1 / host out channel 1 0  Power and clock gating control register  Power and clock gating control perice endpoint 1 / host out channel 3 address  Powice endpoint 7 / host out channel 8 address  Powice endpoint 7 / host out channel 9 address  Powice endpoint 7 / host out channel 9 address  Powice endpoint 7 / host out channel 10                                                                                                             | LICCTOR DOEDDMAR   | 0, 0, 1, - | ١٨/                                          | 00000000       | Device endpoint-n DMA    |
| HOST20_PCGCR  0x0b24 W  0x200b8000  Control register  Power and clock gating control register  Device endpoint 0 / host out channel 0 address  Device endpoint 1 / host out channel 1 address  Device endpoint 2 / host out channel 2 address  Device endpoint 3 / host out channel 3 address  Device endpoint 4 / host out channel 3 address  Device endpoint 5 / host out channel 4 address  Device endpoint 5 / host out channel 5 address  HOST20_EPBUF5  0x6000 W  0x00000000  HOST20_EPBUF5  0x6000 W  0x00000000  Device endpoint 6 / host out channel 5 address  Device endpoint 6 / host out channel 6 address  Device endpoint 7 / host out channel 7 address  Device endpoint 7 / host out channel 7 address  Device endpoint 8 / host out channel 7 address  Device endpoint 9 / host out channel 8 address  Device endpoint 9 / host out channel 9 address  Device endpoint 9 / host out channel 9 address  Device endpoint 1 / host out channel 9 address  Device endpoint 9 / host out channel 9 address  Device endpoint 1 / host out channel 9 address  Device endpoint 1 / host out channel 9 address  Device endpoint 1 / host out channel 9 address  Device endpoint 1 / host out channel 9 address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | HOSTZU_DOEPDMABN   | OXODIC     | VV                                           |                | buffer address register  |
| HOST20_PCGCR  0x0b24 W  0x200b8000  Power and clock gating control register  Device endpoint 0 / host out channel 0 address  Device endpoint 1 / host out channel 1 address  Device endpoint 2 / host out channel 2 address  HOST20_EPBUF2  0x3000 W  0x00000000  HOST20_EPBUF3  0x4000 W  0x00000000  Device endpoint 1 / host out channel 2 address  Device endpoint 3 / host out channel 3 address  Device endpoint 4 / host out channel 4 address  Device endpoint 5 / host out channel 5 address  Device endpoint 6 / host out channel 6 address  Device endpoint 7 / host out channel 6 address  Device endpoint 7 / host out channel 7 address  Device endpoint 8 / host out channel 7 address  Device endpoint 8 / host out channel 8 address  Device endpoint 9 / host out channel 9 address  Device endpoint 1 / host out channel 9 address  Device endpoint 1 / host out channel 9 address  Device endpoint 1 / host out channel 9 address  Device endpoint 1 / host out channel 9 address  Device endpoint 1 / host out channel 9 address  Device endpoint 1 / host out channel 9 address  Device endpoint 1 / host out channel 9 address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | LIGGTON BOEDGTI -  | 0,,0520    | ١٨/                                          | 00000000       | Device endpoint-n        |
| HOST20_EPBUF0  Ox1000 W  Ox00000000  Device endpoint 0 / host out channel 0 address Ox1000 W  Ox00000000  HOST20_EPBUF1  Ox2000 W  Ox00000000  Device endpoint 1 / host out channel 1 address Ox1000 W  Ox000000000  HOST20_EPBUF2  Ox3000 W  Ox000000000  Device endpoint 2 / host out channel 2 address Ox1000 W  Ox000000000  HOST20_EPBUF3  Ox5000 W  Ox000000000  HOST20_EPBUF4  Ox5000 W  Ox000000000  Device endpoint 4 / host out channel 3 address Ox5000 W  Ox000000000  Device endpoint 5 / host out channel 5 address Ox5000 W  Ox000000000  Device endpoint 6 / host out channel 6 address Ox7000 W  Ox00000000  HOST20_EPBUF7  Ox8000 W  Ox00000000  Device endpoint 7 / host out channel 7 address Ox5000 W  Ox00000000  Device endpoint 8 / host out channel 8 address Ox5000 W  Ox000000000  Device endpoint 9 / host out channel 9 address Device endpoint 10 / host out channel 9 address Device endpoint 10 / host out channel 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | HOST20_DOEPCTEN    | UXUD2U     | VV                                           | 0x00000000     | control register         |
| HOST20_EPBUF0  Ox1000 W  Ox00000000  Device endpoint 0 / host out channel 0 address Ox1000 W  Ox00000000  HOST20_EPBUF1  Ox2000 W  Ox00000000  Device endpoint 1 / host out channel 1 address Ox1000 W  Ox000000000  HOST20_EPBUF2  Ox3000 W  Ox000000000  Device endpoint 2 / host out channel 2 address Ox1000 W  Ox000000000  HOST20_EPBUF3  Ox5000 W  Ox000000000  HOST20_EPBUF4  Ox5000 W  Ox000000000  Device endpoint 4 / host out channel 3 address Ox5000 W  Ox000000000  Device endpoint 5 / host out channel 5 address Ox5000 W  Ox000000000  Device endpoint 6 / host out channel 6 address Ox7000 W  Ox00000000  HOST20_EPBUF7  Ox8000 W  Ox00000000  Device endpoint 7 / host out channel 7 address Ox5000 W  Ox00000000  Device endpoint 8 / host out channel 8 address Ox5000 W  Ox000000000  Device endpoint 9 / host out channel 9 address Device endpoint 10 / host out channel 9 address Device endpoint 10 / host out channel 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | LIOCTAD DOCCD      | 001-24     | ١٨/                                          | 02001-0000     | Power and clock gating   |
| HOST20_EPBUF1  0x2000 W  0x00000000  0ut channel 0 address Device endpoint 1 / host out channel 1 address Device endpoint 2 / host out channel 2 address Device endpoint 3 / host out channel 3 address Device endpoint 3 / host out channel 3 address Device endpoint 4 / host out channel 3 address Device endpoint 5 / host out channel 4 address Device endpoint 6 / host out channel 5 address Device endpoint 6 / host out channel 5 address Device endpoint 7 / host out channel 6 address Device endpoint 6 / host out channel 6 address Device endpoint 7 / host out channel 7 address Device endpoint 8 / host out channel 7 address Device endpoint 8 / host out channel 8 address Device endpoint 9 / host out channel 8 address Device endpoint 9 / host out channel 9 address Device endpoint 1 / host out channel 9 address Device endpoint 1 / host out channel 9 address Device endpoint 1 / host out channel 9 address Device endpoint 1 / host out channel 9 address Device endpoint 1 / host out channel 9 address Device endpoint 1 / host out channel 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | HOS120_PCGCR       | UXUD24     | VV                                           | 0x200b8000     |                          |
| HOST20_EPBUF1  0x2000 W  0x00000000  0ut channel 0 address Device endpoint 1 / host out channel 1 address Device endpoint 2 / host out channel 2 address Device endpoint 3 / host out channel 3 address Device endpoint 3 / host out channel 3 address Device endpoint 4 / host out channel 3 address Device endpoint 5 / host out channel 4 address Device endpoint 6 / host out channel 5 address Device endpoint 6 / host out channel 5 address Device endpoint 7 / host out channel 6 address Device endpoint 6 / host out channel 6 address Device endpoint 7 / host out channel 7 address Device endpoint 8 / host out channel 7 address Device endpoint 8 / host out channel 8 address Device endpoint 9 / host out channel 8 address Device endpoint 9 / host out channel 9 address Device endpoint 1 / host out channel 9 address Device endpoint 1 / host out channel 9 address Device endpoint 1 / host out channel 9 address Device endpoint 1 / host out channel 9 address Device endpoint 1 / host out channel 9 address Device endpoint 1 / host out channel 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                    |            |                                              |                | Device endpoint 0 / host |
| HOST20_EPBUF2  0x3000 W  0x000000000  out channel 1 address Device endpoint 2 / host out channel 2 address Device endpoint 3 / host out channel 3 address Device endpoint 4 / host out channel 4 address Device endpoint 5 / host out channel 4 address Device endpoint 6 / host out channel 5 address HOST20_EPBUF5  0x6000 W  0x00000000  HOST20_EPBUF5  0x7000 W  0x00000000  Device endpoint 5 / host out channel 5 address Device endpoint 6 / host out channel 6 address Device endpoint 7 / host out channel 7 address Device endpoint 7 / host out channel 7 address Device endpoint 8 / host out channel 8 address Device endpoint 8 / host out channel 8 address Device endpoint 9 / host out channel 8 address Device endpoint 9 / host out channel 9 address Device endpoint 10 / host out channel 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | HOS120_EPBUF0      | 0x1000     | W                                            | 0x00000000     | •                        |
| HOST20_EPBUF2  0x3000 W  0x00000000  Device endpoint 2 / host out channel 2 address Ox4000 W  0x000000000  Device endpoint 3 / host out channel 3 address Ox5000 W  0x000000000  HOST20_EPBUF4  0x5000 W  0x000000000  Device endpoint 4 / host out channel 4 address Ox6000 W  0x000000000  Device endpoint 5 / host out channel 5 address Ox6000 W  0x000000000  Device endpoint 6 / host out channel 6 address Ox7000 W  0x000000000  Device endpoint 6 / host out channel 6 address Ox7000 W  0x000000000  Device endpoint 7 / host out channel 7 address Ox9000 W  0x000000000  Device endpoint 8 / host out channel 8 address Ox9000 W  0x000000000  Device endpoint 8 / host out channel 8 address Ox9000 W  0x000000000  Device endpoint 9 / host out channel 9 address Ox9000 W  0x000000000  Device endpoint 9 / host out channel 9 address Ox9000 W  0x0000000000  Device endpoint 10 / host out channel 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | HOSTO EDRUE1       | 0×2000     | W/ (                                         | 0×0000000      | Device endpoint 1 / host |
| HOST20_EPBUF3  0x4000 W  0x00000000  0ut channel 2 address Device endpoint 3 / host out channel 3 address Device endpoint 4 / host out channel 4 address Device endpoint 5 / host out channel 5 address Device endpoint 6 / host out channel 5 address Device endpoint 7 / host out channel 6 address Device endpoint 7 / host out channel 6 address Device endpoint 6 / host out channel 6 address Device endpoint 7 / host out channel 7 address Device endpoint 8 / host out channel 7 address Device endpoint 9 / host out channel 8 address Device endpoint 9 / host out channel 9 address Device endpoint 10 / host out channel 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | TIOSTZU_LFB0T1     | 0.000      | VV                                           | 0x00000000     | out channel 1 address    |
| HOST20_EPBUF3  0x4000 W  0x00000000  Device endpoint 3 / host out channel 3 address  Device endpoint 4 / host out channel 4 address  Device endpoint 5 / host out channel 5 address  Device endpoint 5 / host out channel 5 address  Device endpoint 6 / host out channel 6 address  Device endpoint 7 / host out channel 6 address  Device endpoint 7 / host out channel 7 address  Device endpoint 8 / host out channel 7 address  Device endpoint 9 / host out channel 8 address  Device endpoint 9 / host out channel 9 address  Device endpoint 10 / host out channel 9 address  Device endpoint 10 / host out channel 9 address  Device endpoint 10 / host out channel 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | HOSTON EDRIJES     | 0^3000     | W                                            | 0,0000000      | Device endpoint 2 / host |
| HOST20_EPBUF3  0x4000 W  0x00000000  0ut channel 3 address  Device endpoint 4 / host out channel 4 address  Device endpoint 5 / host out channel 5 address  Device endpoint 6 / host out channel 6 address  Device endpoint 7 / host out channel 6 address  Device endpoint 7 / host out channel 7 address  Device endpoint 8 / host out channel 7 address  Device endpoint 7 / host out channel 7 address  Device endpoint 8 / host out channel 8 address  Device endpoint 8 / host out channel 8 address  Device endpoint 9 / host out channel 9 address  Device endpoint 9 / host out channel 9 address  Device endpoint 10 / host out channel 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | HUSTZU_EPBUFZ      | 0x3000     | VV                                           | 0x0000000      | out channel 2 address    |
| HOST20_EPBUF4  0x5000 W  0x00000000  Device endpoint 4 / host out channel 3 address  Device endpoint 5 / host out channel 5 address  Device endpoint 5 / host out channel 5 address  Device endpoint 6 / host out channel 6 address  Device endpoint 7 / host out channel 6 address  Device endpoint 7 / host out channel 7 address  Device endpoint 7 / host out channel 7 address  Device endpoint 8 / host out channel 8 address  Device endpoint 9 / host out channel 8 address  Device endpoint 9 / host out channel 9 address  Device endpoint 10 / host out channel 9 address  Device endpoint 10 / host out channel 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | HOSTON EDDINES     | 0×4000     | ١٨/                                          | 0,0000000      | Device endpoint 3 / host |
| HOST20_EPBUF5  Ox6000 W  Ox00000000  Device endpoint 5 / host out channel 5 address  Device endpoint 6 / host out channel 6 address  Device endpoint 7 / host out channel 7 address  Device endpoint 7 / host out channel 7 address  Device endpoint 8 / host out channel 8 address  Device endpoint 8 / host out channel 8 address  Device endpoint 9 / host out channel 9 address  Device endpoint 9 / host out channel 9 address  Device endpoint 9 / host out channel 9 address  Device endpoint 10 / host out channel 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | HOS120_EPBUF3      | UX4000     | VV                                           |                | out channel 3 address    |
| HOST20_EPBUF5  0x6000 W  0x00000000  Device endpoint 5 / host out channel 5 address  Device endpoint 6 / host out channel 6 address  Device endpoint 7 / host out channel 7 address  Device endpoint 7 / host out channel 7 address  Device endpoint 8 / host out channel 8 address  Device endpoint 9 / host out channel 8 address  Device endpoint 9 / host out channel 9 address  Device endpoint 9 / host out channel 9 address  Device endpoint 9 / host out channel 9 address  Device endpoint 10 / host out channel 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | LIOCTOO EDDILEA    | 0          | ١٨/                                          | 00000000       | Device endpoint 4 / host |
| HOST20_EPBUF6  0x7000 W  0x00000000  Device endpoint 6 / host out channel 6 address  Device endpoint 7 / host out channel 7 address  Device endpoint 8 / host out channel 8 address  Device endpoint 8 / host out channel 8 address  Device endpoint 9 / host out channel 9 address  Device endpoint 9 / host out channel 9 address  Device endpoint 10 / host out channel 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | HUS12U_EPBUF4      | UX5000     | VV                                           |                | out channel 4 address    |
| HOST20_EPBUF6  0x7000 W  0x00000000  Device endpoint 6 / host out channel 6 address  Device endpoint 7 / host out channel 7 address  Device endpoint 8 / host out channel 8 address  Device endpoint 8 / host out channel 8 address  Device endpoint 8 / host out channel 8 address  Device endpoint 9 / host out channel 9 address  Device endpoint 10 / host out channel 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | LIOCTOO EDDUCE     | 0          | ١٨/                                          | 00000000       | Device endpoint 5 / host |
| HOST20_EPBUF7  Ox8000 W  Ox00000000  Out channel 6 address  Device endpoint 7 / host out channel 7 address  Ox9000 W  Ox00000000  Ox00000000  Device endpoint 8 / host out channel 8 address  Device endpoint 9 / host out channel 9 address  Device endpoint 10 / host out channel 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | HUS120_EPBUF5      | UX6000     | VV                                           |                | out channel 5 address    |
| HOST20_EPBUF7  0x8000 W  0x00000000  Device endpoint 7 / host out channel 7 address  Device endpoint 8 / host out channel 8 address  Device endpoint 8 / host out channel 8 address  Device endpoint 9 / host out channel 9 address  Device endpoint 10 / host out channel 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | LIOCTOR EDDLIEC    | 07000      | ١٨/                                          | 00000000       | Device endpoint 6 / host |
| HOST20_EPBUF9  Ox8000 W  Ox00000000  Out channel 7 address  Device endpoint 8 / host out channel 8 address  Ox8000 W  Ox00000000  Ox00000000  Device endpoint 9 / host out channel 9 address  Device endpoint 10 / host out channel 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | HOSTZU_EPBUF6      | UX7000     | VV                                           |                | out channel 6 address    |
| HOST20_EPBUF9  Ox8000 W  Ox00000000  Out channel 7 address  Device endpoint 8 / host out channel 8 address  Ox8000 W  Ox00000000  Ox00000000  Device endpoint 9 / host out channel 9 address  Device endpoint 10 / host out channel 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                    |            |                                              |                | Device endpoint 7 / host |
| HOST20_EPBUF9  Oxa000 W  Ox00000000  Out channel 8 address  Device endpoint 9 / host out channel 9 address  Device endpoint 10 / host out channel 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | HOS120_EPBUF/      | 0008X0     | VV                                           | 0×00000000     | out channel 7 address    |
| HOST20_EPBUF9  0xa000 W  0x00000000  Device endpoint 9 / host out channel 9 address  Device endpoint 10 /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | LIOCTAG EDDIJEG    | 0000       | <b>\</b> \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | 000000000      | Device endpoint 8 / host |
| Oxa000   W   Ox0000000   Out channel 9 address   Device endpoint 10 / HOST20_EPBUF10   Ox9000   W   Ox00000000   host out channel 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | HOS120_EPBUF8      | 0X9000     | VV                                           | 0x00000000     | out channel 8 address    |
| HOST20_EPBUF10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | LIOCTAG EDDIJEG    | 0000       | <b>\</b> \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | 000000000      | Device endpoint 9 / host |
| HOST20_EPBUF10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | HUS12U_EPBUF9      | uxauuu     | VV                                           | UXUUUUUUUU     | out channel 9 address    |
| HOST20_EPBUF10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                    |            |                                              |                | Device endpoint 10 /     |
| address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | HOST20_EPBUF10     | 0x9000     | W                                            | 0x00000000     | host out channel 10      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                    |            | address                                      |                |                          |



| Name           | Offset | Size | Reset<br>Value | Description                                            |
|----------------|--------|------|----------------|--------------------------------------------------------|
| HOST20_EPBUF11 | 0xa000 | W    | 0×00000000     | Device endpoint 11 /<br>host out channel 11<br>address |
| HOST20_EPBUF12 | 0x9000 | W    | 0×00000000     | Device endpoint 12 /<br>host out channel 12<br>address |
| HOST20_EPBUF13 | 0xa000 | W    | 0×00000000     | Device endpoint 13 /<br>host out channel 13<br>address |
| HOST20_EPBUF14 | 0x9000 | W    | 0x00000000     | Device endpoint 14 /<br>host out channel 14<br>address |
| HOST20_EPBUF15 | 0xa000 | W    | 0x00000000     | Device endpoint 15 /<br>host out channel 15<br>address |

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

26.5.2 Registers Description

Refer to 27.5.2

# 26.6 Interface description

Table 26-1 USB HOST 2.0 Interface Description

| Module Pin    | Direction | Pad Name     | pinmux                     |
|---------------|-----------|--------------|----------------------------|
| HOST_VSSAC    | AG        | HOST_VSSAC   | -                          |
| HOST_DVSS     | DG        | HOST_DVSS    | -                          |
| HOST_DVDD     | DP        | HOST_DVDD    | -                          |
| HOST_VDD25    | AP        | HOST_VDD25   | -                          |
| HOST_DM       | Α         | HOST_DM      | -                          |
| HOST_RKELVIN  | Α         | HOST_RKELVIN | -                          |
| HOST_DP       | Α         | HOST_DP      | -                          |
| HOST_VSSA     | AG        | HOST_VSSA    | -                          |
| HOST_VBUS     | Α         | HOST_VBUS    | -                          |
| HOST_VDD33    | AP        | HOST_VDD33   | -                          |
| host_drv_vbus | 0         | GPIO0_A[6]   | GRF_GPIO0A_IOMUX<br>[12]=1 |

**Note**: **A**—Analog pad ; **AP**—Analog power; **AG**—Analog ground ;**DP**—Digital

power ; **DG**-Digital ground;

# Chapter 27 USB OTG2.0

## 27.1 Overview

USB OTG 2.0 is a Dual-Role Device controller, which supports both device andhost functions and is fully compliant with OTG Supplement to USB2.0 specification, and support

high-speed(480Mbps),full-speed(12Mbps),low-speed(1.5Mbps) transfer. USB OTG 2.0 isoptimized for portable electronic devices, point-to-point applications(no hub, directcoernnection to device) and multi-point applications to devices.USB OTG 2.0 interface supports both device and host functions and is fully compliant with OTG Supplement to USB2.0 specification, and support high-speed(480Mbps), full-speed(12Mbps), low-speed (1.5Mbps) transfer. It is optimized for portable electronic device, point-to-point applications (no hub, direct connection to device) and multi-point applications to devices.

#### 27.1.1 Features

- Compliant with the OTG Supplement to the USB2.0 Specification
- Operates in High-Speed and Full-Speed mode
- Support Session Request Protocol(SRP) and Host Negotiation Protocol(HNP)
- Support 9 channels in host mode
- 9 Device mode endpoints in addition to control endpoint 0, 4 in,3 out and 2 IN/OUT
- Built-in one 1024x35 bits FIFO
- Internal DMA with scatter/gather function
- Supports packet-based , synamic FIFO memory allocation for endpoints for flexible, efficient use of RAM
- Provides support to change an endpoint's FIFO memory size during transfers

# 27.2 Block Diagram



Fig. 27-1USB OTG 2.0 Architecture

Fig.27-1 shows the architecture of USB OTG 2.0. It is broken up into two separate units: USB OTG 2.0 controller and USB OTG 2.0 PHY. The two units are interconnected with UTMI interface.

### 27.2.1 USB OTG 2.0 Controller Function

The USB OTG 2.0 Controller controlsSIE(Serial Interface Engine) Logic , the



Endpointlogic, the Channel logic and the internal DMA logic.

The SIElogic contains the USB PID and address recognition logic, and other sequencing and state machine logic to handle USB packets and transactions. Generally the SIE Logicis required for any USB implementation while the number and types of endpoints will vary as function of application and performance requirements.

The Endpoint Logic contains the endpointspecific logic: endpoint number recognition, FIFOs and FIFO control, etc.

The Channel Logic contains the channel tasks schedule, FIFOs and FIFO control, etc.

The internal DMA logic controls data trasaction between system memory and USB FIFOs.

#### 27.2.2 USB OTG 2.0 PHY Function

The USB OTG 2.0 PHY handles the low level USB protocol and signaling. This includes features such as; dataserialization and deserialization, bit stuffing and clock recovery and synchronization. The primary focus ofthis block is to shift the clock domain of the data from the USB 2.0 rate to the frequency of UTMI clock which is 30MHz.

#### 27.2.3 UTMI Interface

#### Trasmit

Transmit must be asserted to enable any transmissions.

- 1) The USB OTG2.0 CONTROLLER asserts TXValid to begin a transmission and negates TXValid to end a transmission. After the USB OTG2.0 CONTROLLER asserts TXValid it can assume that the transmission has started when it detectsTXReady asserted.
- 2) The USB OTG2.0 CONTROLLER assumes that the USB OTG2.0 PHYhas consumed a data byte if TXReady and TXValid are asserted.
- 3) The USB OTG2.0 CONTROLLER must have valid packet information (PID) asserted on the DataIn bus coincident with theassertion of TXValid. Depending on the USB OTG2.0 PHYimplementation, TXReady may be asserted by the Transmit State Machine as soon as one CLK after the assertion of TXValid.
- 4) TXValid and TXReady are sampled on the rising edge of CLK.
- 5) The Transmit State Machine does NOT automatically generate Packet ID's (PIDs) or CRC. Whentransmitting, the USB OTG2.0 CONTROLLER is always expected to present a PID as the first byte of the data stream and ifappropriate, CRC as the last bytes of the data stream.
- The USB OTG2.0 CONTROLLER must use LineState to verify a Bus Idle condition before asserting TXValid in the TX Waitstate.
- 7) The state of TXReady in the TX Wait and Send SYNC states is undefined. An MTU implementationmay prepare for the next transmission immediately after the Send EOP state and assert TXReady inthe TX Wait state. An MTU implementation may also assert TXReady in the Send SYNC state. Thefirst assertion of TXReady is Macrocell implementation dependent. The USB OTG2.0 CONTROLLER must prepare DataIn forthe first byte to be transmitted before asserting TXValid.



Fig. 27-2 UTMI interface –Transmit timing for a data packet

- Receive
- 1) RXActive and RXValid are sampled on the rising edge of CLK.
- 2) In the RX Wait state the receiver is always looking for SYNC.
- 3) The USB OTG 2.0 PHY asserts RXActive when SYNC is detected (Strip SYNC state).
- 4) The USB OTG 2.0 PHY negates RXActive when an EOP is detected (Strip EOP state).
- 5) When RxActive is asserted, RXValid will be asserted if the RX Holding Register is full.
- 6) RXValid will be negated if the RX Holding Register was not loaded during the previous byte time.
- 7) This will occur if 8 stuffed bits have been accumulated.
- 8) The USB OTG2.0 Controller must be ready to consume a data byte if RXActive and RXValid are asserted (RX Data state).
- 9) In FS mode, if a bit stuff error is detected then the Receive State Machine will negate RXActive and
- 10) RXValid, and return to the RXWait state.



Fig. 27-3 UTMI interface – Receive timing for a data packet

## 27.3 USB OTG2.0 Controller

USB OTG Controller is a Dual-Role Device controller, which supports both device and host functions and is fully compliant with OTG Supplement to USB2.0 specification, and support high-speed(480Mbps), full-speed(12Mbps), low-speed (1.5Mbps) transfer. This controller will support UTMI+ Level 3 PHY interface. It connects to the industry-standard AMBA AHB for communication with the application and system memory. And it is optimized for portable

electronic device, point-to-point applications (no hub, direct connection to device) and multi-point applications to devices.

Fig. 27-2 shows the main components and flow of the USB OTG 2.0 controller system.



Fig. 27-4 USB OTG2.0 Controller Architecture

#### 27.3.1 Host Architercture

The host uses one transmit FIFO for all non-periodic OUT transactions and one transmit FIFO for all periodic OUT transactions (periodic FIFOs 2 to n are only used in Device mode, where n is number of periodic IN endpoints in Device mode). These transmit FIFOs are used as transmit buffers to hold the data (payload of the transmit packet) to be transmitted over USB. The host pipes the USB transactions through Request queues (one for periodic and one for non-periodic). Each entry in the Request queue holds the IN or OUT channel number along with other information to perform a transaction on the USB. The order in which the requests are written into the queue determines the sequence

of transactions on the USB. The host processes the periodic Request queue first, followed by the non-periodic Request queue, at the beginning of each (micro)frame. The host uses one receive FIFO for all periodic and non-periodic transactions. The FIFO is used as a receive buffer to hold the received data (payload of the received packet) from the USB until it is transferred to the system memory. The status of each packet received also goes into the FIFO. The status entry holds the IN channel number along with other information, such as received byte count and validity status, to perform a transaction on the AHB. Fig27-2 shows the bus interface architecture of the USB OTG 2.0Controller in Host mode.



Fig. 27-5 USB OTG2.0 Controller – Host Architecture



#### 27.3.2 Device Architercture

**Dedicated Transmit FIFO Operation** 

When dedicated transmit FIFO architecture is used (OTG\_EN\_DED\_TX\_FIFO = 1), the core uses individual transmit FIFOs for each IN endpoint. There are no Request queues associated with any of the FIFOs. There is no need for the application to predict the order in which the USB host is going to access the non-periodic endpoints. In Dedicated Transmit FIFO Operation, the core also supports thresholding in the transmit and receive directions when DMA mode is selected. For Transmit mode there are separate controls to enable thresholding for isochRnous and non-isochRnous transfers. When thresholding is enabled, the core can be configured to have less-than-one-packet-sized FIFO. The core internally handles underrun condition during transmit and corrupts the packet (inverts the CRC) on the USB. During receive with thresholding, when a packet ends up in a FIFO overflow condition, the core NAKs the OUT packet and internally rewinds the pointers. When thresholding is enabled, vendor recommends that you have a FIFO size two times the threshold value. If packet transmission results in underrun condition—(eventually resulting in packet corruption on the USB—often the host can time out the endpoint after three consecutive errors.

#### Single Receive FIFO

The OTG device uses a single receive FIFO to receive the data for all the OUT endpoints. The receive FIFO holds the status of the received data packet, such as byte count, data PID and the validity of the received data. The DMA or the application reads the data out of the receive FIFO as it is received.



Fig. 27-6 USB OTG2.0 Controller – Host Architecture

### 27.3.3 Internal DMA Mode

Internal DMA mode is typically selected when the CPU bandwidth to process the USB transfer is limited and you Wuld like an internal DMA controller to take care of the data transfers between the system memory and the USB OTG 2.0 Controller. The driver sets up the transfer and the USB OTG 2.0 Controller interrupts the processor only on transfer completion or an error condition





Fig. 27-7 USB OTG2.0 Controller - Internal DMA mode

### 27.3.4 FIFO Mapping

Fig.27-8 shows FIFO mapping in Host mode.

When the device is operating in Internal DMA mode, the last locations of the SPRAM are used to store the DMAADDR values for each channel.



Fig. 27-8 USB OTG 2.0 Controller host mode FIFO address mapping

Fig.27-9shows FIFO mapping in Device mode.

When the device is operating in non Descriptor Internal DMA mode, the last locations of the SPRAM are used to store the DMAADDR values for each channel. When the device is operating in Descriptor mode, then the last locations of the SPRAM store the Base Descriptor address, Current Descriptor address, Current Buffer address, and status quadlet information for each endpoint direction.





Fig. 27-9 USB OTG 2.0 Controller device mode FIFO address mapping

#### 27.3.5 Sub-Module Architecture

#### 1.DMA Scheduler (DSCH)

This block is used only in DMA mode. It controls the transfer of data packets between the system memory and the USB OTG 2.0 Controller for both Internal and External DMA. The following functions constitute the DMA scheduler:

#### Arbiter

This logic provides the sequence in which the channels/endpoints are to be processed in DMA mode. In Host mode, the arbiter provides Rund-Rbin arbitration among periodic and non-periodic channels. Periodic channels are processed with higher priority. In Device mode with Shared FIFO operation (OTG\_EN\_DED\_TX\_FIFO = 0), the arbiter provides a Rund-Rbin arbitration only among periodic endpoints. Arbitration for non-periodic endpoints is based on Next EP Number1 link register values. Periodic endpoints are processed with higher priority. In Device mode, during a Dedicated Transmit FIFO operation (OTG\_EN\_DED\_TX\_FIFO = 1), and when threshold is enabled, the priority is as follows:

- a) Any transmit endpoint which is active on the USB.
- b) Any receive data in a receive FIFO.
- Rund-Rbin arbitration on periodic transmit endpoints.
- Rund-Rbin arbitration on non-periodic transmit endpoints. In device mode when dedicated FIFO mode is used and when thresholding is not enabled, Rund Rbin arbitration is used for periodic and non-periodic IN endpoints with priority given to periodic IN endpoints.
- DMA Request State Machine The state machine is responsible for the following:



- Requesting the External/Internal DMA for data fetch (from system memory to transmit FIFO, one maximum packet size or last packet size at a time)
- Writing the OUT request token into the request queue at the end of data fetch, in host mode and in Device mode when  $OTG_EN_DED_TX_FIFO = 0.$
- Writing the IN request token into the Request Queue in Host mode
- Requesting the External/Internal DMA for data update (from receive FIFO to system memory, one maximum packet size or last packet size at a time)
- Writing the Request Queue for ping, complete split, zeR-length packet, or disable channel requests for the host.

## 2.Packet FIFO Controller (PFC)

Fig.27-10 represents the Packet FIFO Controller in Shared FIFO operation. Several FIFOs are used in Device and Host modes to store data inside the core before transmitting it on either the AHB or the USB.



Fig. 27-10 USB OTG 2.0 Controller Packet FIFO controller

PFC-to-SPRAM interface Fig.27-11 shows how to connect the USB OTG 2.0 Controller Data FIFO



interface to an industry-standard, single-port synchRnous SRAM. Address, write data, and control outputs are driven late by the USB OTG 2.0 Controller, but in time to meet the SRAM setup requirements. Input read data is expected late from the SSRAM and registered inside the core before being used.



Fig. 27-11 DFIFO single-port synchRnous SRAM interface

#### 3. Media Access Controller



Fig. 27-12 USB OTG 2.0 Controller – MAC block diagram

Fig 27-12 shows the major MAC module components. The major blocks are:

- Device Speed enumeration, Suspend, and Resume block (DSSR) The DSSR block is only active in Device mode. This block performs the speed enumeration, suspend, resume and remote wakeup functions in Device mode.
- Parallel Interface Engine (PIE) This block is responsible for token, data, and handshake packet generation and reception, and PID and CRC checking and generation. It generates handshake and data packets based on data



integrity and on CSR control and FIFO status information. The PIE also handles the data transfer to and from the FIFO, and the status update to the PFC and AIU.

- SOF tracker (SOFT) This block tracks SOF packets and generates SOF interrupts in Device mode. It handles missing SOFs and delayed SOFs to keep the frame number synchronization between the host and the device.
- Port (PRT) The Port block is only active in the Host mode. It is responsible for connect and disconnect detection, USB reset and speed enumeration, suspend and resume generation, remote wakeup detection, SOF generation, and High Speed Test mode handling, OTG Interface (OTGIF) The OTG Interface block handles SRP and HNP. These OTG protocols are implemented either through the regular UTMI+ interface
- UTMI+ PHY Interface (UPI) The block converts data widths for the 8-bit PHY interface and multiplexes output signals to the PHY from multiple blocks, It also implements some logic shared by multiple MAC blocks. The MAC is designed so that unused components can be removed in some configurations to reduce gate count. SOFT, DSSR, and OTGIF can be removed in a host-only configuration; PRT and OTGIF can be removed for device-only configuration.

# **27.4 USB OTG2.0 PHY**

The USB OTG 2.0 PHY connects a USB OTG controller to a USB system. It is a complete mixed-signal IP designed to implement OTG connectivity in a System-on-Chip(SOC) design targeted to a specific fabrication process using core and 2.5-V thick-oxide devices. The USB 2.0 PHY supports the USB2.0 480-Mbps protocol and data rate, and is backward compatible with the USB 1.1 1.5-Mbps and 12-Mbps protocol and data rates.

#### 27.4.1 Block Diagram

Fig. 27-13 shows the USB OTG 2.0 PHY functional block diagram for a one-port macro.





Fig. 27-13 USB OTG 2.0 PHY Architecture

The USB OTG 2.0 PHY consists of three basic components: the Common block, Transceiver block, and OTGblock.

- Common block: This block contains design components that can be reused for multiple transceivers.
- Transceiver block: This block contains the bulk of USB OTG 2.0 PHY circuitry for data processingand transfers.
- OTG block: This block enables A-devices and B-devices to initiate the Session Request Protocol(SRP), and dual-Role devices to initiate the Host Negotiation Protocol (HNP).

### 27.4.2 Powering Up and Powering Down



Fig. 27-14 USB OTG 2.0 PHY power supply and power up sequency

Table 27-1 USB OTG 2.0 PHY power supply timing parameter

| Timing    | Description                                                                                                                                                                             | value                                                                                                                                                                                    |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Parameter |                                                                                                                                                                                         |                                                                                                                                                                                          |
| T0        | Power-on reset (POR) is initiated                                                                                                                                                       | 0(reference)                                                                                                                                                                             |
| T1        | T1 indicates when POR can be set to $1\u2019b0$ . (To provide examples, values for T2 and T3 are also shown where T1 = T0 + 30 \u03bcs.) In general, T1 must be \u2265 T0 + 10 \u03bcs. | T0 + 10us <=T1                                                                                                                                                                           |
| T2        | T2 indicates which CLK12MOHCI is available at the macro output , based on the USB OTG 2.0 PHY reference clock source                                                                    | Orystal:T2 <t0+620us,<br>External board clock or<br/>CLKCORE: T2<t0+2us< td=""></t0+2us<></t0+620us,<br>                                                                                 |
| GUSBCFG   | T3 indicates when PHYCLOCK and CLK48MOHCI are available at the macro output, based on the USB OTG 2.0 PHY reference clock source                                                        | 1)Crystal: when T1=T0+10us, T3 <t1+805us 2)="" =="" =t0+835us="" board="" clkcore:when="" clock="" external="" or="" t0+815us,="" t1="T0+10us,T3&lt;T1+45us=&lt;/td" when=""></t1+805us> |



|  | T0+55us, when<br>T1=T0+30us,T3 <t1+45us=<br>T0+75us</t1+45us=<br> |
|--|-------------------------------------------------------------------|
|  |                                                                   |

# 27.4.3 Removing Power Supplies for Power Saving



Fig. 27-15 USB OTG 2.0 PHY removing power supplies

# 27.5 Register description

## 27.5.1 Register Summary

| Name             | Offset | Size | Reset<br>Value | Description                                            |
|------------------|--------|------|----------------|--------------------------------------------------------|
| USBOTG_GOTGCTL   | 0x0000 | W    | 0x00000000     | Control and Status<br>Register                         |
| USBOTG_GOTGINT   | 0x0004 | W    | 0x00000000     | Interrupt Register                                     |
| USBOTG_GAHBCFG   | 0x0008 | W    | 0×00000000     | AHB Configuration<br>Register                          |
| USBOTG_GUSBCFG   | 0x000c | W    | 0x00001400     | USB Configuration<br>Register                          |
| USBOTG_GRSTCTL   | 0x0010 | W    | 0x80000000     | Reset Register                                         |
| USBOTG_GINTSTS   | 0x0014 |      | 0x00000000     | Interrupt Register                                     |
| USBOTG_GINTMSK   | 0x0018 | W    | 0x00000000     | Interrupt Mask Register                                |
| USBOTG_GRXSTSR   | 0x001c | W    | 0×00000000     | Receive Status Debug<br>Read                           |
| USBOTG_GRXSTSP   | 0x0020 | W    | 0x00000000     | Receive Status Read and Pop                            |
| USBOTG_GRXFSIZ   | 0x0024 | W    | 0x00000000     | Receive FIFO Size<br>Register                          |
| USBOTG_GNPTXFSIZ | 0x0028 | W    | 0x00000000     | Non-Periodic Transmit<br>FIFO Size Register            |
| USBOTG_GNPTXSTS  | 0x002c | W    | 0×00000000     | Non-Periodic Transmit<br>FIFO/Queue Status<br>Register |
| USBOTG_GI2CCTL   | 0x0030 | W    | 0x11000000     | I2C Address Register                                   |
| USBOTG_GPVNDCTL  | 0x0034 | W    | 0×00000000     | PHY Vendor Control<br>Register                         |
| USBOTG_GGPIO     | 0x0038 | W    | 0×00000000     | General Purpost<br>Input/Output Register               |
| USBOTG_GUID      | 0x003c | W    | 0x0000000      | User ID Register                                       |
| USBOTG_GSNPSID   | 0x0040 | W    | 0x00004f54     | Core ID Register                                       |



| Name             | Offset | Size | Reset<br>Value | Description                                             |
|------------------|--------|------|----------------|---------------------------------------------------------|
| USBOTG_GHWCFG1   | 0x0044 | W    | 0x00000000     | User HW Config1<br>Register                             |
| USBOTG_GHWCFG2   | 0x0048 | W    | 0x00000000     | User HW Config2<br>Register                             |
| USBOTG_GHWCFG3   | 0x004c | W    | 0x00000000     | User HW Config3<br>Register                             |
| USBOTG_GHWCFG4   | 0x0050 | W    | 0x00000000     | User HW Config4<br>Register                             |
| USBOTG_GLPMCFG   | 0x0054 | W    | 0×00000000     | Core LPM Configuration Register                         |
| USBOTG_GPWRDN    | 0x0058 | W    | 0×00000000     | Global Power Down<br>Register                           |
| USBOTG_GDFIFOCFG | 0x005c | W    | 0×00000000     | Global DFIFO Software<br>Config Register                |
| USBOTG_GADPCTL   | 0x0060 | W    | 0×00000000     | ADP Timer,Control and Status Register                   |
| USBOTG_HPTXFSIZ  | 0x0100 | W    | 0×00000000     | Host Periodic Transmit<br>FIFO Size Register            |
| USBOTG_DIEPTXFn  | 0x0104 | W    | 0×00000000     | Device Periodic Transmit<br>FIFO-n Size Register        |
| USBOTG_HCFG      | 0x0400 | W    | 0x00000000     | Host Configuration<br>Register                          |
| USBOTG_HFIR      | 0x0404 | W    | 0x00000000     | Host Frame Interval<br>Register                         |
| USBOTG_HFNUM     | 0x0408 | W    | 0x0000ffff     | Host Frame<br>Number/Frame Time<br>Remaining Register   |
| USBOTG_HPTXSTS   | 0×0410 | W    | 0x00000000     | Host Periodic Transmit<br>FIFO/Queue Status<br>Register |
| USBOTG_HAINT     | 0x0414 | W    | 0x00000000     | Host All Channels<br>Interrupt Reigster                 |
| USBOTG_HAINTMSK  | 0x0418 | W    | 0x00000000     | Host All Channels<br>Interrupt Mask Register            |
| USBOTG_HPRT      | 0x0440 | W    | 0x00000000     | HostPort Control and<br>Status Register                 |
| USBOTG_HCCHARn   | 0x0500 | W    | 0x00000000     | Host Channel-n<br>Characteristics Register              |
| USBOTG_HCSPLTn   | 0x0504 | W    | 0x00000000     | Host Channel-n Split<br>Control Register                |
| USBOTG_HCINTn    | 0x0508 | W    | 0x00000000     | Host Channel-n<br>Interrupt Register                    |
| USBOTG_HCINTMSKn | 0x050c | W    | 0x00000000     | Host Channel-n<br>Interrupt Mask Register               |
| USBOTG_HCTSIZn   | 0x0510 | W    | 0×00000000     | Host Channel-n Transfer<br>Size Register                |
| USBOTG_HCDMAn    | 0x0514 | W    | 0×00000000     | Host Channel-n DMA<br>Address Register                  |
| USBOTG_HCDMABn   | 0x051c | W    | 0x00000000     | Host Channel-n DMA<br>Buffer Address Register           |



| Name                | Offset | Size | Reset<br>Value | Description                                            |
|---------------------|--------|------|----------------|--------------------------------------------------------|
| USBOTG_DCFG         | 0x0800 | W    | 0x08200000     | Device Cconfiguration<br>Register                      |
| USBOTG_DCTL         | 0x0804 | W    | 0x00002000     | Device Control Register                                |
| USBOTG_DSTS         | 0x0808 | W    |                | Device Status Register                                 |
| USBOTG_DIEPMSK      | 0x0810 | W    | 0×00000000     | Device IN Endpoint common interrupt mask register      |
| USBOTG_DOEPMSK      | 0x0814 | W    | 0×00000000     | Device OUT Endpoint common interrupt mask register     |
| USBOTG_DAINT        | 0x0818 | W    | 0x00000000     | Device All Endpoints interrupt register                |
| USBOTG_DAINTMSK     | 0x081c | W    | 0x00000000     | Device All Endpoint interrupt mask register            |
| USBOTG_DTKNQR1      | 0x0820 | W    | 0×00000000     | Device IN token sequence learning queue read register1 |
| USBOTG_DTKNQR2      | 0x0824 | W    | 0x00000000     | Device IN token sequence learning queue read register2 |
| USBOTG_DVBUSDIS     | 0x0828 | W    | 0x00000b8f     | Device VBUS discharge time register                    |
| USBOTG_DVBUSPULSE   | 0x082c | W    | 0x00000000     | Device VBUS Pulsing<br>Timer Register                  |
| USBOTG_DTHRCTL      | 0x0830 | w    | 0x08100020     | Device Threshold<br>Control Register                   |
| USBOTG_DIEPEMPMSK   | 0x0834 | W    | 0x00000000     | Device IN endpoint FIFO empty interrupt mask register  |
| USBOTG_DEACHINT     | 0x0838 | W    | 0×00000000     | Device each endpoint interrupt register                |
| USBOTG_DEACHINTMSK  | 0x083c | W    | 0x00000000     | Device each endpoint interrupt register mask           |
| USBOTG_DIEPEACHMSKn | 0x0840 | W    | 0x00000000     | Device each IN endpoint<br>-n interrupt Register       |
| USBOTG_DOEPEACHMSKr | 0x0880 | W    | 0x00000000     | Device each out<br>endpoint-n interrupt<br>register    |
| USBOTG_DIEPCTL0     | 0x0900 | W    | 0×00008000     | Device control IN endpoint 0 control register          |
| USBOTG_DIEPINTn     | 0x0908 | W    | 0x00000000     | Device Endpoint-n<br>Interrupt Register                |
| USBOTG_DIEPTSIZn    | 0x0910 | W    | 0x00000000     | Device endpoint n transfer size register               |
| USBOTG_DIEPDMAn     | 0x0914 | W    | 0x00000000     | Device endpoint-n DMA address register                 |
| USBOTG_DTXFSTSn     | 0x0918 | W    | 0x00000000     | Device IN endpoint<br>transmit FIFO status<br>register |



| Name             | Offset | Size | Reset<br>Value | Description                                    |
|------------------|--------|------|----------------|------------------------------------------------|
| USBOTG_DIEPDMABn | 0x091c | W    | 0x00000000     | Device endpoint-n DMA buffer address register  |
| USBOTG_DIEPCTLn  | 0x0920 | W    | 0×00000000     | Device endpoint-n control register             |
| USBOTG_DOEPCTL0  | 0x0b00 | W    | 0×00000000     | Device control OUT endpoint 0 control register |
| USBOTG_DOEPINTn  | 0x0b08 | W    | 0x00000000     | Device endpoint-n control register             |
| USBOTG_DOEPTSIZn | 0x0b10 | W    | 0x00000000     | Device endpoint n transfer size register       |
| USBOTG_DOEPDMAn  | 0x0b14 | W    | 0x00000000     | Device Endpoint-n DMA<br>Address Register      |
| USBOTG_DOEPDMABn | 0x0b1c | W    | 0x00000000     | Device endpoint-n DMA buffer address register  |
| USBOTG_DOEPCTLn  | 0x0b20 | W    | 0×00000000     | Device endpoint-n control register             |
| USBOTG_PCGCR     | 0x0b24 | W    | 0x200b8000     | Power and clock gating control register        |
| USBOTG_EPBUF0    | 0x1000 | W    | 0x00000000     | Device endpoint 0 / host out channel 0 address |
| USBOTG_EPBUF1    | 0x2000 | W    | 0x00000000     | Device endpoint 1 / host out channel 1 address |
| USBOTG_EPBUF2    | 0x3000 | W    | 0×00000000     | Device endpoint 2 / host out channel 2 address |
| USBOTG_EPBUF3    | 0x4000 | W)   | 0x00000000     | Device endpoint 3 / host out channel 3 address |
| USBOTG_EPBUF4    | 0x5000 | W    | 0x00000000     | Device endpoint 4 / host out channel 4 address |
| USBOTG_EPBUF5    | 0x6000 | W    | 0×00000000     | Device endpoint 5 / host out channel 5 address |
| USBOTG_EPBUF6    | 0x7000 | W    | 0x00000000     | Device endpoint 6 / host out channel 6 address |
| USBOTG_EPBUF7    | 0x8000 | W    | 0×00000000     | Device endpoint 7 / host out channel 7 address |

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

# 27.5.2 Detail Register Description

# **USBOTG\_GOTGCTL**

Address: Operational Base + offset (0x0000)

Control and Status Register

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



1. The vbus assigns the values internally for

non-SRP or non-HNP configurations.



| Bit      | Attr | Reset Value | Description                                        |
|----------|------|-------------|----------------------------------------------------|
|          |      |             | ASesVld                                            |
|          |      |             | A-session valid                                    |
|          |      |             | Indicates the Host mode transceiver status.        |
|          |      |             | 0: A-session is not valid                          |
| 18       | RO   | 0x0         | 1: A-session is valid                              |
|          |      |             | Note: If you do not enabled OTG features (such     |
|          |      |             | as SRP and HNP), the read reset value will be      |
|          |      |             | 1.The vbus assigns the values internally for       |
|          |      |             | non-SRP or non-HNP configurations.                 |
|          |      |             | DbnTime                                            |
|          |      |             | Long/short debounce time                           |
|          |      |             | Indicates the debounce time of a detected          |
| 17       | RO   | 0x0         | connection.                                        |
| 17       | RO   | UXU         | 0: Long debounce time, used for physical           |
|          |      |             | connections (100 ms + 2.5 us)                      |
|          |      |             | 1: Short debounce time, used for soft              |
|          |      |             | connections (2.5 us)                               |
|          |      |             | ConIDSts                                           |
|          |      |             | Connector ID Status                                |
| 16       | RO   | 0x0         | Indicates the connector ID status on a connect     |
|          |      | 0.00        | event.                                             |
|          |      |             | 0: The core is in A-Device mode                    |
|          |      |             | 1: The core is in B-Device mode                    |
| 15:12    | RO   | 0x0         | reserved                                           |
|          |      | • 1         | DevHNPEn                                           |
|          |      |             | Device HNP Enable                                  |
|          |      |             | The application sets this bit when it successfully |
| 11       | RW   | 0x0         | receives a SetFeature. SetHNPEnable command        |
|          | 1    |             | from the connected USB host.                       |
|          |      | ·           | 0: HNP is not enabled in the application           |
|          |      |             | 1: HNP is enabled in the application               |
|          |      |             | HstSetHNPEn                                        |
|          | V    |             | Host set HNP enable                                |
| <b>Y</b> |      |             | The application sets this bit when it has          |
| 10       | RW   | 0×0         | successfully enabled HNP (using the                |
|          |      |             | SetFeature.SetHNPEnable command) on the            |
|          |      |             | connected device.                                  |
|          |      |             | 0: Host Set HNP is not enabled                     |
|          |      |             | 1: Host Set HNP is enabled                         |



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9   | RW   | 0x0         | HNPReq HNP request The application sets this bit to initiate an HNP request to the connected USB host. The application can clear this bit by writing a 0 when the Host Negotiation Success Status Change bit in the OTG Interrupt register (GOTGINT.HstNegSucStsChng) is set. The core clears this bit when the HstNegSucStsChng bit is cleared. 0: No HNP request 1: HNP request HstNegScs                                                                                                                                                                                                                                                                                                                       |
| 8   | RO   | 0×0         | Host Negotiation Success The core sets this bit when host negotiation is successful. The core clears this bit when the HNP Request (HNPReq) bit in this register is set.  0: Host negotiation failure 1: Host negotiation success                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7:2 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1   | RW   | 0×0         | Session Request The application sets this bit to initiate a session request on the USB. The application can clear this bit by writing a 0 when the Host Negotiation Success Status Change bit in the OTG Interrupt register (GOTGINT.HstNegSucStsChng) is set. The core clears this bit when the HstNegSucStsChng bit is cleared. If you use the USB 1.1 Full-Speed Serial Transceiver interface to initiate the session request, the application must wait until the VBUS discharges to 0.2 V, after the B-Session Valid bit in this register (GOTGCTL.BSesVld) is cleared. This discharge time varies between different PHYs and can be obtained from the PHY vendor.  0: No session request 1: Session request |



| Bit | Attr | Reset Value             | Description                                   |
|-----|------|-------------------------|-----------------------------------------------|
|     |      |                         | SesReqScs                                     |
|     |      | Session Request Success |                                               |
|     | 0 RO | 0x0                     | The core sets this bit when a session request |
| U   |      |                         | initiation is successful.                     |
|     |      |                         | 0: Session request failure                    |
|     |      |                         | 1: Session request success                    |

# USBOTG\_GOTGINT

Address: Operational Base + offset (0x0004)

Interrupt Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                     |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:21 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                        |
| 20    | W1C  | 0×0         | MultiValueChg Multi-Valued input changed This bit when set indicates that there is a change in the value of at least one ACA pin value. This bit is present only if OTG_BC_SUPPORT = 1, otherwise it is reserved.                                                                                                                               |
| 19    | W1C  | 0×0         | DbnceDone Debounce Done The core sets this bit when the debounce is completed after the device connect. The application can start driving USB reset after seeing this interrupt. This bit is only valid when the HNP Capable or SRP Capable bit is set in the Core USB Configuration register (GUSBCFG.HNPCap or GUSBCFG.SRPCap, respectively). |
| 18    | W1C  | 0×0         | ADevTOUTChg A-Device Timeout Change The core sets this bit to indicate that the A-device has timed out while waiting for the B-device to connect.                                                                                                                                                                                               |
| 17    | W1C  | 0×0         | HstNegDet Host Negotiation Detected The core sets this bit when it detects a host negotiation request on the USB                                                                                                                                                                                                                                |
| 16:10 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                        |



| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                       |
|-----|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9   | W1C  | 0×0                | HstNegSucStsChng Host Negotiation Success Status Change The core sets this bit on the success or failure of a USB host negotiation request. The application must read the Host Negotiation Success bit of the OTG Control and Status register (GOTGCTL.HstNegScs) to check for success or failure |
| 8   | W1C  | 0×0                | SesReqSucStsChng Session Request Success Status Change The core sets this bit on the success or failure of a session request. The application must read the Session Request Success bit in the OTG Control and Status register (GOTGCTL.SesReqScs) to check for success or failure.               |
| 7:3 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                          |
| 2   | W1C  | 0×0                | SesEndDet Session End Detected The core sets this bit when the utmisrp_bvalid signal is deasserted                                                                                                                                                                                                |
| 1:0 | RO   | 0×0                | reserved                                                                                                                                                                                                                                                                                          |

# **USBOTG\_GAHBCFG**

Address: Operational Base + offset (0x0008)

AHB Configuration Register

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



| Bit           | Attr | Reset Value      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------------|------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b> 22 | RW   | Reset Value  0x0 | NotiAllDmaWrit Notify All Dma Write Transactions This bit is programmed to enable the System DMA Done functionality for all the DMA write Transactions corresponding to the Channel/Endpoint. This bit is valid only when GAHBCFG.RemMemSupp is set to 1. GAHBCFG.NotiAllDmaWrit = 1. HSOTG core asserts int_dma_req for all the DMA write transactions on the AHB interface along with int_dma_done, chep_last_transact and chep_number signal informations. The core waits for sys_dma_done signal for all the DMA write transactions in order to complete the transfer of a particular Channel/Endpoint. GAHBCFG.NotiAllDmaWrit = 0. HSOTG core asserts int_dma_req signal only for the last transaction of DMA write transfer corresponding to a particular |
|               |      |                  | corresponding to a particular Channel/Endpoint. Similarly, the core waits for sys_dma_done signal only for that transaction of DMA write to complete the transfer of a particular Channel/Endpoint.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

Rockenin



| Bit  | Attr | Reset Value | Description                                     |
|------|------|-------------|-------------------------------------------------|
|      |      |             | RemMemSupp                                      |
|      |      |             | Remote Memory Support                           |
|      |      |             | This bit is programmed to enable the            |
|      |      |             | functionality to wait for the system DMA Done   |
|      |      |             | Signal for the DMA Write Transfers.             |
|      |      |             | GAHBCFG.RemMemSupp=1.                           |
|      |      |             | The int_dma_req output signal is asserted       |
|      |      |             | when HSOTG DMA starts write transfer to the     |
|      |      |             | external memory. When the core is done with     |
|      |      |             | the Transfers it asserts int_dma_done signal to |
|      |      |             | flag the completion of DMA writes from HSOTG.   |
| 21   | RW   | 0x0         | The core then waits for sys_dma_done signal     |
|      |      |             | from the system to proceed further and          |
|      |      |             | complete the Data Transfer corresponding to a   |
|      |      |             | particular Channel/Endpoint.                    |
|      |      |             | GAHBCFG.RemMemSupp=0.                           |
|      |      |             | The int_dma_req and int_dma_done signals        |
|      |      |             | are not asserted and the core proceeds with the |
|      |      |             | assertion of the XferComp interrupt as soon as  |
|      |      |             | the DMA write transfer is done at the HSOTG     |
|      |      |             | Core Boundary and it does not wait for the      |
|      |      |             | sys_dma_done signal to complete the DATA        |
|      |      |             | transfers.                                      |
| 20:9 | RO   | 0x0         | reserved                                        |
|      |      |             | PTxFEmpLvl                                      |
|      |      | 1,5         | Periodic TxFIFO Empty Level                     |
|      |      |             | Indicates when the Periodic TxFIFO Empty        |
|      |      |             | Interrupt bit in the Core Interrupt register    |
| 8    | RW   | 0×0         | (GINTSTS.PTxFEmp) is triggered. This bit is     |
|      |      | 7           | used only in Slave mode.                        |
|      |      |             | 0: GINTSTS.PTxFEmp interrupt indicates that     |
|      |      |             | the Periodic TxFIFO is half empty               |
|      |      |             | 1: GINTSTS.PTxFEmp interrupt indicates that     |
|      |      |             | the Periodic TxFIFO is completely empty         |



| Bit | Attr | Reset Value | Description                                                                   |
|-----|------|-------------|-------------------------------------------------------------------------------|
|     |      |             | NPTxFEmpLvI                                                                   |
|     |      |             | Non-Periodic TxFIFO Empty Level                                               |
|     |      |             | This bit is used only in Slave mode. In host                                  |
|     |      |             | mode and with Shared FIFO with device mode,                                   |
|     |      |             | this bit indicates when the Non-Periodic TxFIFO                               |
|     |      |             | Empty Interrupt bit in the Core Interrupt                                     |
|     |      |             | register GINTSTS.NPTxFEmp) is triggered.                                      |
|     |      |             | With dedicated FIFO in device mode, this bit                                  |
|     |      |             | indicates when IN endpoint Transmit FIFO                                      |
|     |      |             | empty interrupt (DIEPINTn.TxFEmp) is                                          |
|     |      |             | triggered.                                                                    |
| 7   | RW   | 0x0         | Host mode and with Shared FIFO with device                                    |
|     |      | 0.00        | mode:                                                                         |
|     |      |             | 1'b0: GINTSTS.NPTxFEmp interrupt indicates                                    |
|     |      |             | that the Non-Periodic TxFIFO is half empty                                    |
|     |      |             | 1'b1: GINTSTS.NPTxFEmp interrupt indicates                                    |
|     |      |             | that the Non-Periodic TxFIFO is completely                                    |
|     |      |             | empty                                                                         |
|     |      |             | Dedicated FIFO in device mode:                                                |
|     |      |             | 1'b0: DIEPINTn.TxFEmp interrupt indicates                                     |
|     |      |             | that the IN Endpoint TxFIFO is half empty                                     |
|     |      |             | 1'b1: DIEPINTn.TxFEmp interrupt indicates                                     |
|     |      |             | that the IN Endpoint TxFIFO is completely                                     |
|     |      |             | empty                                                                         |
| 6   | RO   | 0x0         | reserved                                                                      |
|     |      | 0x0         | DMAEn                                                                         |
|     |      |             | DMA Enable                                                                    |
| 5   | RW   |             | 0: Core operates in Slave mode                                                |
|     |      |             | 1: Core operates in a DMA mode  This bit is always 0 when Slave-Only mode has |
|     |      | 7           | This bit is always 0 when Slave-Only mode has been selected.                  |
|     |      | 1           | peen selected.                                                                |



| Bit | Attr | Reset Value | Description                                       |
|-----|------|-------------|---------------------------------------------------|
|     |      |             | HBstLen                                           |
|     |      |             | Burst Length/Type                                 |
|     |      |             | This field is used in both External and Internal  |
|     |      |             | DMA modes. In External DMA mode, these bits       |
|     |      |             | appear on dma_burst[3:0] ports, External DMA      |
|     |      |             | Mode defines the DMA burst length in terms of     |
|     |      |             | 32-bit words:                                     |
|     |      |             | 4'b0000: 1 word                                   |
|     |      |             | 4'b0001: 4 words                                  |
|     |      |             | 4'b0010: 8 words                                  |
|     |      |             | 4'b0011: 16 words                                 |
| 4:1 | RW   | 0x0         | 4'b0100: 32 words                                 |
|     |      |             | 4'b0101: 64 words                                 |
|     |      |             | 4'b0110: 128 words                                |
|     |      |             | 4'b0111: 256 words                                |
|     |      |             | Others: Reserved                                  |
|     |      |             | Internal DMA Mode AHB Master burst type:          |
|     |      |             | 4'b0000: Single                                   |
|     |      |             | 4'b0001: INCR                                     |
|     |      |             | 4'b0011: INCR4                                    |
|     |      |             | 4'b0101: INCR8                                    |
|     |      |             | 4'b0111: INCR16                                   |
|     |      |             | Others: Reserved                                  |
|     |      |             | GlblIntrMsk                                       |
|     |      | . (         | Global Interrupt Mask                             |
|     |      |             | The application uses this bit to mask or unmask   |
|     |      |             | the interrupt line assertion to itself.           |
| 0   | RW   | 0×0         | Irrespective of this bit's setting, the interrupt |
|     | 11   |             | status registers are updated by the core.         |
|     |      | 7           | 1'b0: Mask the interrupt assertion to the         |
|     |      |             | application.                                      |
|     |      |             | 1'b1: Unmask the interrupt assertion to the       |
|     |      |             | application.                                      |

# USBOTG\_GUSBCFG

Address: Operational Base + offset (0x000c)

**USB** Configuration Register

| Bit | Attr | <b>Reset Value</b> | Description                                    |
|-----|------|--------------------|------------------------------------------------|
| 31  | RW   | 0x0                | CorruptTxpacket                                |
|     |      |                    | Corrupt Tx packet                              |
|     |      |                    | This bit is for debug purposes only. Never set |
|     |      |                    | this bit to 1.                                 |



| Bit | Attr | Reset Value | Description                                         |
|-----|------|-------------|-----------------------------------------------------|
|     | RW   | 0×0         | ForceDevMode                                        |
|     |      |             | Force Device Mode                                   |
| 30  |      |             | Writing a 1 to this bit forces the core to device   |
|     |      |             | mode irrespective of utmiotg_iddig input pin.       |
|     |      |             | 1'b0: Normal Mode                                   |
|     |      |             | 1'b1: Force Device Mode                             |
|     |      |             | After setting the force bit, the application must   |
|     |      |             | wait at least 25 ms before the change to take       |
|     |      |             | effect. When the simulation is in scale down        |
|     |      |             | mode, waiting for 500 us is sufficient. This bit is |
|     |      |             | valid only when OTG $\_$ MODE = 0, 1 or 2. In all   |
|     |      |             | other cases, this bit reads 0.                      |
|     | RW   | 0×0         | ForceHstMode                                        |
|     |      |             | Force Host Mode                                     |
|     |      |             | Writing a 1 to this bit forces the core to host     |
|     |      |             | mode irrespective of utmiotg_iddig input pin.       |
|     |      |             | 1'b0: Normal Mode                                   |
| 29  |      |             | 1'b1: Force Host Mode                               |
|     |      |             | After setting the force bit, the application must   |
|     |      |             | wait at least 25 ms before the change to take       |
|     |      |             | effect. When the simulation is in scale down        |
|     |      |             | mode, waiting for 500 us is sufficient. This bit is |
|     |      |             | valid only when OTG_MODE =0, 1 or 2. In             |
|     |      |             | allother cases, this bit reads 0.                   |
| 28  | RW   | 0x0         | TxEndDelay                                          |
|     |      |             | Tx End Delay                                        |
|     |      |             | Writing a 1 to this bit enables the TxEndDelay      |
|     |      |             | timers in the core.                                 |
|     |      |             | 1'b0: Normal mode                                   |
|     |      |             | 1'b1: Introduce Tx end delay timers                 |
| 27  | RW   | 0×0         | IC_USBTrafCtl                                       |
|     |      |             | IC_USB TrafficPullRemove Control                    |
|     |      |             | When this bit is set, pullup/pulldown resistors     |
|     |      |             | are detached from the USB during traffic            |
|     |      |             | signaling.This bit is valid only when               |
|     |      |             | configuration parameter OTG_ENABLE_IC_USB           |
|     |      |             | = 1 and register field GUSBCFG.IC_USBCap is         |
|     |      |             | set to 1.                                           |



| the            |
|----------------|
| the            |
| the            |
|                |
|                |
| cted.          |
| l.             |
|                |
|                |
| value          |
| er             |
| N Y            |
| r cases,       |
| d only.        |
|                |
|                |
|                |
| link           |
| r              |
| an be          |
| ification      |
|                |
| cuit           |
| cuit           |
|                |
|                |
| ut is          |
| ous State      |
| ous State<br>I |
| 1              |
| alified        |
| r.             |
| qualified      |
| r.             |
|                |



| Bit | Attr | Reset Value | Description                                    |
|-----|------|-------------|------------------------------------------------|
|     |      |             | IndComple                                      |
|     |      |             | Indicator Complement                           |
|     |      |             | Controls the PHY to invert the                 |
|     |      |             | ExternalVbusIndicator input signal,generating  |
| 23  | RW   | 0x0         | the Complement Output. Please refer to the     |
| 23  | KVV  | UXU         | ULPI Specification for more detail             |
|     |      |             | 1'b0: PHY does not invert                      |
|     |      |             | ExternalVbusIndicator signal                   |
|     |      |             | 1'b1: PHY does invert ExternalVbusIndicator    |
|     |      |             | signal                                         |
|     |      |             | TermSelDLPulse                                 |
|     |      |             | TermSel DLine Pulsing Selection                |
|     |      |             | This bit selects utmi_termselect to drive data |
| 22  | RW   | 0x0         | line pulse during SRP.                         |
|     |      |             | 1'b0: Data line pulsing using utmi_txvalid     |
|     |      |             | (default).                                     |
|     |      |             | 1'b1: Data line pulsing using utmi_termsel.    |
|     |      |             | ULPIExtVbusIndicator                           |
|     |      |             | ULPI External VBUS Indicator                   |
|     |      |             | This bit indicates to the ULPI PHY to use an   |
|     |      |             | external VBUS over-current indicator.          |
| 21  | RW   | 0x0         | 1'b0: PHY uses internal VBUS valid comparator. |
|     |      |             | 1'b1: PHY uses external VBUS valid             |
|     |      |             | comparator.                                    |
|     |      | . (         | (Valid only when RTL parameter                 |
|     |      |             | OTG_HSPHY_INTERFACE = 2 or 3)                  |
|     |      |             | ULPIExtVbusDrv                                 |
|     |      |             | ULPI External VBUS Drive                       |
|     | 1    |             | This bit selects between internal or external  |
|     |      | 7           | supply to drive 5V on VBUS,in ULPI PHY.        |
| 20  | RW   | 0x0         | 1'b0: PHY drives VBUS using internal charge    |
|     |      |             | pump (default).                                |
|     |      |             | 1'b1: PHY drives VBUS using external supply.   |
| 7   |      |             | (Valid only when RTL parameter                 |
|     |      |             | OTG_HSPHY_INTERFACE = 2 or 3)                  |



| Bit           | Attr | Reset Value      | Description                                                                                                                                                                                                                                                                                                                                                  |
|---------------|------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b> 19 | RW   | Reset Value  0x0 | ULPICIkSusM ULPI Clock SuspendM This bit sets the ClockSuspendM bit in the Interface Control register on the ULPI PHY. This bit applies only in serial or carkit modes. 1'b0: PHY powers down internal clock during suspend.                                                                                                                                 |
|               |      |                  | 1'b1: PHY does not power down internal clock. (Valid only when RTL parameter OTG_HSPHY_INTERFACE = 2 or 3)                                                                                                                                                                                                                                                   |
| 18            | RW   | 0×0              | ULPIAutoRes ULPI Auto Resume This bit sets the AutoResume bit in the Interface Control register on the ULPI PHY. 1'b0: PHY does not use AutoResume feature. 1'b1: PHY uses AutoResume feature. (Valid only when RTL parameter OTG_HSPHY_INTERFACE = 2 or 3)                                                                                                  |
| 17            | RW   | 0×0              | ULPIFsLs ULPI FS/LS Select The application uses this bit to select the FS/LS serial interface for the ULPI PHY. This bit is valid only when the FS serial transceiver is selected on the ULPI PHY. 1'b0: ULPI interface 1'b1: ULPI FS/LS serial interface (Valid only when RTL parameters OTG_HSPHY_INTERFACE = 2 or 3 and OTG_FSPHY_INTERFACE = 1, 2, or 3) |
| 16            | RW   | 0×0              | OtgI2CSel UTMIFS or I2C Interface Select The application uses this bit to select the I2C interface. 1'b0: UTMI USB 1.1 Full-Speed interface for OTG signals 1'b1: I2C interface for OTG signals This bit is writable only if I2C and UTMIFS were specified for Enable I2C Interface? (parameter OTG_I2C_INTERFACE = 2). Otherwise, reads return 0.           |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15    | RW   | 0×0         | PhyLPwrClkSel PHY Low-Power Clock Select Selects either 480-MHz or 48-MHz (low-power) PHY mode. In FS and LS modes, the PHY can usually operate on a 48-MHz clock to save power. 1'b0: 480-MHz Internal PLL clock 1'b1: 48-MHz External Clock In 480 MHz mode, the UTMI interface operates at either 60 or 30-MHz, depending upon whether 8- or 16-bit data width is selected. In 48-MHz mode, the UTMI interface operates at 48 MHz in FS and LS modes. This bit drives the utmi_fsls_low_power core output signal, and is valid only for UTMI+ PHYs.                                                                                   |
| 14    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 13:10 | RW   | 0x5         | USBTrdTim USB Turnaround Time Sets the turnaround time in PHY clocks. Specifies the response time for a MAC request to the Packet FIFO Controller (PFC) to fetch data from the DFIF(SPRAM). This must be programmed to 4'h5: When the MAC interface is 16-bit UTMI+. 4'h9: When the MAC interface is 8-bit UTMI+. Note: The values above are calculated for the minimum AHB frequency of 30 MHz. USB turnaround time is critical for certification where long cables and 5-Hubs are used, so if you need the AHB to run at less than 30 MHz, and if USB turnaround time is not critical, these bits can be programmed to a larger value. |
| 9     | RW   | 0×0         | HNPCap HNP-Capable The application uses this bit to control the otg core's HNP capabilities. 0: HNP capability is not enabled. 1: HNP capability is enabled. This bit is writable only if an HNP mode was specified for Mode of Operation (parameter OTG_MODE). Otherwise, reads return 0.                                                                                                                                                                                                                                                                                                                                               |



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8   | RW   | 0×0         | SRPCap SRP-Capable The application uses this bit to control the otg core SRP capabilities. If the core operates as a non-SRP-capable B-device, it cannot request the connected A-device (host) to activate VBUS and start a session. 0: SRP capability is not enabled. 1: SRP capability is enabled. This bit is writable only if an SRP mode was specified for Mode of Operation (parameter OTG_MODE). Otherwise, reads return 0.                                                                                                                                                                                                                                                                                                       |
| 7   | RW   | 0×0         | DDRSel ULPI DDR Select The application uses this bit to select a Single Data Rate (SDR) or Double Data Rate (DDR) or ULPI interface. 0: Single Data Rate ULPI Interface, with 8-bit-wide data bus 1: Double Data Rate ULPI Interface, with 4-bit-wide data bus                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 6   | RW   | 0×0         | PHYSel USB 2.0 High-Speed PHY or USB 1.1 Full-Speed Serial Transceiver The application uses this bit to select either a high-speed UTMI+ or ULPI PHY, or a full-speed transceiver. 0: USB 2.0 high-speed UTMI+ or ULPI PHY 1: USB 1.1 full-speed serial transceiver If a USB 1.1 Full-Speed Serial Transceiver interface was not selected (parameter OTG_FSPHY_INTERFACE = 0), this bit is always 0, with Write Only access. If a high-speed PHY interface was not selected (parameter OTG_HSPHY_INTERFACE = 0), this bit is always 1, with Write Only access. If both interface types were selected (parameters have non-zero values), the application uses this bit to select which interface is active, and access is Read and Write. |



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5   | RW   | 0×0         | FSIntf Full-Speed Serial Interface Select The application uses this bit to select either a unidirectional or bidirectional USB 1.1 full-speed serial transceiver interface.  0: 6-pin unidirectional full-speed serial interface 1: 3-pin bidirectional full-speed serial interface If a USB 1.1 Full-Speed Serial Transceiver interface was not selected (parameter OTG_FSPHY_INTERFACE = 0), this bit is always 0, with Write Only access. If a USB 1.1 FS interface was selected (parameter OTG_FSPHY_INTERFACE! = 0), then the application can set this bit to select between the 3- and 6-pin interfaces, and access is Read and Write. |
| 4   | RW   | 0×0         | ULPI_UTMI_Sel ULPI or UTMI+ Select The application uses this bit to select either a UTMI+ interface or ULPI Interface. 0: UTMI+ Interface 1: ULPI Interface This bit is writable only if UTMI+ and ULPI was specified for High-Speed PHY Interface(s) (parameter OTG_HSPHY_INTERFACE = 3). Otherwise, reads return either 0 or 1, depending on the interface selected using the OTG_HSPHY_INTERFACE parameter.                                                                                                                                                                                                                               |
| 3   | RW   | 0×0         | PHYIf PHY Interface The application uses this bit to configure the core to support a UTMI+ PHY with an 8- or 16-bit interface. When a ULPI PHY is chosen, this must be set to 8-bit mode.  0: 8 bits 1: 16 bits This bit is writable only if UTMI+ and ULPI were selected (parameter OTG_HSPHY_DWIDTH = 3). Otherwise, this bit returns the value for the power-on interface selected during configuration.                                                                                                                                                                                                                                  |



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0 | RW   | 0×0         | TOutCal HS/FS Timeout Calibration The number of PHY clocks that the application programs in this field is added to the high-speed/full-speed interpacket timeout duration in the core to account for any additional delays introduced by the PHY. This can be required, because the delay introduced by the PHY in generating the line state condition can vary from one PHY to another. The USB standard timeout value for high-speed operation is 736 to 816 (inclusive) bit times. The USB standard timeout value for full-speed operation is 16 to 18 (inclusive) bit times. The application must program this field based on the speed of enumeration. The number of bit times added per PHY clock are: High-speed operation: One 30-MHz PHY clock = 16 bit times One 60-MHz PHY clock = 0.4 bit times Full-speed operation: One 30-MHz PHY clock = 0.2 bit times One 48-MHz PHY clock = 0.25 bit times |

#### USBOTG\_GRSTCTL

Address: Operational Base + offset (0x0010)

Reset Register

| Bit   | Attr | <b>Reset Value</b> | Description                                    |                                                |
|-------|------|--------------------|------------------------------------------------|------------------------------------------------|
|       |      | 7                  | AHBIdle                                        |                                                |
| 31    | DO.  | RO 0x1             | AHB Master Idle                                |                                                |
| 31    | KO   |                    | Indicates that the AHB Master State Machine is |                                                |
|       |      |                    | in the IDLE condition.                         |                                                |
|       | RO   | <b>Y</b>           |                                                | DMAReq                                         |
| 30    |      | 0.40               | DMA Request Signal                             |                                                |
| 30    |      | RO 0x0             | UXU                                            | Indicates that the DMA request is in progress. |
|       |      |                    | Used for debug.                                |                                                |
| 29:11 | RO   | 0x0                | reserved                                       |                                                |

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:6 | RW   | 0×00        | TxFIvo Number This is the FIFO number that must be flushed using the TxFIFO Flush bit. This field must not be changed until the core clears the TxFIFO Flush bit. 5'h0: Non-periodic TxFIFO flush in Host mode; Non-periodic TxFIFO flush in device mode when in shared FIFO operation. Tx FIFO 0 flush in device mode when in dedicated FIFO mode. 5'h1: Periodic TxFIFO flush in Host mode: Periodic TxFIFO 1 flush in Device mode when in shared FIFO operation; TXFIFO 1 flush in device mode when in dedicated FIFO mode. 5'h2: Periodic TxFIFO 2 flush in Device mode when in shared FIFO operation: TXFIFO 2 flush in device mode when in dedicated FIFO mode 5'hF: Periodic TxFIFO 15 flush in Device mode when in shared FIFO operation: TXFIFO 15 flush in device mode when in dedicated FIFO mode. 5'h10: Flush all the transmit FIFOs in device or host mode. |



| Bit | Attr  | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|-------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |       |             | TxFFlsh<br>TxFIFO Flush                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 5   | R/WSC | 0×0         | This bit selectively flushes a single or all transmit FIFOs, but cannot do so if the core is in the midst of a transaction. The application must write this bit only after checking that the core is neither writing to the TxFIFO nor reading from the TxFIFO. Verify using these registers: Read NAK Effective Interrupt ensures the core is not reading from the FIFO. Write GRSTCTL.AHBIdle ensures the core is not writing anything to the FIFO. Flushing is normally recommended when FIFOs are re-configured or when switching between Shared FIFO and Dedicated Transmit FIFO operation. FIFO flushing is also recommended during device endpoint disable. The application must wait until the core clears this bit before performing any operations. This bit takes eight clocks to clear, using the slower clock of |
| 4   | R/WSC | 0×0         | phy_clk or hclk.  RxFIsh RxFIFO Flush The application can flush the entire RxFIFO using this bit, but must first ensure that the core is not in the middle of a transaction. The application must only write to this bit after checking that the core is neither reading from the RxFIFO nor writing to the RxFIFO. The application must wait until the bit is cleared before performing any other operations. This bit requires 8 clocks (slowest of PHY or AHB clock) to clear.                                                                                                                                                                                                                                                                                                                                             |
| 3   | R/WSC | 0×0         | INTknQFlsh IN Token Sequence Learning Queue Flush This bit is valid only if OTG_EN_DED_TX_FIFO = 0. The application writes this bit to flush the IN Token Sequence Learning Queue.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

| Bit | Attr  | <b>Reset Value</b> | Description                                    |
|-----|-------|--------------------|------------------------------------------------|
|     |       |                    | FrmCntrRst                                     |
|     |       |                    | Host Frame Counter Reset                       |
|     |       |                    | The application writes this bit to reset the   |
| 2   | W1C   | 0x0                | (micro)frame number counter inside the core.   |
|     |       |                    | When the (micro)frame counter is reset, the    |
|     |       |                    | subsequent SOF sent out by the core has a      |
|     |       |                    | (micro)frame number of 0.                      |
|     |       |                    | Reset                                          |
| 1   | R/WSC | 0x0                | A write to this bit issues a soft reset to the |
|     |       |                    | otg_power_dn module of the core.               |



| as                                     |
|----------------------------------------|
| CSR                                    |
| ts:                                    |
|                                        |
|                                        |
|                                        |
|                                        |
|                                        |
|                                        |
| N'                                     |
|                                        |
|                                        |
|                                        |
|                                        |
|                                        |
|                                        |
|                                        |
|                                        |
|                                        |
| HB<br>                                 |
| and all                                |
| are                                    |
| ster                                   |
| r                                      |
| e of an                                |
| SB are                                 |
| ion or                                 |
| is not                                 |
| ation                                  |
| reset                                  |
| e core                                 |
| c is                                   |
| clocks,                                |
| re.                                    |
| ait at                                 |
| ss to                                  |
|                                        |
| 31 of                                  |
| efore                                  |
| e reset                                |
| d also                                 |
| lection                                |
| sted                                   |
| )                                      |
| ed and                                 |
| ck is                                  |
| t for                                  |
| ai<br>es:<br>31<br>ef<br>d<br>le<br>ck |

## **USBOTG\_GINTSTS**

Address: Operational Base + offset (0x0014)

Interrupt Register

| Bit | Attr | Reset Value | Description                                       |
|-----|------|-------------|---------------------------------------------------|
|     |      |             | WkUpInt                                           |
|     |      |             | Resume/Remote Wakeup Detected Interrupt           |
|     |      |             | Wakeup Interrupt during Suspend(L2) or            |
|     |      |             | LPM(L1) state.                                    |
|     |      |             | During Suspend(L2):                               |
|     |      |             | Device Mode:This interrupt is asserted only       |
|     |      |             | when Host Initiated Resume is detected on USB.    |
|     |      |             | Host Mode:This interrupt is asserted only         |
| 31  | W1C  | 0x0         | when Device Initiated Remote Wakeup is            |
|     |      |             | detected on USB.                                  |
|     |      |             | During LPM(L1):                                   |
|     |      |             | Device Mode:This interrupt is asserted for        |
|     |      |             | either Host Initiated Resume or Device Initiated  |
|     |      |             | Remote Wakeup on USB.                             |
|     |      |             | Host Mode:This interrupt is asserted for either   |
|     |      |             | Host Initiated Resume or Device Initiated         |
|     |      |             | Remote Wakeup on USB.                             |
|     |      |             | SessReqInt                                        |
|     |      |             | Session Request/New Session Detected              |
|     |      |             | Interrupt                                         |
|     |      |             | In Host mode, this interrupt is asserted when a   |
| 30  | W1C  | 0x0         | session request is detected from the device. In   |
|     |      |             | Host mode, this interrupt is asserted when a      |
|     |      |             | session request is detected from the device. In   |
|     | 1    |             | Device mode, this interrupt is asserted when the  |
|     |      |             | utmisrp_bvalid signal goes high.                  |
|     |      |             | DisconnInt                                        |
| 29  | W1C  | 0×0         | Disconnect Detected Interrupt                     |
|     |      |             | This interrupt is asserted when a device          |
| 7   |      |             | disconnect is detected.                           |
|     |      |             | ConIDStsChng                                      |
| 28  | W1C  | V1C 0x0     | Connector ID Status Change                        |
|     |      |             | This interrupt is asserted when there is a change |
|     |      |             | in connector ID status.                           |



| Bit | Attr | Reset Value   | Description                                                                             |
|-----|------|---------------|-----------------------------------------------------------------------------------------|
|     |      |               | LPM_Int                                                                                 |
|     |      |               | LPM Transaction Received Interrupt                                                      |
|     |      |               | Device Mode: This interrupt is asserted when                                            |
|     |      |               | the device receives an LPM transaction and                                              |
|     |      |               | responds with a non-ERRORed response.                                                   |
|     |      |               | Host Mode: This interrupt is asserted when the                                          |
| 27  | W1C  | 0×0           | device responds to an LPM transaction with a                                            |
| 27  | WIC  | 0.00          | non-ERRORed response or when the host core                                              |
|     |      |               | has completed LPM transactions for the                                                  |
|     |      |               | programmed number of times                                                              |
|     |      |               | (GLPMCFG.RetryCnt).                                                                     |
|     |      |               | This field is valid only if the Core LPM                                                |
|     |      |               | Configuration register's LPMCapable (LPMCap)                                            |
|     |      |               | field is set to 1.                                                                      |
|     |      |               | PTxFEmp                                                                                 |
|     | RO   | 0×0           | Periodic TxFIFO Empty                                                                   |
|     |      |               | This interrupt is asserted when the Periodic                                            |
|     |      |               | Transmit FIFO is either half or completely empty                                        |
| 26  |      |               | and there is space for at least one entry to be                                         |
|     |      |               | written in the Periodic Request Queue. The half                                         |
|     |      |               | or completely empty status is determined by the                                         |
|     |      |               | Periodic TxFIFO Empty Level bit in the Core AHB                                         |
|     |      |               | Configuration register (GAHBCFG.PTxFEmpLvI).                                            |
|     |      |               | HChInt                                                                                  |
|     |      | • 1           | Host Channels Interrupt                                                                 |
|     |      |               | The core sets this bit to indicate that an interrupt                                    |
|     |      |               | is pending on one of the channels of the core (in                                       |
|     |      | $C_{\lambda}$ | Host mode). The application must read the Host                                          |
| 25  | RO   | 0x0           | All Channels Interrupt (HAINT) register to determine the exact number of the channel on |
| 23  | RU   | UXU           | which the interrupt occurred, and then read the                                         |
| 8   |      |               | corresponding Host Channel-n Interrupt                                                  |
|     |      |               | (HCINTn) register to determine the exact cause                                          |
|     |      |               | of the interrupt. The application must clear the                                        |
|     |      |               | appropriate status bit in the HCINTn register to                                        |
|     |      |               | clear this bit.                                                                         |
|     |      |               | cicui tilis biti                                                                        |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                |
|-----|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24  | RO   | 0×0                | PrtInt Host Port Interrupt The core sets this bit to indicate a change in port status of one of the otg core ports in Host mode. The application must read the Host Port Control and Status (HPRT) register to determine the exact event that caused this interrupt. The application must clear the appropriate status bit in the Host Port Control and Status register to clear this bit. |
| 23  | RW   | 0x0                | ResetDet Reset Detected Interrupt The core asserts this interrupt in Device mode when it detects a reset on the USB in Partial Power-Down mode when the device is in Suspend. This interrupt is not asserted in Host mode.                                                                                                                                                                 |



| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22  | W1C  | 0×0                | FetSusp Data Fetch Suspended This interrupt is valid only in DMA mode. This interrupt indicates that the core has stopped fetching data for IN endpoints due to the unavailability of TxFIFO space or Request Queue space. This interrupt is used by the application for an endpoint mismatch algorithm. For example, after detecting an endpoint mismatch, the application: Sets a global non-periodic IN NAK handshake, Disables In endpoints, Flushes the FIFO, Determines the token sequence from the IN Token Sequence Learning Queue, Re-enables the endpoints, Clears the global non-periodic IN NAK handshake. If the global non-periodic IN NAK is cleared, the core has not yet fetched data for the IN endpoint, and the IN token is received: the core generates an "IN token received when FIFO empty" interrupt. The OTG then sends the host a NAK response. To avoid this scenario, the application can check the GINTSTS.FetSusp interrupt, which ensures that the FIFO is full before clearing a global NAK handshake. Alternatively, the application can mask the IN token received when FIFO empty?interrupt when clearing a global IN NAK handshake. |
| 21  | W1C  | 0×0                | incomplP Incomplete Periodic Transfer In Host mode, the core sets this interrupt bit when there are incomplete periodic transactions still pending which are scheduled for the current microframe. Incomplete Isochronous OUT Transfer (incompISOOUT) The Device mode, the core sets this interrupt to indicate that there is at least one isochronous OUT endpoint on which the transfer is not completed in the current microframe. This interrupt is asserted along with the End of Periodic Frame Interrupt (EOPF) bit in this register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20  | W1C  | 0×0         | incompISOIN Incomplete Isochronous IN Transfer The core sets this interrupt to indicate that there is at least one isochronous IN endpoint on which the transfer is not completed in the current microframe. This interrupt is asserted along with the End of Periodic Frame Interrupt (EOPF) bit in this register. Note: This interrupt is not asserted in Scatter/Gather DMA mode.                                                                                                                                                                                         |
| 19  | RO   | 0×0         | OEPInt OUT Endpoints Interrupt The core sets this bit to indicate that an interrupt is pending on one of the OUT endpoints of the core (in Device mode). The application must read the Device All Endpoints Interrupt (DAINT) register to determine the exact number of the OUT endpoint on which the interrupt occurred, and then read the corresponding Device OUT Endpoint-n Interrupt (DOEPINTn) register to determine the exact cause of the interrupt. The application must clear the appropriate status bit in the corresponding DOEPINTn register to clear this bit. |
| 18  | RO   | 0×0         | IEPInt IN Endpoints Interrupt The core sets this bit to indicate that an interrupt is pending on one of the IN endpoints of the core (in Device mode). The application must read the Device All Endpoints Interrupt (DAINT) register to determine the exact number of the IN endpoint on which the interrupt occurred, and then read the corresponding Device IN Endpoint-n Interrupt (DIEPINTn) register to determine the exact cause of the interrupt. The application must clear the appropriate status bit in the corresponding DIEPINTn register to clear this bit.     |



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                   |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17  | W1C  | 0×0         | EPMis Endpoint Mismatch Interrupt Note: This interrupt is valid only in shared FIFO operation. Indicates that an IN token has been received for a non-periodic endpoint, but the data for another endpoint is present in the top of the Non-periodic Transmit FIFO and the IN endpoint mismatch count programmed by the       |
| 16  | W1C  | 0×0         | application has expired.  RstrDoneInt Restore Done Interrupt The core sets this bit to indicate that the restore command after Hibernation was completed by the core. The core continues from Suspended state into the mode dictated by PCGCCTL.RestoreMode field.This bit is valid only when Hibernation feature is enabled. |
| 15  | W1C  | 0x0         | EOPF End of Periodic Frame Interrupt Indicates that the period specified in the Periodic Frame Interval field of the Device Configuration register (DCFG.PerFrInt) has been reached in the current microframe.                                                                                                                |
| 14  | W1C  | 0×0         | ISOOutDrop Isochronous OUT Packet Dropped Interrupt The core sets this bit when it fails to write an isochronous OUT packet into the RxFIFO because the RxFIFO does not have enough space to accommodate a maximum packet size packet for the isochronous OUT endpoint.                                                       |
| 13  | W1C  | 0×0         | EnumDone Enumeration Done The core sets this bit to indicate that speed enumeration is complete. The application must read the Device Status (DSTS) register to obtain the enumerated speed.                                                                                                                                  |
| 12  | W1C  | 0x0         | USBRst USB Reset The core sets this bit to indicate that a reset is detected on the USB.                                                                                                                                                                                                                                      |



| Bit | Attr | Reset Value | Description                                                                                                                                                                                           |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | USBSusp<br>USB Suspend                                                                                                                                                                                |
| 11  | W1C  | 0×0         | The core sets this bit to indicate that a suspend was detected on the USB. The core enters the Suspended state when there is no activity on the utmi_linestate signal for an extended period of time. |
|     |      |             | time.<br>ErlySusp                                                                                                                                                                                     |
| 10  | W1C  | 0×0         | Early Suspend The core sets this bit to indicate that an Idle state has been detected on the USB for 3 ms.                                                                                            |
|     |      |             | I2CINT                                                                                                                                                                                                |
|     |      |             | I2C Interrupt                                                                                                                                                                                         |
| 9   | W1C  | 0×0         | The core sets this interrupt when I2C access is completed on the I2C interface. This field is used only if the I2C interface was enabled.                                                             |
|     |      |             | Otherwise, reads return 0.                                                                                                                                                                            |
|     |      |             | ULPICKINT                                                                                                                                                                                             |
|     |      |             | ULPI Carkit Interrupt                                                                                                                                                                                 |
|     |      |             | This field is used only if the Carkit interface was                                                                                                                                                   |
|     |      |             | enabled . Otherwise, reads return 0. The core                                                                                                                                                         |
|     | W1C  | W1C 0x0     | sets this interrupt when a ULPI Carkit interrupt                                                                                                                                                      |
| 8   |      |             | is received. The core's PHY sets ULPI Carkit                                                                                                                                                          |
| 0   |      |             | interrupt in UART or Audio mode. I2C Carkit                                                                                                                                                           |
|     |      |             | Interrupt (I2CCKINT) This field is used only if                                                                                                                                                       |
|     |      |             | the I2C interface was enabled . Otherwise, reads                                                                                                                                                      |
|     |      |             | return 0.The core sets this interrupt when a                                                                                                                                                          |
|     |      |             | Carkit interrupt is received. The core's PHY sets                                                                                                                                                     |
|     |      |             | the I2C Carkit interrupt in Audio mode.                                                                                                                                                               |
|     |      | 7           | GOUTNakEff                                                                                                                                                                                            |
|     |      |             | Global OUT NAK Effective                                                                                                                                                                              |
| 7   | RO   |             | Indicates that the Set Global OUT NAK bit in the                                                                                                                                                      |
|     |      | 0×0         | Device Control register DCTL.SGOUTNak), set                                                                                                                                                           |
|     |      |             | by the application, has taken effect in the core.                                                                                                                                                     |
|     |      |             | This bit can be cleared by writing the Clear Global OUT NAK bit in the Device Control                                                                                                                 |
|     |      |             | register (DCTL.CGOUTNak).                                                                                                                                                                             |
|     |      |             | register (Deteredoutivak).                                                                                                                                                                            |



| Bit | Attr       | Reset Value | Description                                        |
|-----|------------|-------------|----------------------------------------------------|
|     |            |             | GINNakEff                                          |
|     |            |             | Global IN Non-Periodic NAK Effective               |
|     |            |             | Indicates that the Set Global Non-periodic IN      |
|     |            |             | NAK bit in the Device Control register             |
|     |            |             | (DCTL.SGNPInNak), set by the application, has      |
|     |            |             | taken effect in the core. That is, the core has    |
| 6   | RO         | 0x0         | sampled the Global IN NAK bit set by the           |
|     |            |             | application. This bit can be cleared by clearing   |
|     |            |             | the Clear Global Nonperiodic IN NAK bit in the     |
|     |            |             | Device Control register (DCTL.CGNPInNak). This     |
|     |            |             | interrupt does not necessarily mean that a NAK     |
|     |            |             | handshake is sent out on the USB. The STALL bit    |
|     |            |             | takes precedence over the NAK bit.                 |
|     |            |             | NPTxFEmp                                           |
|     |            |             | Non-Periodic TxFIFO Empty                          |
|     |            |             | This interrupt is valid only when                  |
|     |            |             | OTG_EN_DED_TX_FIFO = 0. This interrupt is          |
|     |            | 0x0         | asserted when the Non-periodic TxFIFO is either    |
| 5   | RO         |             | half or completely empty, and there is space for   |
|     | IKO        | 0.00        | at least one entry to be written to the            |
|     |            |             | Non-periodic Transmit Request Queue. The half      |
|     |            |             | or completely empty status is determined by the    |
|     |            |             | Non-periodic TxFIFO Empty Level bit in the Core    |
|     |            |             | AHB Configuration                                  |
|     |            |             | register(GAHBCFG.NPTxFEmpLvI).                     |
|     |            | 0x0         | RxFLvI                                             |
| 4   | RO         |             | RxFIFO Non-Empty                                   |
|     |            |             | Indicates that there is at least one packet        |
|     | A .        |             | pending to be read from the RxFIFO.                |
|     |            |             | Sof                                                |
|     |            |             | Start of (micro)Frame                              |
|     | $\bigcirc$ |             | In Host mode, the core sets this bit to indicate   |
|     | ~          |             | that an SOF (FS), micro-SOF(HS), or Keep-Alive     |
| 7   |            |             | (LS) is transmitted on the USB. The application    |
|     | \\\\ 1 C   | 00          | must write a 1 to this bit to clear the interrupt. |
| 3   | W1C        | 0x0         | In Device mode, in the core sets this bit to       |
|     |            |             | indicate that an SOF token has been received on    |
|     |            |             | the USB.                                           |
|     |            |             | The application can read the Device Status         |
|     |            |             | register to get the current (micro)frame           |
|     |            |             | number. This interrupt is seen only when the       |
|     |            |             | core is operating at either HS or FS.              |



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | RO   |             | OTGInt OTG Interrupt The core sets this bit to indicate an OTG protocol event. The application must read the OTG Interrupt Status (GOTGINT) register to determine the exact event that caused this interrupt. The application must clear the                                                                                                                                               |
|     |      |             | appropriate status bit in the GOTGINT register to clear this bit.                                                                                                                                                                                                                                                                                                                          |
| 1   | W1C  | 0×0         | ModeMis Mode Mismatch Interrupt The core sets this bit when the application is trying to access: A Host mode register, when the core is operating in Device mode; A Device mode register, when the core is operating in Host mode. The register access is completed on the AHB with an OKAY response, but is ignored by the core internally and does not affect the operation of the core. |
| 0   | RO   | 0×0         | CurMod Current Mode of Operation Indicates the current mode. 1'b0: Device mode 1'b1: Host mode                                                                                                                                                                                                                                                                                             |

#### **USBOTG\_GINTMSK**

Address: Operational Base + offset (0x0018)

Interrupt Mask Register

| Bit | Attr | <b>Reset Value</b> | Description                             |
|-----|------|--------------------|-----------------------------------------|
|     | CV   | 7                  | WkUpIntMsk                              |
| 31  | RW   | 0x0                | Resume/Remote Wakeup Detected Interrupt |
|     |      |                    | Mask                                    |
|     |      |                    | SessReqIntMsk                           |
| 30  | RW   | 0x0                | Session Request/New Session Detected    |
|     |      |                    | Interrupt Mask                          |
| 29  | RW   | 0×0                | DisconnIntMsk                           |
| 29  |      |                    | Disconnect Detected Interrupt Mask      |
| 28  | RW   | 0×0                | ConIDStsChngMsk                         |
| 20  | KVV  | UXU                | Connector ID Status Change Mask         |
| 27  | DW   | 00                 | LPM_IntMsk                              |
| 21  | RW   | 0x0                | LPM Transaction Received Interrupt Mask |
| 26  | DW   | 0.40               | PTxFEmpMsk                              |
| 26  | RW   | 0x0                | Periodic TxFIFO Empty Mask              |



| Bit | Attr  | Reset Value | Description                                  |
|-----|-------|-------------|----------------------------------------------|
| 25  | DW    | 00          | HChIntMsk                                    |
| 25  | RW    | 0x0         | Host Channels Interrupt Mask                 |
| 2.4 | D144  |             | PrtIntMsk                                    |
| 24  | RW    | 0x0         | Host Port Interrupt Mask                     |
| 22  | D144  |             | ResetDetMsk                                  |
| 23  | RW    | 0x0         | Reset Detected Interrupt Mask                |
| 22  | D144  |             | FetSuspMsk                                   |
| 22  | RW    | 0x0         | Data Fetch Suspended Mask                    |
|     |       |             | incomplPMsk_incompISOOUTMsk                  |
| 2.1 | DVA   | 00          | Incomplete Periodic Transfer Mask(Host only) |
| 21  | RW    | 0x0         | Incomplete Isochronous OUT Transfer          |
|     |       |             | Mask(Device only)                            |
| 20  | DW    | 00          | incompISOINMsk                               |
| 20  | RW    | 0x0         | Incomplete Isochronous IN Transfer Mask      |
| 10  | DW    | 00          | OEPIntMsk                                    |
| 19  | RW    | 0x0         | OUT Endpoints Interrupt Mask                 |
| 1.0 | DVA   | 00          | IEPIntMsk                                    |
| 18  | RW    | 0x0         | IN Endpoints Interrupt Mask                  |
| 47  | DVA   | 0.0         | EPMisMsk                                     |
| 17  | RW    | 0x0         | Endpoint Mismatch Interrupt Mask             |
|     |       |             | RstrDoneIntMsk                               |
| 4.6 | D.144 |             | Restore Done Interrupt Mask                  |
| 16  | RW    | 0x0         | This field is valid only when Hibernation    |
|     |       |             | feature is enabled.                          |
| 1 - | DW    |             | EOPFMsk                                      |
| 15  | RW    | 0x0         | End of Periodic Frame Interrupt Mask         |
|     |       |             | ISOOutDropMsk                                |
| 14  | RW    | 0x0         | Isochronous OUT Packet Dropped Interrupt     |
|     | 11    |             | Mask                                         |
| 12  | DW    | 0.40        | EnumDoneMsk                                  |
| 13  | RW    | 0x0         | Enumeration Done Mask                        |
| 12  | DW    | 0.40        | USBRstMsk                                    |
| 12  | RW    | 0x0         | USB Reset Mask                               |
| 11  | DW    | 00          | USBSuspMsk                                   |
| 11  | RW    | 0x0         | USB Suspend Mask                             |
| 1.0 | DW    | 00          | ErlySuspMsk                                  |
| 10  | RW    | 0x0         | Early Suspend Mask                           |
| 0   | DW    | 0.40        | I2CIntMsk                                    |
| 9   | RW    | 0x0         | I2C Interrupt Mask                           |
|     |       |             | ULPICKINTMsk_I2CCKINTMsk                     |
| 8   | RW    | 0x0         | ULPI Carkit Interrupt Mask (ULPICKINTMsk)    |
|     |       |             | I2C Carkit Interrupt Mask (I2CCKINTMsk)      |



| Bit | Attr | Reset Value | Description                               |
|-----|------|-------------|-------------------------------------------|
| 7   | RW   | 00          | GOUTNakEffMsk                             |
| /   | KVV  | 0x0         | Global OUT NAK Effective Mask             |
| 6   | DW   | 0.40        | GINNakEffMsk                              |
| 6   | RW   | 0x0         | Global Non-periodic IN NAK Effective Mask |
| 5   | RW   | 0.40        | NPTxFEmpMsk                               |
| 5   | KW   | 0x0         | Non-periodic TxFIFO Empty Mask            |
| 4   | DW   | 0.40        | RxFLvIMsk                                 |
| 4   | RW   | 0x0         | Receive FIFO Non-Empty Mask               |
| 3   | RW   | 0x0         | SofMsk                                    |
| 3   | KVV  | UXU         | Start of (micro)Frame Mask                |
| 2   | RW   | 0.40        | OTGIntMsk                                 |
| 2   | KW   | 0x0         | OTG Interrupt Mask                        |
| 4   | DW   | 0.40        | ModeMisMsk                                |
| 1   | RW   | 0×0         | Mode Mismatch Interrupt Mask              |
| 0   | RO   | 0x0         | reserved                                  |

## USBOTG\_GRXSTSR

Address: Operational Base + offset (0x001c)

Receive Status Debug Read Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                         |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25 | RO   | 0x0         | reserved                                                                                                                                                                                                            |
| 24:21 | RO   | 0x0         | FN Frame Number (Device Only)This is the least significant 4 bits of the (micro)frame number in which the packet is received on the USB. This field is supported only when isochronous OUT endpoints are supported. |



| Bit         | Attr | Reset Value | Description                                   |
|-------------|------|-------------|-----------------------------------------------|
|             |      |             | PktSts                                        |
|             |      |             | Packet Status                                 |
|             |      |             | Indicates the status of the received          |
|             |      |             | packet(Host Only)                             |
|             |      |             | 4'b0010: IN data packet received              |
|             |      |             | 4'b0011: IN transfer completed (triggers an   |
|             |      |             | interrupt)                                    |
|             |      |             | 4'b0101: Data toggle error (triggers an       |
|             |      |             | interrupt)                                    |
|             |      |             | 4'b0111: Channel halted (triggers an          |
|             |      |             | interrupt)                                    |
| 20:17       | RO   | 0x0         | Others: Reserved                              |
|             |      |             | Indicates the status of the received          |
|             |      |             | packet(Device only)                           |
|             |      |             | 4'b0001: Global OUT NAK (triggers an          |
|             |      |             | interrupt)                                    |
|             |      |             | 4'b0010: OUT data packet received             |
|             |      |             | 4'b0011: OUT transfer completed (triggers     |
|             |      |             | an interrupt)                                 |
|             |      |             | 4'b0100: SETUP transaction completed          |
|             |      |             | (triggers an interrupt)                       |
|             |      |             | 4'b0110: SETUP data packet received           |
|             |      |             | Others: Reserved                              |
|             |      |             | DPID                                          |
|             |      |             | Data PID                                      |
|             |      |             | Indicates the Data PID of the received packet |
| 16:15       | RO   | 0x0         | 2'b00: DATA0                                  |
|             |      |             | 2'b10: DATA1                                  |
|             | 41   |             | 2'b01: DATA2                                  |
|             |      | 7           | 2'b11: MDATA                                  |
|             |      |             | BCnt                                          |
| 14:4        | RW   | 0×000       | Byte Count                                    |
|             |      | OXOOC       | Indicates the byte count of the received data |
| <b>&gt;</b> |      |             | packet.                                       |
|             |      |             | ChNum_EPNum                                   |
|             |      |             | Channel Number(Host) Endpoint                 |
|             |      |             | Number(Device)                                |
| 3:0         | RO   | 0x0         | (Host Only) Indicates the channel number to   |
|             |      |             | which the current received packet belongs.    |
|             |      |             | (Device Only) Indicates the endpoint number   |
|             |      |             | to which the current received packet belongs. |



# **USBOTG\_GRXSTSP**

Address: Operational Base + offset (0x0020) Receive Status Read and Pop Register

| Bit   | Attr | Reset Value | Description                                        |
|-------|------|-------------|----------------------------------------------------|
| 31:25 | RO   | 0x0         | reserved                                           |
|       |      |             | FN                                                 |
|       |      |             | Frame Number                                       |
|       |      |             | (Device Only) This is the least significant 4 bits |
| 24:21 | RO   | 0x0         | of the (micro)frame number in which the            |
|       |      |             | packet is received on the USB. This field is       |
|       |      |             | supported only when isochronous OUT                |
|       |      |             | endpoints are supported.                           |
|       |      |             | PktSts                                             |
|       |      |             | Packet Status                                      |
|       |      |             | Indicates the status of the received               |
|       |      |             | packet(Host Only)                                  |
|       |      |             | 4'b0010: IN data packet received                   |
|       |      |             | 4'b0011: IN transfer completed (triggers an        |
|       |      |             | interrupt)                                         |
|       |      |             | 4'b0101: Data toggle error (triggers an            |
|       |      |             | interrupt)                                         |
|       |      |             | 4'b0111: Channel halted (triggers an               |
|       |      |             | interrupt)                                         |
| 20:17 | RO   | 0x0         | Others: Reserved                                   |
|       |      |             | Indicates the status of the received               |
|       |      |             | packet(Device only)                                |
|       |      | • 1         | 4'b0001: Global OUT NAK (triggers an               |
|       |      |             | interrupt)                                         |
|       |      |             | 4'b0010: OUT data packet received                  |
|       |      |             | 4'b0011: OUT transfer completed (triggers          |
|       | 11   |             | an interrupt)                                      |
|       |      |             | 4'b0100: SETUP transaction completed               |
|       |      |             | (triggers an interrupt)                            |
| 0     |      |             | 4'b0110: SETUP data packet received                |
|       | ·    |             | Others: Reserved                                   |
| 7     |      |             | DPID                                               |
|       |      |             | Data PID                                           |
|       |      |             | Indicates the Data PID of the received OUT         |
| 16.15 | DO.  | 0.40        | data packet                                        |
| 16:15 | RO   | 0x0         | 2'b00: DATA0                                       |
|       |      |             | 2'b10: DATA1                                       |
|       |      |             | 2'b01: DATA2                                       |
|       |      |             | 2'b11: MDATA                                       |



| Bit  | Attr | Reset Value | Description                                   |
|------|------|-------------|-----------------------------------------------|
|      |      |             | BCnt                                          |
| 14:4 | RO   | 0×000       | Byte Count                                    |
| 14.4 | KO   | 0000        | Indicates the byte count of the received data |
|      |      |             | packet.                                       |
|      | RO   | 0×0         | ChNum_EPNum                                   |
|      |      |             | Channel Number(Host) Endpoint                 |
|      |      |             | Number(Device)                                |
| 3:0  |      |             | (Host Only) Indicates the channel number to   |
|      |      |             | which the current received packet belongs.    |
|      |      |             | (Device Only) Indicates the endpoint number   |
|      |      |             | to which the current received packet belongs. |

## USBOTG\_GRXFSIZ

Address: Operational Base + offset (0x0024)

Receive FIFO Size Register

| Bit           | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16         | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 31:16<br>15:0 | RO   | 0x0000      | RxFDep RxFIFO Depth This value is in terms of 32-bit words. Minimum value is 16, Maximum value is 32,768. The power-on reset value of this register is specified as the Largest Rx Data FIFO Depth. If Enable Dynamic FIFO Sizing? was deselected, these flops are optimized, and reads return the power-on value. If Enable Dynamic FIFO Sizing? was selected, you can write a new value in this field. You can write a new value in this field. Programmed |
|               |      | 7           | values must not exceed the power-on value.                                                                                                                                                                                                                                                                                                                                                                                                                   |

## **USBOTG\_GNPTXFSIZ**

Address: Operational Base + offset (0x0028)

Non-Periodic Transmit FIFO Size Register (Host mode)

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
|-----|------|-------------|-------------|



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0×0000      | NPTxFDep Non-periodic TxFIFO For host mode, this field is always valid. For Device mode, this field is valid only when OTG_EN_DED_TX_FIFO==0. This value is in terms of 32-bit words. Minimum value is 16 Maximum value is 32,768 This field is determined by Enable Dynamic FIFO Sizing. OTG_DFIFO_DYNAMIC = 0: These flops are optimized, and reads return the power-on value. OTG_DFIFO_DYNAMIC = 1: The application can write a new value in this field. Programmed values must not exceed the power-on value. The power-on reset value of this field is specified by OTG_EN_DED_TX_FIFO: OTG_EN_DED_TX_FIFO = 0:The reset value is the Largest Non-periodic Tx Data FIFO Depth parameter, OTG_TX_NPERIO_DFIFO_DEPTH. OTG_EN_DED_TX_FIFO = 1:The reset value is parameter OTG_TX_HNPERIO_DFIFO_DEPTH. |
| 15:0  | RW   | 0x0000      | NPTxFStAddr Non-periodic Transmit RAM For host mode, this field is always valid. This field contains the memory start address for Non-periodic Transmit FIFO RAM. This field is determined by Enable Dynamic FIFO Sizing?(OTG_DFIFO_DYNAMIC): OTG_DFIFO_DYNAMIC = 0 :These flops are optimized, and reads return the power-on value. OTG_DFIFO_DYNAMIC = 1 :The application can write a new value in this field. Programmed values must not exceed the power-on value. The power-on reset value of this field is specified by Largest Rx Data FIFO Depth (parameter OTG_RX_DFIFO_DEPTH).                                                                                                                                                                                                                  |

Non-Periodic Transmit FIFO Size Register (Device mode)

| Bit | Attr Reset Value | Description |
|-----|------------------|-------------|
|-----|------------------|-------------|



| Bit      | Attr   | Reset Value | Description                                         |
|----------|--------|-------------|-----------------------------------------------------|
|          |        |             | INEPTxF0Dep                                         |
|          |        |             | IN Endpoint TxFIFO 0 Depth                          |
|          |        |             | This field is valid only for Device mode and when   |
|          |        |             | OTG_EN_DED_TX_FIFO = 1                              |
|          |        |             | This value is in terms of 32-bit words.             |
|          |        |             | Minimum value is 16                                 |
|          |        |             | Maximum value is 32,768                             |
|          |        |             | This field is determined by Enable Dynamic FIFO     |
| 31:16    | RW     | 0x0000      | Sizing? (OTG_TX_DINEP_DFIFO_DEPTH_0):               |
|          |        |             | OTG_DFIFO_DYNAMIC = 0—These flops are               |
|          |        |             | optimized, and reads return the power-on            |
|          |        |             | value.                                              |
|          |        |             | OTG_DFIFO_DYNAMIC = 1—Programmed                    |
|          |        |             | values must not exceed the power-on value.          |
|          |        |             | The power-on reset value of this field is specified |
|          |        |             | as Largest IN Endpoint FIFO 0 Depth (parameter      |
|          |        |             | OTG_TX_DINEP_DFIFO_DEPTH_0).                        |
|          |        |             | INEPTxF0StAddr                                      |
|          |        |             | IN Endpoint FIFO0 Transmit RAM Start Address        |
|          |        |             | For Device mode                                     |
|          |        |             | this field is valid only when                       |
|          |        |             | OTG_EN_DED_TX_FIFO = 0 This field contains          |
|          |        |             | the memory start address for IN Endpoint            |
|          |        |             | Transmit FIFO# 0. OTG_RX_DFIFO_DEPTH This           |
|          |        |             | field is determined by Enable Dynamic FIFO          |
| 15:0     | RW     | 0×0000      | Sizing? (OTG_DFIFO_DYNAMIC):                        |
| 15.0     | IX V V | 00000       | OTG_DFIFO_DYNAMIC = 0 —These flops are              |
|          |        |             | optimized, and reads return the power-on            |
|          | A 4    |             | value.                                              |
|          |        |             | OTG_DFIFO_DYNAMIC = 1—The application can           |
|          |        |             | write a new value in this field. Programmed         |
|          |        |             | values must not exceed the power-on value.          |
|          | _      |             | The power-on reset value of this register is        |
| <b>Y</b> |        |             | specified as the Largest Rx Data FIFO Depth         |
|          |        |             | (parameter OTG_RX_DFIFO_DEPTH).                     |

## **USBOTG\_GNPTXSTS**

Address: Operational Base + offset (0x002c)Non-Periodic Transmit FIFO/Queue Status Register

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
| 31  | RO   | 0x0         | reserved    |



| Bit   | Attr | Reset Value | Description                                     |
|-------|------|-------------|-------------------------------------------------|
|       |      |             | NPTxQTop                                        |
|       |      |             | Top of the Non-periodic Transmit Request        |
|       |      |             | Queue                                           |
|       |      |             | Entry in the Non-periodic Tx Request Queue      |
|       |      |             | that is currently being processed by the MAC.   |
|       |      |             | Bits [30:27]: Channel/endpoint number           |
| 20.24 | D.O. | 000         | Bits [26:25]:                                   |
| 30:24 | RO   | 0x00        | 2'b00: IN/OUT token                             |
|       |      |             | 2'b01: Zero-length transmit packet (device      |
|       |      |             | IN/host OUT)                                    |
|       |      |             | 2'b10: PING/CSPLIT token                        |
|       |      |             | 2'b11: Channel halt command                     |
|       |      |             | Bit [24]: Terminate (last entry for selected    |
|       |      |             | channel/endpoint)                               |
|       |      |             | NPTxQSpcAvail                                   |
|       |      |             | Non-periodic Transmit Request Queue Space       |
|       |      |             | Available                                       |
|       |      |             | Indicates the amount of free space available in |
|       |      |             | the Non-periodic Transmit Request Queue.        |
|       |      |             | This queue holds both IN and OUT requests in    |
| 23:16 | RO   | 0×00        | Host mode. Device mode has only IN              |
| 23.10 | RO   | 0000        | requests.                                       |
|       |      |             | 8'h0: Non-periodic Transmit Request Queue       |
|       |      |             | is full                                         |
|       |      |             | 8'h1: 1 location available                      |
|       |      |             | 8'h2: 2 locations available                     |
|       |      | V Y         | n: n locations available $(0 \le n \le 8)$      |
|       |      |             | Others: Reserved                                |
|       | 1    |             | NPTxFSpcAvail                                   |
|       |      |             | Non-periodic TxFIFO Space Avail                 |
|       |      |             | Indicates the amount of free space available in |
| 15:0  |      |             | the Non-periodic TxFIFO. Values are in terms    |
|       | ,    |             | of 32-bit words.                                |
|       | RO   | 0×0000      | 16'h0: Non-periodic TxFIFO is full              |
|       |      | 020000      | 16'h1: 1 word available                         |
|       |      |             | 16'h2: 2 words available                        |
|       |      |             | 16'hn: n words available (where 0 <=n           |
|       |      |             | <=32,768)                                       |
|       |      |             | 16'h8000: 32,768 words available                |
|       |      |             | Others: Reserved                                |

# USBOTG\_GI2CCTL

Address: Operational Base + offset (0x0030)



I2C Address Register

| Bit         | ress Reg<br>Attr | Reset Value | Description                                        |
|-------------|------------------|-------------|----------------------------------------------------|
|             |                  |             | BsyDne                                             |
|             |                  |             | I2C Busy/Done                                      |
|             |                  |             | The application sets this bit to 1'b1 to start a   |
|             |                  |             | request on the I2C interface. When the             |
| 31          | R/WSC            | 0x0         | transfer is complete, the core deasserts this      |
|             |                  |             | bit to 1'b0. As long as the bit is set, indicating |
|             |                  |             | that the I2C interface is busy, the application    |
|             |                  |             | cannot start another request on the interface.     |
|             |                  |             | RW                                                 |
|             |                  |             | Read/Write Indicator                               |
|             |                  |             | Indicates whether a read or write register         |
| 20          | D) 47            |             | transfer must be performed on the                  |
| 30          | RW               | 0x0         | interface.Read/write bursting is not supported     |
|             |                  |             | for registers.                                     |
|             |                  |             | 1'b1: Read                                         |
|             |                  |             | 1'b0: Write                                        |
| 29          | RO               | 0x0         | reserved                                           |
|             |                  |             | I2CDatSe0                                          |
|             |                  |             | I2C DatSe0 USB Mode                                |
| 28          | RW               | 0x1         | Selects the FS interface USB mode.                 |
|             |                  |             | 1'b1: VP_VM USB mode                               |
|             |                  |             | 1'b0: DAT_SE0 USB mode                             |
|             |                  |             | I2CDevAdr                                          |
|             |                  |             | I2C Device Address                                 |
|             |                  |             | Selects the address of the I2C Slave on the        |
|             |                  | V X         | USB 1.1 full-speed serial transceiver that the     |
| 27:26       | RW               | 0x0         | core uses for OTG signaling.                       |
|             | 41               |             | 2'b00: 7'h2C                                       |
|             |                  | 7           | 2'b01: 7'h2D                                       |
|             |                  |             | 2'b10: 7'h2E                                       |
|             |                  |             | 2'b11: 7'h2F                                       |
| 1           |                  |             | I2CSuspCtl                                         |
| <b>&gt;</b> |                  |             | I2C Suspend Control                                |
|             |                  |             | Selects how Suspend is connected to a              |
| 25          | RW               | 0x0         | full-speed transceiver in I2C mode.                |
|             |                  |             | 1'b0: Use the dedicated utmi_suspend_n pin         |
|             |                  |             | 1'b1: Use an I2C write to program the              |
|             |                  |             | Suspend bit in the PHY register                    |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                            |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24    | RO   | 0×1         | Ack I2C ACK Indicates whether an ACK response was received from the I2C Slave. This bit is valid when BsyDne is cleared by the core, after application has initiated an I2C access. 1'b0: NAK 1'b1: ACK                                                                                |
| 23    | RW   | 0×0         | I2CEn I2C Enable Enables the I2C Master to initiate I2C transactions on the I2C interface                                                                                                                                                                                              |
| 22:16 | RW   | 0x00        | Addr I2C Address This is the 7-bit I2C device address used by software to access any external I2C Slave,including the I2C Slave on a USB 1.1 OTG full-speed serial transceiver. Software can change this address to access different I2C Slaves.                                       |
| 15:8  | RW   | 0x00        | RegAddr I2C Register Addr This field programs the address of the register to be read from or written to.                                                                                                                                                                               |
| 7:0   | RW   | 0×00        | RWData I2C Read/Write Data After a register read operation, this field holds the read data for the application. During a write operation, the application can use this register to program the write data to be written to a register. During writes, this field holds the write data. |

#### **USBOTG\_GPVNDCTL**

Address: Operational Base + offset (0x0034)

PHY Vendor Control Register

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
|-----|------|-------------|-------------|



| Bit   | Attr                                    | Reset Value | Description                                        |
|-------|-----------------------------------------|-------------|----------------------------------------------------|
|       |                                         |             | DisUlpiDrvr                                        |
|       |                                         |             | Disable ULPI Drivers                               |
|       |                                         |             | This field is used only if the Carkit interface    |
|       |                                         |             | was enabled (parameter OTG_ULPI_CARKIT =           |
|       |                                         |             | 1). Otherwise, reads return 0. The application     |
| 31    | R/WSC                                   | 0x0         | sets this bit when it has finished processing the  |
|       |                                         |             | ULPI Carkit Interrupt (GINTSTS.ULPICKINT).         |
|       |                                         |             | When set, the otg core disables drivers for        |
|       |                                         |             | output signals and masks input signal for the      |
|       |                                         |             | ULPI interface. Otg clears this bit before         |
|       |                                         |             | enabling the ULPI interface.                       |
| 30:28 | RO                                      | 0x0         | reserved                                           |
|       |                                         |             | VStsDone                                           |
|       |                                         |             | VStatus Done                                       |
| 27    | R/WSC                                   | 0x0         | The core sets this bit when the vendor control     |
|       | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | o no        | access is done. This bit is cleared by the core    |
|       |                                         |             | when the application sets the New Register         |
|       |                                         |             | Request bit (bit 25).                              |
|       |                                         |             | VStsBsy                                            |
| 26    | D.O.                                    | 0.0         | VStatus Busy                                       |
| 26    | RO                                      | 0x0         | The core sets this bit when the vendor control     |
|       |                                         |             | access is in progress and clears this bit when     |
|       |                                         |             | done.                                              |
|       |                                         | 0x0         | NewRegReq<br>New Register Request                  |
| 25    | R/WSC                                   |             | The application sets this bit for a new vendor     |
|       |                                         |             | control access.                                    |
| 24:23 | RO                                      | 0×0         | reserved                                           |
| 24.23 | A 1                                     | OXO ,       | RegWr                                              |
|       | 1                                       | ~           | Register Write                                     |
| 22    | RW                                      | 0x0         | Set this bit for register writes, and clear it for |
|       |                                         |             | register reads.                                    |
|       | /                                       |             | RegAddr                                            |
|       |                                         |             | Register Address                                   |
| 21:16 | RW                                      | 0×00        | The 6-bit PHY register address for immediate       |
|       |                                         |             | PHY Register Set access. Set to                    |
|       |                                         |             | 6'h2F for Extended PHY Register Set access.        |



| Bit  | Attr | Reset Value | Description                                        |
|------|------|-------------|----------------------------------------------------|
|      |      |             | VCtrl                                              |
|      |      |             | UTMI+ Vendor Control Register Address              |
|      |      |             | The 4-bit register address a vendor defined        |
| 15:8 | RW   | 0x00        | 4-bit parallel output bus. Bits 11:8 of this field |
|      |      |             | are placed on utmi_vcontrol[3:0]. ULPI             |
|      |      |             | Extended Register Address (ExtRegAddr) The         |
|      |      |             | 6-bit PHY extended register address.               |
|      |      |             | RegData                                            |
|      |      |             | Register Data                                      |
| 7:0  | RW   | 0x00        | Contains the write data for register write. Read   |
|      |      |             | data for register read, valid when VStatus         |
|      |      |             | Done is set.                                       |

#### **USBOTG\_GGPIO**

Address: Operational Base + offset (0x0038) General Purpost Input/Output Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                   |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0×0000      | GPO General Purpose Output This field is driven as an output from the core, gp_o[15:0]. The application can program this field to determine the corresponding value on the gp_o[15:0] output. |
| 15:0  | RO   | 0x0000      | GPI General Purpose Input This field's read value reflects the gp_i[15:0] core input value.                                                                                                   |

#### USBOTG\_GUID

Address: Operational Base + offset (0x003c)

User ID Register

| Bit  | Attr    | Reset Value | Description                        |
|------|---------|-------------|------------------------------------|
| 31:0 | 31:0 RW | 0×00000000  | UserID                             |
|      |         |             | Application-programmable ID field. |

#### **USBOTG\_GSNPSID**

Address: Operational Base + offset (0x0040)

Core ID Register

| Bit  | Attr | Reset Value | Description                           |
|------|------|-------------|---------------------------------------|
| 31:0 | RO   | 0x00004f54  | CoreID                                |
| 31.0 | RO   | 000004154   | Release number of the core being used |



# USBOTG\_GHWCFG1

Address: Operational Base + offset (0x0044)

User HW Config1 Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                 |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0×00000000  | epdir Endpoint Direction This 32-bit field uses two bits per endpoint to determine the endpoint direction. Endpoint Bits [31:30]: Endpoint 15 direction Bits [29:28]: Endpoint 14 direction Bits [3:2]: Endpoint 1 direction Bits[1:0]: Endpoint 0 direction (always BIDIR) Direction 2'b00: BIDIR (IN and OUT) endpoint 2'b01: IN endpoint 2'b11: Reserved |

#### USBOTG\_GHWCFG2

Address: Operational Base + offset (0x0048)

User HW Config2 Register

| Bit   | Attr | Reset Value | Description                                 |
|-------|------|-------------|---------------------------------------------|
|       |      |             | OTG_ENABLE_IC_USB                           |
|       |      | • \         | IC_USB mode specified for mode of operation |
| 31    | RO   | 0x0         | (parameter OTG_ENABLE_IC_USB). To choose    |
|       |      |             | IC_USB_MODE, both OTG_FSPHY_INTERFACE       |
|       |      |             | and OTG_ENABLE_IC_USB must be 1.            |
|       |      | 7           | TknQDepth                                   |
| 30:26 | DO.  | 0×00        | Device Mode IN Token Sequence Learning      |
| 30.20 | RO   | 0000        | Queue Depth                                 |
|       |      |             | Range: 0-30                                 |
|       |      |             | PTxQDepth                                   |
|       |      |             | Host Mode Periodic Request Queue Depth      |
| 25:24 | RO   | 0×0         | 2'b00: 2                                    |
| 23.24 | KU   | UXU         | 2'b01: 4                                    |
|       |      |             | 2'b10: 8                                    |
|       |      |             | Others: Reserved                            |



| Bit   | Attr | Reset Value | Description                                  |
|-------|------|-------------|----------------------------------------------|
|       |      |             | NPTxQDepth                                   |
|       |      |             | Non-periodic Request Queue Depth             |
| 22.22 | D.O. | 00          | 2'b00: 2                                     |
| 23:22 | RO   | 0x0         | 2'b01: 4                                     |
|       |      |             | 2'b10: 8                                     |
|       |      |             | Others: Reserved                             |
| 21    | RO   | 0x0         | reserved                                     |
|       |      |             | MultiProcIntrpt                              |
| 20    | DO.  | 0.40        | Multi Processor Interrupt Enabled            |
| 20    | RO   | 0×0         | 1'b0: No                                     |
|       |      |             | 1'b1: Yes                                    |
|       |      |             | DynFifoSizing                                |
| 10    | DO.  | 0.40        | Dynamic FIFO Sizing Enabled                  |
| 19    | RO   | 0x0         | 1'b0: No                                     |
|       |      |             | 1'b1: Yes                                    |
|       |      |             | PerioSupport                                 |
| 10    | DO.  | 0x0         | Periodic OUT Channels Supported in Host Mode |
| 18    | RO   |             | 1'b0: No                                     |
|       |      |             | 1'b1: Yes                                    |
|       |      |             | NumHstChnl                                   |
|       |      |             | Number of Host Channels                      |
| 17.14 | D.O. |             | Indicates the number of host channels        |
| 17:14 | RO   | 0x0         | supported by the core in Host mode. The      |
|       |      |             | range of this field is 0-15: 0 specifies 1   |
|       |      |             | channel, 15 specifies 16 channels.           |
|       |      | 1.5         | NumDevEps                                    |
|       |      | No. y       | Number of Device Endpoints                   |
| 12.10 | DO   | 0.0         | Indicates the number of device endpoints     |
| 13:10 | RO   | 0x0         | supported by the core in Device mode in      |
|       |      | 7           | addition to control endpoint 0. The range of |
|       |      |             | this field is 1-15.                          |
|       |      |             | FSPhyType                                    |
|       |      |             | Full-Speed PHY Interface Type                |
| 0.0   | DO.  | 00          | 2'b00: Full-speed interface not supported    |
| 9:8   | RO   | 0x0         | 2'b01: Dedicated full-speed interface        |
|       |      |             | 2'b10: FS pins shared with UTMI+ pins        |
|       |      |             | 2'b11: FS pins shared with ULPI pins         |
|       |      |             | HSPhyType                                    |
|       |      |             | High-Speed PHY Interface Type                |
| 7.6   | D.C. | 0x0         | 2'b00: High-Speed interface not supported    |
| 7:6   | RO   |             | 2'b01: UTMI+                                 |
|       |      |             | 2'b10: ULPI                                  |
|       |      |             | 2'b11: UTMI+ and ULPI                        |



| Bit | Attr | Reset Value | Description                                   |
|-----|------|-------------|-----------------------------------------------|
|     |      |             | SingPnt                                       |
|     |      |             | Point-to-Point                                |
| 5   | RO   | 0×0         | 1'b0: Multi-point application (hub and split  |
| 5   | RU   | UXU         | support)                                      |
|     |      |             | 1'b1: Single-point application (no hub and no |
|     |      |             | split support)                                |
|     |      |             | OtgArch                                       |
|     |      |             | Architecture                                  |
| 4:3 | RO   | 0×0         | 2'b00: Slave-Only                             |
| 7.5 |      | UXU         | 2'b01: External DMA                           |
|     |      |             | 2'b10: Internal DMA                           |
|     |      |             | Others: Reserved                              |
|     |      |             | OtgMode                                       |
|     |      |             | Mode of Operation                             |
|     | RO   | 0×0         | 3'b000: HNP- and SRP-Capable OTG (Host        |
|     |      |             | and Device)                                   |
|     |      |             | 3'b001: SRP-Capable OTG (Host and Device)     |
| 2:0 |      |             | 3'b010: Non-HNP and Non-SRP Capable OTG       |
| 2.0 |      |             | (Host and Device)                             |
|     |      |             | 3'b011: SRP-Capable Device                    |
|     |      |             | 3'b100: Non-OTG Device                        |
|     |      |             | 3'b101: SRP-Capable Host                      |
|     |      |             | 3'b110: Non-OTG Host                          |
|     |      |             | Others: Reserved                              |

#### **USBOTG\_GHWCFG3**

Address: Operational Base + offset (0x004c)

User HW Config3 Register

| Bit   | Attr | Reset Value | Description                              |
|-------|------|-------------|------------------------------------------|
|       |      | ,           | DfifoDepth                               |
|       |      |             | DFIFO Depth                              |
| 31:16 | RO   | 0x0000      | This value is in terms of 32-bit words.  |
|       |      |             | Minimum value is 32                      |
|       |      |             | Maximum value is 32,768                  |
|       |      |             | OTG_ENABLE_LPM                           |
| 15    | RO   | 0x0         | LPM mode specified for Mode of Operation |
|       |      |             | (parameter OTG_ENABLE_LPM).              |
|       |      |             | OTG_BC_SUPPORT                           |
|       |      |             | This bit indicates the HS OTG controller |
| 14    | RO   | 0x0         | support for Battery Charger.             |
|       |      |             | 0 : No Battery Charger Support           |
|       |      |             | 1 : Battery Charger support present.     |



| Bit | Attr | Reset Value | Description                                     |
|-----|------|-------------|-------------------------------------------------|
| 13  | RO   | 0x0         | OTG_ENABLE_HSIC                                 |
|     |      |             | HSIC mode specified for Mode of Operation       |
|     |      |             | (parameter OTG_ENABLE_HSIC).                    |
|     |      |             | Value Range: 0-1                                |
|     |      |             | 1: HSIC-capable with shared UTMI PHY            |
|     |      |             | interface                                       |
|     |      |             | 0: Non-HSIC-capable                             |
| 12  | RO   | 0x0         | OTG_ADP_SUPPORT                                 |
|     |      |             | This bit indicates whether ADP logic is present |
|     |      |             | within or external to the HS OTG                |
|     |      |             | controller                                      |
|     |      |             | 0: No ADP logic present with HSOTG              |
|     |      |             | controller                                      |
|     |      |             | 1: ADP logic is present along with HSOTG        |
|     |      |             | controller.                                     |
| 11  | RO   | 0x0         | RstType                                         |
|     |      |             | Reset Style for Clocked always Blocks in RTL    |
|     |      |             | 1'b0: Asynchronous reset is used in the core    |
|     |      |             | 1'b1: Synchronous reset is used in the core     |
| 10  | RO   | 0x0         | OptFeature                                      |
|     |      |             | Optional Features Removed                       |
|     |      |             | Indicates whether the User ID register, GPIO    |
|     |      |             | interface ports, and SOF toggle and counter     |
|     |      |             | ports were removed for gate count               |
|     |      |             | optimization by enabling Remove Optional        |
|     |      |             | Features?                                       |
|     |      |             | 1'b0: No                                        |
|     |      |             | 1'b1: Yes                                       |
|     | N    | 7           | VndctlSupt                                      |
|     |      |             | Vendor Control Interface Support                |
| 9   | RO   | 0x0         | 1'b0: Vendor Control Interface is not           |
| 2   |      |             | available on the core.                          |
|     |      |             | 1'b1: Vendor Control Interface is available.    |
| 8   | RO   | 0x0         | I2CIntSel                                       |
|     |      |             | I2C Selection                                   |
|     |      |             | 1'b0: I2C Interface is not available on the     |
|     |      |             | core.                                           |
|     |      |             | 1'b1: I2C Interface is available on the core.   |



| Bit | Attr | Reset Value | Description                                      |
|-----|------|-------------|--------------------------------------------------|
|     |      |             | OtgEn                                            |
|     |      |             | OTG Function Enabled                             |
| 7   | RO   | 0×0         | The application uses this bit to indicate theotg |
| ,   |      | 0.00        | core's OTG capabilities.                         |
|     |      |             | 1'b0: Not OTG capable                            |
|     |      |             | 1'b1: OTG Capable                                |
|     |      |             | PktSizeWidth                                     |
|     |      |             | Width of Packet Size Counters                    |
|     |      |             | 3'b000: 4 bits                                   |
|     |      | 0×0         | 3'b001: 5 bits                                   |
| 6:4 | RO   |             | 3'b010: 6 bits                                   |
|     |      |             | 3'b011: 7 bits                                   |
|     |      |             | 3'b100: 8 bits                                   |
|     |      |             | 3'b101: 9 bits                                   |
|     |      |             | 3'b110: 10 bits                                  |
|     |      |             | Others: Reserved                                 |
|     |      |             | XferSizeWidth                                    |
|     |      |             | Width of Transfer Size Counters                  |
|     |      |             | 4'b0000: 11 bits                                 |
| 3:0 | RO   | 0x0         | 4'b0001: 12 bits                                 |
|     |      |             |                                                  |
|     |      |             | 4'b1000: 19 bits                                 |
|     |      |             | Others: Reserved                                 |

# USBOTG\_GHWCFG4

Address: Operational Base + offset (0x0050)

User HW Config4 Register

| Bit   | Attr | Reset Value | Description                                  |
|-------|------|-------------|----------------------------------------------|
|       | 11   |             | SGDMA                                        |
| 31    | RO   | 0x0         | Scatter/Gather DMA                           |
|       |      |             | 1'b1: Dynamic configuration                  |
|       |      |             | SGDMACon                                     |
| 30    | RO   | 0×0         | Scatter/Gather DMA configuration             |
| 30    | KO   | 000         | 1'b0: Non-Scatter/Gather DMA configuration   |
|       |      |             | 1'b1: Scatter/Gather DMA configuration       |
|       |      |             | INEps                                        |
|       |      |             | Number of Device Mode IN Endpoints Including |
|       |      | 0x0         | Control Endpoint                             |
| 29:26 | RO   |             | Range 0 -15                                  |
| 29.20 | KO   | UXU         | 0:1 IN Endpoint                              |
|       |      |             | 1:2 IN Endpoints                             |
|       |      |             |                                              |
|       |      |             | 15:16 IN Endpoints                           |





| Bit | Attr | Reset Value | Description                                 |
|-----|------|-------------|---------------------------------------------|
|     |      |             | EnHiber                                     |
| 6   | RO   | 0×0         | Enable Hibernation                          |
| 0   | KO   | UXU         | 1'b0: Hibernation feature not enabled       |
|     |      |             | 1'b1: Hibernation feature enabled           |
|     |      |             | AhbFreq                                     |
| 5   | RO   | 0×0         | Minimum AHB Frequency Less Than 60 MHz      |
| 3   | RO   | UXU         | 1'b0: No                                    |
|     |      |             | 1'b1: Yes                                   |
|     |      |             | EnParPwrDown                                |
| 4   | DO.  | 0.40        | Enable Partial Power Down                   |
| 4   | RO   | 0x0         | 1'b0: Partial Power Down Not Enabled        |
|     |      |             | 1'b1: Partial Power Down Enabled            |
|     |      |             | NumDevPerioEps                              |
| 3:0 | RO   | 0x0         | Number of Device Mode Periodic IN Endpoints |
|     |      |             | Range: 0-15                                 |

# USBOTG\_GLPMCFG

Address: Operational Base + offset (0x0054)
Core LPM Configuration Register

| Bit | Attr | Reset Value      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----|------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      | Reset Value  0x0 | InvSelHsic HSIC-Invert Select HSIC The application uses this bit to control the otg core HSIC enable/disable. This bit overrides and functionally inverts the if_sel_hsic input port signal. If the core operates as non-HSIC-capable, it can only connect to non-HSIC-capable PHYs. If the core operates as HSIC-capable, it can only connect to HSICcapable PHYs. If the if_sel_hsic input signal is1:  1'b1: HSIC capability is not enabled.  1'b0: HSIC capability is enabled, If InvSelHsic = 1'b0: HSIC capability is enabled. I'b1: HSIC capability is enabled.  1'b1: HSIC capability is enabled, I'b1: HSIC capability is not enabled.  This bit is writable only if an HSIC mode was |
|     |      |                  | This bit is writable only if an HSIC mode was specified for Mode of Operation (parameter OTG_ENABLE_HSIC). This bit is valid only if OTG_ENABLE_HSIC is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |



| Bit   | Attr   | Reset Value | Description                                                                                |
|-------|--------|-------------|--------------------------------------------------------------------------------------------|
|       |        |             | HSICCon                                                                                    |
|       |        |             | HSIC-Connect                                                                               |
|       |        |             | The application must use this bit to initiate the                                          |
|       |        |             | HSIC Attach sequence. Host Mode: Once this                                                 |
|       |        |             | bit is set, the host core configures to drive the                                          |
|       |        |             | HSIC Idle state (STROBE = $1 \& DATA = 0$ ) on                                             |
| 30    | RW     | 0×0         | the bus. It then waits for the device to initiate                                          |
| 30    | IK VV  | UXU         | the Connect sequence. Device Mode: Once this                                               |
|       |        |             | bit is set, the device core waits for the HSIC                                             |
|       |        |             | Idle line state on the bus. Upon receiving the                                             |
|       |        |             | Idle line state, it initiates the HSIC Connect                                             |
|       |        |             | sequence. This bit is valid only if                                                        |
|       |        |             | OTG_ENABLE_HSIC is 1, if_sel_hsic = 1 and                                                  |
|       |        |             | InvSelHSIC is 0. Otherwise, it is read-only.                                               |
| 29:28 | RO     | 0x0         | reserved                                                                                   |
|       |        |             | LPM_RetryCnt_Sts                                                                           |
| 27:25 | RO     | 0x0         | LPM Retry Count Status                                                                     |
| 27.23 |        | UXU         | Number of LPM host retries remaining to be                                                 |
|       |        |             | transmitted for the current LPM sequence.                                                  |
|       |        |             | SndLPM                                                                                     |
|       |        |             | Send LPM Transaction                                                                       |
|       |        |             | Host Mode: When the application software sets                                              |
|       |        |             | this bit, an LPM transaction containing two                                                |
|       |        |             | tokens, EXT and LPM, is sent. The hardware                                                 |
| 24    | RW     | 0x0         | clears this bit once a valid response (STALL,                                              |
|       |        |             | NYET, or ACK) is received from the device or                                               |
|       |        |             | the core has finished transmitting the                                                     |
|       |        |             | programmed number of LPM retries. Note: This                                               |
|       |        |             | bit must only be set when the host is connected                                            |
|       |        | 7           | to a local port.                                                                           |
| - (   |        |             | LPM_Retry_Count                                                                            |
|       | $\cup$ |             | LPM Retry Count                                                                            |
| 23:21 | R/WSC  | 0x0         | When the device gives an ERROR response, this is the number of additional LPM retries that |
|       |        |             | the host performs until a valid device response                                            |
|       |        |             | (STALL, NYET, or ACK) is received.                                                         |
|       |        |             | (SIALL, NILI, OI ACK) IS TECEIVEU.                                                         |



| Bit   | Attr | Reset Value | Description                                      |
|-------|------|-------------|--------------------------------------------------|
|       |      |             | LPM_Chnl_Indx                                    |
|       |      |             | LPM Channel Index                                |
|       |      |             | The channel number on which the LPM              |
|       |      |             | transaction must be applied while sending an     |
| 20:17 | RW   | 0x0         | LPM transaction to the local device. Based on    |
|       |      |             | the LPM channel index, the core automatically    |
|       |      |             | inserts the device address and endpoint          |
|       |      |             | number programmed in the corresponding           |
|       |      |             | channel into the LPM transaction.                |
|       |      |             | L1ResumeOK                                       |
|       |      |             | Sleep State Resume OK                            |
|       |      |             | Indicates that the application or host can start |
|       |      |             | a resume from the Sleep state. This bit is valid |
|       |      |             | in the LPM Sleep (L1) state. It is set in Sleep  |
| 16    | RO   | 0x0         | mode after a delay of 50 us (TL1Residency).      |
|       |      |             | The bit is reset when SlpSts is 0                |
|       |      |             | 1'b1: The application/core can start resume      |
|       |      |             | from the Sleep state                             |
|       |      |             | 1'b0: The application/core cannot start          |
|       |      |             | resume from the Sleep state                      |



| Bit | Attr | Reset Value | Description                                       |
|-----|------|-------------|---------------------------------------------------|
|     |      |             | SlpSts                                            |
|     |      |             | Port Sleep Status                                 |
|     |      |             | Device Mode: This bit is set as long as a Sleep   |
|     |      |             | condition is present on the USB bus. The core     |
|     |      |             | enters the Sleep state when an ACK response is    |
|     |      |             | sent to an LPM transaction and the timer          |
|     |      |             | TL1TokenRetry. has expired. To stop the PHY       |
|     |      |             | clock, the application must set the Port Clock    |
|     |      |             | Stop bit, which asserts the PHY Suspend input     |
|     |      |             | pin. The application must rely on SlpSts and      |
|     |      |             | not ACK in CoreL1Res to confirm transition into   |
|     |      |             | sleep.                                            |
|     |      |             | The core comes out of sleep:                      |
|     |      |             | When there is any activity on the USB             |
|     |      |             | line_state                                        |
|     |      |             | When the application writes to the Remote         |
|     |      |             | Wakeup Signaling bit in the Device Control        |
|     |      |             | register (DCTL.RmtWkUpSig) or when the            |
| 15  | RO   | 0x0         | application resets or soft-disconnects the        |
|     |      |             | device.                                           |
|     |      |             | Host Mode: The host transitions to the Sleep      |
|     |      |             | (L1) state as a sideeffect of a successful LPM    |
|     |      |             | transaction by the core to the local port with an |
|     |      |             | ACK response from the device. The read value      |
|     |      | . (         | of this bit reflects the port's current sleep     |
|     |      |             | status. The core clears this bit after:           |
|     |      |             | The core detects a remote L1 Wakeup signal        |
|     |      |             | The application sets the Port Reset bit or the    |
|     | 11   |             | Port L1Resume bit in the HPRT register or         |
|     | CN   | ,           | The application sets the L1Resume/ Remote         |
|     |      |             | Wakeup Detected Interrupt bit or Disconnect       |
|     |      |             | Detected Interrupt bit in the Core Interrupt      |
|     | ~    |             | register (GINTSTS.L1WkUpInt or                    |
| 7   |      |             | GINTSTS.DisconnInt, respectively). Values:        |
|     |      |             | 1'b0: Core not in L1                              |
|     |      |             | 1'b1: Core in L1                                  |
|     |      |             | I DI. COLE III LI                                 |



|       | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14:13 | RO   | 0x0                | CoreL1Res LPM Response Device Mode: The core's response to the received LPM transaction is reflected in these two bits. Host Mode: The handshake response received from the local device for LPM transaction.  11: ACK 10: NYET 01: STALL 00: ERROR (No handshake response)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|       |      |                    | SS. Z. C. C. C. T. G. T. |
|       | 1    |                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |



| Bit  | Attr         | Reset Value         |                            | Description               |             |
|------|--------------|---------------------|----------------------------|---------------------------|-------------|
|      |              | 2 2 22 2            | HIRD_Thres                 | . r                       |             |
|      |              |                     | HIRD Thresho               | old                       |             |
|      |              |                     |                            | The core asserts L1Su     | ispendM to  |
|      |              |                     |                            | nto Deep Low-Power m      | -           |
|      |              |                     | [ ·                        | D value is greater than   |             |
|      |              |                     |                            | ned in this field         | or equal to |
|      |              |                     |                            | RD_Thres[3:0]), and       |             |
|      |              |                     | =                          | 1] is set to 1'b1.        |             |
|      |              |                     | _                          | he core asserts L1Susp    | andM to     |
|      |              |                     |                            | nto Deep Low-Power m      |             |
|      |              |                     | [ ·                        | hres[4] is set to 1'b1.   | lode III LI |
|      |              |                     |                            | 3:0] specifies the time   | for which   |
|      |              |                     |                            | ling is to be reflected b |             |
|      |              |                     | _                          | sume2) on the USB wl      | •           |
|      |              |                     |                            | e-initiated resume. HIF   |             |
|      |              |                     |                            | programmed with a val     |             |
|      |              |                     | -                          | in Host mode, because     | _           |
|      |              |                     |                            | mum TL1HubDrvResur        |             |
|      |              |                     | SI. No HIRD_               |                           | de resume   |
|      |              |                     | time(us)                   | 111165[3.0] 1103(1110     | de resume   |
|      |              |                     | 1                          | 4'b0000                   |             |
|      |              |                     | 60                         | <del>-</del> 50000        |             |
|      |              |                     | 2                          | 4'b0001                   |             |
|      |              |                     | 135                        | 4 D0001                   |             |
|      |              |                     | 3                          | 4'b0010                   |             |
|      |              | • ~ ~               | 210                        | 1 50010                   |             |
| 12:8 | RW           | 0x00                | 4                          | 4'b0011                   |             |
|      |              |                     | 285                        |                           |             |
|      | h /          | ( ) ,               | 5                          | 4'b0100                   |             |
|      |              | 7                   | 360                        |                           |             |
|      |              | ·                   | 6                          | 4'b0101                   |             |
|      |              |                     | 435                        |                           |             |
|      |              |                     | 7                          | 4'b0110                   |             |
|      |              |                     | 510                        |                           |             |
|      |              |                     | 8                          | 4'b0111                   |             |
|      |              |                     | 585                        |                           |             |
|      |              |                     | 9                          | 4'b1000                   |             |
|      |              |                     | 660                        |                           |             |
|      |              |                     | 10                         | 4'b1001                   |             |
|      |              |                     | 735                        |                           |             |
|      |              |                     | 11                         | 4'b1010                   |             |
|      |              |                     | 810                        |                           |             |
|      |              |                     | 12                         | 4'b1011                   |             |
|      |              |                     | 885                        |                           |             |
| Hic  | ıh Performaı | nce and Low-power P | 13<br>rocessor for Digital | Media Application         | 872         |
|      |              |                     | 960                        | ,,                        |             |
|      |              |                     | 14                         | 4'b1101                   |             |
|      |              |                     | invalid                    |                           |             |



| Bit | Attr | Reset Value | Description                                          |
|-----|------|-------------|------------------------------------------------------|
|     |      |             | EnblSlpM                                             |
|     |      |             | Enable utmi_sleep_n                                  |
|     |      |             | For ULPI interface: The application uses this bit    |
|     |      |             | to write to the function control [7] in the L1       |
|     |      |             | state, to enable the PHY to go into Low Power        |
|     |      |             | mode. For the host, this bit is valid only in Local  |
|     |      |             | Device mode.                                         |
|     |      |             | 1'b0: Writes to the ULPI Function Control            |
|     |      |             | Bit[7] are disabled.                                 |
|     |      |             | 1'b1: The core is enabled to write to the ULPI       |
|     |      |             | Function Control Bit[7], which enables the PHY       |
|     |      |             | to enter Low-Power mode.                             |
|     |      |             | Note: When a ULPI interface is configured,           |
|     |      |             | enabling this bit results in a write to Bit 7 of the |
|     |      |             | ULPI Function Control register. The ULPI PHY         |
| 7   | RW   | 0x0         | supports writing to this bit, and in the L1 state    |
|     |      |             | asserts SleepM when utmi_l1_suspend_n                |
|     |      |             | cannot be asserted. When a ULPI interface is         |
|     |      |             | configured, this bit must always be set if you       |
|     |      |             | are using the ULPI PHY. Note: For ULPI               |
|     |      |             | interfaces, do not clear this bit during the         |
|     |      |             | resume. For all other interfaces: The                |
|     |      |             | application uses this bit to control                 |
|     |      |             | utmi_sleep_n assertion to the PHY in the L1          |
|     |      | . (         | state. For the host, this bit is valid only in Local |
|     |      |             | Device mode.                                         |
|     |      |             | 1'b0: utmi_sleep_n assertion from the core is        |
|     |      | ()          | not transferred to the external PHY.                 |
|     | 11   |             | 1'b1: utmi_sleep_n assertion from the core is        |
|     |      | 7           | transferred to the external PHY when                 |
|     |      |             | utmi_l1_suspend_n cannot be asserted.                |
|     |      |             | bRemoteWake                                          |
|     | ~    |             | RemoteWakeEnable                                     |
| 7   |      |             | Host Mode: The remote wakeup value to be             |
| 6   | RW   | 0x0         | sent in the LPM transaction's wIndex field.          |
|     |      |             | Device Mode: This field is updated with the          |
|     |      |             | received bRemoteWake LPM token's                     |
|     |      |             | bmAttribute when an ACK/NYET/STALL                   |
|     |      |             | response is sent to an LPM transaction.              |



| Bit | Attr | Reset Value |                                             | Descriptio                                    | n                   |  |
|-----|------|-------------|---------------------------------------------|-----------------------------------------------|---------------------|--|
|     |      |             | HIRD                                        |                                               |                     |  |
|     |      |             | Host-Initiated Resume Duration              |                                               |                     |  |
|     |      |             | Host Mode: T                                | Host Mode: The value of HIRD to be sent in an |                     |  |
|     |      |             | LPM transaction. This value is also used to |                                               |                     |  |
|     |      |             | initiate resum                              | ne for a duration                             | n                   |  |
|     |      |             | TL1HubDrvRe                                 | esume1 for host                               | initiated resume.   |  |
|     |      |             | Device Mode:                                | This field is up                              | dated with the      |  |
|     |      |             | Received LPM                                | Token HIRD b                                  | mAttribute when     |  |
|     |      |             | an ACK/NYET                                 | /STALL respons                                | e is sent to an LPM |  |
|     |      |             | transaction                                 |                                               |                     |  |
|     |      |             | SI. No                                      | HIRD[3:0]                                     | THIRD (us)          |  |
|     |      |             | 1                                           | 4'b0000                                       | 50                  |  |
|     |      |             | 2                                           | 4'b0001                                       | 125                 |  |
| 5:2 | RW   | 0x0         | 3                                           | 4'b0010                                       | 200                 |  |
|     |      |             | 4                                           | 4'b0011                                       | 275                 |  |
|     |      |             | 5                                           | 4'b0100                                       | 350                 |  |
|     |      |             | 6                                           | 4'b0101                                       | 425                 |  |
|     |      |             | 7                                           | 4'b0110                                       | 500                 |  |
|     |      |             | 8                                           | 4'b0111                                       | 575                 |  |
|     |      |             | 9                                           | 4'b1000                                       | 650                 |  |
|     |      |             | 10                                          | 4'b1001                                       | 725                 |  |
|     |      |             | 11                                          | 4'b1010                                       | 800                 |  |
|     |      |             | 12                                          | 4'b1011                                       | 875                 |  |
|     |      |             | 13                                          | 4'b1100                                       | 950                 |  |
|     |      |             | 14                                          | 4'b1101                                       | 1025                |  |
|     |      |             | 15                                          | 4'b1110                                       | 1100                |  |
|     |      |             | 16                                          | 4'b1111                                       | 1175                |  |



| Bit | Attr | Reset Value | Description                                      |
|-----|------|-------------|--------------------------------------------------|
|     |      |             | AppL1Res                                         |
|     |      |             | LPM response programmed by application           |
|     |      |             | Handshake response to LPM token                  |
|     |      |             | pre-programmed by device application             |
|     |      |             | software. The response depends on                |
|     |      |             | GLPMCFG.LPMCap. If GLPMCFG.LPMCap is             |
|     |      |             | 1'b0, the core always responds with a NYET. If   |
|     |      |             | GLPMCFG.LPMCap is 1'b1, the core responds as     |
|     |      |             | follows:                                         |
|     |      |             | 1: ACK. Even though an ACK is                    |
|     |      |             | pre-programmed, the core responds with an        |
| 1   | RW   | 0x0         | ACK only on a successful LPM transaction. The    |
| 1   | KVV  | UXU         | LPM transaction is successful if: There are no   |
|     |      |             | PID/CRC5 errors in both the EXT token and the    |
|     |      |             | LPM token (else ERROR); A valid bLinkState =     |
|     |      |             | 0001B (L1) is received in the LPM transaction    |
|     |      |             | (else STALL); No data is pending in the          |
|     |      |             | Transmit queue (else NYET)                       |
|     |      |             | 0: NYET. The pre-programmed software bit is      |
|     |      |             | overridden for response to LPM token             |
|     |      |             | when:(1)The received bLinkState is not L1        |
|     |      |             | (STALL response); (2)An error is detected in     |
|     |      |             | either of the LPM token packets due to           |
|     |      |             | corruption (ERROR response).                     |
|     |      |             | LPMCap                                           |
|     |      | 1.5         | LPM-Capable                                      |
|     |      | My y        | The application uses this bit to control the otg |
|     |      | ()          | core LPM capabilities. If the core operates as a |
|     | 11   |             | non-LPM-capable host, it cannot request the      |
|     | CV   | 7           | connected device/hub to activate LPM mode. If    |
|     |      |             | the core operates as a non-LPM-capable           |
| 0   | RW   | 0x0         | device, it cannot respond to any LPM             |
|     | _    |             | transactions.                                    |
| 7   |      |             | 1'b0: LPM capability is not enabled.             |
|     |      |             | 1'b1: LPM capability is enabled.                 |
|     |      |             | This bit is writable only if an LPM mode was     |
|     |      |             | specified for Mode of Operation (parameter       |
|     |      |             | OTG_ENABLE_LPM). Otherwise, reads return         |
|     |      |             | 0.                                               |

# USBOTG\_GPWRDN

Address: Operational Base + offset (0x0058)

Global Power Down Register



| Bit   | Attr | Reset Value | Description                                     |
|-------|------|-------------|-------------------------------------------------|
| 31:29 | RO   | 0x0         | reserved                                        |
|       |      |             | MultValIdBC                                     |
|       |      |             | Multi Valued ID pin                             |
|       |      |             | Battery Charger ACA inputs in the following     |
|       |      |             | order:                                          |
|       |      |             | Bit 26 - rid_float.                             |
|       |      |             | Bit 25 - rid_gnd                                |
| 28:24 | RO   | 0x00        | Bit 24 - rid_a                                  |
|       |      |             | Bit 23 - rid_b                                  |
|       |      |             | Bit 22 - rid_c                                  |
|       |      |             | These bits are present only if                  |
|       |      |             | OTG_BC_SUPPORT = 1.                             |
|       |      |             | Otherwise, these bits are reserved and will     |
|       |      |             | read 5'h0.                                      |
|       |      |             | ADPInt                                          |
| 23    | W1C  | 0x0         | ADP Interupt                                    |
|       |      |             | This bit is set whenever there is a ADP event.  |
|       |      |             | BSessVld                                        |
|       |      |             | B Session Valid                                 |
|       |      |             | This field reflects the B session valid status  |
| 22    | RO   | 0×0         | signal from the PHY.                            |
|       |      | OXO .       | 1'b0: B-Valid is 0.                             |
|       |      |             | 1'b1: B-Valid is 1.                             |
|       |      |             | This bit is valid only when GPWRDN.PMUActv is   |
|       |      |             | 1.                                              |
|       |      |             | IDDIG                                           |
|       |      |             | This bit indicates the status of the signal     |
|       |      | C           | IDDIG. The application must read this bit after |
|       | 11   |             | receiving GPWRDN.StsChngInt and decode          |
| 21    | RO   | 0×0         | based on the previous value stored by the       |
|       |      |             | application. Indicates the current mode.        |
|       |      |             | 1'b1: Device mode                               |
|       | -    |             | 1'b0: Host mode                                 |
| 7     |      |             | This bit is valid only when GPWRDN.PMUActv is   |
|       |      |             | 1.                                              |



| Bit   | Attr       | Reset Value | Description                                     |
|-------|------------|-------------|-------------------------------------------------|
|       |            |             | LineState                                       |
|       |            |             | This field indicates the current linestate on   |
|       |            |             | USB as seen by the PMU module.                  |
|       |            |             | 2'b00: DM = 0, DP = 0.                          |
| 20:19 | RO         | 0x0         | 2'b01: DM = 0, DP = 1.                          |
|       |            |             | 2'b10: DM = 1, DP = 0.                          |
|       |            |             | 2'b11: Not-defined.                             |
|       |            |             | This bit is valid only when GPWRDN.PMUActv is   |
|       |            |             | 1.                                              |
| 18    | RW         | 0×0         | StsChngIntMsk                                   |
| 10    | KVV        | UXU         | Mask For StsChng Interrupt                      |
|       |            |             | StsChngInt                                      |
|       |            |             | This field indicates a status change in either  |
|       |            |             | the IDDIG or BSessVld signal.                   |
|       |            |             | 1'b0: No Status change                          |
| 17    | W1C        | 0.40        | 1'b1: status change detected                    |
| 17    | WIC        | 0x0         | After receiving this interrupt the application  |
|       |            |             | should read the GPWRDN register and             |
|       |            |             | interpret the change in IDDIG or BSesVld with   |
|       |            |             | respect to the previous value stored by the     |
|       |            |             | application.                                    |
| 1.0   | DW         | 00          | SRPDetectMsk                                    |
| 16    | RW         | 0x0         | Mask For SRPDetect Interrupt                    |
|       |            |             | SRPDetect                                       |
|       |            |             | This field indicates that SRP has been detected |
|       |            |             | by the PMU.This field generates an interrupt.   |
|       |            |             | After detecting SRP during hibernation the      |
| 15    | W1C        | 0x0         | application should not restore the core. The    |
|       | <b>\</b> 1 |             | application should get into the initialization  |
|       |            | 7           | process.                                        |
|       |            |             | 1'b0: SRP not detected                          |
|       |            |             | 1'b1: SRP detected                              |
|       |            |             | ConnDetMsk                                      |
| 14    | RW         | 0×0         | Mask for ConnectDet interrupt                   |
| 14    | IVVV       | 0×0         | This bit is valid only when OTG_EN_PWROPT =     |
|       |            |             | 2.                                              |
|       |            |             | ConnectDet                                      |
|       |            |             | This field indicates that a new connect has     |
|       | W1C        |             | been detected                                   |
| 13    |            | 0×0         | 1'b0: Connect not detected                      |
|       |            |             | 1'b1: Connect detected                          |
|       |            |             | This bit is valid only when OTG_EN_PWROPT =     |
|       |            |             | 2.                                              |



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                           |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12  | RW   | 0×0         | DisconnectDetectMsk  Mask For DisconnectDetect Interrupt  This bit is valid only when OTG_EN_PWROPT = 2.                                                                                                                                                                                                                                                              |
| 11  | W1C  | 0×0         | DisconnectDetect This field indicates that Disconnect has been detected by the PMU. This field generates an interrupt. After detecting disconnect during hibernation the application must not restore the core, but instead start the initialization process.  1'b0: Disconnect not detected 1'b1: Disconnect detected This bit is valid only when OTG_EN_PWROPT = 2. |
| 10  | RW   | 0x0         | ResetDetMsk  Mask For ResetDetected interrupt.This bit is valid only when OTG_EN_PWROPT = 2.                                                                                                                                                                                                                                                                          |
| 9   | W1C  | 0x0         | ResetDetected This field indicates that Reset has been detected by the PMU module. This field generates an interrupt. 1'b0: Reset Not Detected 1'b1: Reset Detected This bit is valid only when OTG_EN_PWROPT = 2.                                                                                                                                                    |
| 8   | RW   | 0×0         | LineStageChangeMsk  Mask For LineStateChange interrupt  This bit is valid only when OTG_EN_PWROPT = 2.                                                                                                                                                                                                                                                                |
| 7   | W1C  | 0×0         | LnStsChng Line State Change This interrupt is asserted when there is a Linestate Change detected by the PMU. The application should read GPWRDN.Linestate to determine the current linestate on USB. 1'b0: No LineState change on USB 1'b1: LineState change on USB This bit is valid only when GPWRDN.PMUActv is 1.This bit is valid only when OTG_EN_PWROPT = 2.    |



| Bit | Attr | Reset Value | Description                                      |
|-----|------|-------------|--------------------------------------------------|
|     |      |             | DisableVBUS                                      |
|     |      |             | The application should program this bit if       |
|     |      |             | HPRT0.PrtPwr was programmed to 0 before          |
| 6   | RW   | 0×0         | entering Hibernation. This is to indicate PMU    |
| 0   | KVV  | UXU         | whether session was ended before entering        |
|     |      |             | Hibernation.                                     |
|     |      |             | 1'b0: HPRT0.PrtPwr was not programed to 0.       |
|     |      |             | 1'b1: HPRT0.PrtPwr was programmed to 0.          |
|     |      |             | PwrDnSwtch                                       |
|     |      |             | Power Down Switch                                |
|     |      |             | This bit indicates to the OTG core VDD switch is |
| _   | RW   | 0×0         | in ON/OFF state                                  |
| 5   | KVV  | UXU         | 1'b0: OTG is in ON state                         |
|     |      |             | 1'b1: OTG is in OFF state                        |
|     |      |             | Note: This bit must not be written to during     |
|     |      |             | normal mode of operation.                        |
|     |      |             | PwrDnRst_n                                       |
|     |      |             | Power Down ResetN                                |
|     |      |             | The application must program this bit to reset   |
|     | RW   |             | the OTG core during the Hibernation exit         |
|     |      |             | process or during ADP when powering up the       |
| 4   |      | RW 0x0      | core (in case the OTG core was powered off       |
|     |      |             | during ADP process).                             |
|     |      |             | 1'b1: otg is in normal operation                 |
|     |      |             | 1'b0: reset otg                                  |
|     |      |             | Note: This bit must not be written to during     |
|     |      |             | normal mode of operation.                        |
|     |      |             | PwrDnClmp                                        |
|     | 1    |             | Power Down Clamp                                 |
|     |      | 7           | The application must program this bit to         |
| 3   | RW   | 0×0         | enable or disable the clamps to all the outputs  |
|     | KVV  |             | of the OTG core module to prevent the            |
| 1   |      |             | corruption of other active logic.                |
|     |      |             | 1'b0: Disable PMU power clamp                    |
|     |      |             | 1'b1: Enable PMU power clamp                     |



| Bit | Attr | Reset Value | Description                                                                               |
|-----|------|-------------|-------------------------------------------------------------------------------------------|
|     |      |             | Restore                                                                                   |
|     |      |             | The application should program this bit to                                                |
|     |      |             | enable or disable restore mode from the PMU                                               |
|     |      |             | module.                                                                                   |
| 2   | RW   | 0x0         | 1'b0: OTG in normal mode of operation                                                     |
|     |      |             | 1'b1: OTG in restore mode                                                                 |
|     |      |             | Note: This bit must not be written to during                                              |
|     |      |             | normal mode of operation. This bit is valid only                                          |
|     |      |             | when OTG_EN_PWROPT = 2.                                                                   |
|     |      |             | PMUActv                                                                                   |
|     |      |             | PMU Active                                                                                |
|     |      |             | This is bit is to enable or disable the PMU logic.                                        |
| 1   | RW   | 0x0         | 1'b0: Disable PMU module                                                                  |
|     |      |             | 1'b1: Enable PMU module                                                                   |
|     |      |             | Note: This bit must not be written to during                                              |
|     |      |             | normal mode of operation.                                                                 |
|     |      |             | PMUIntSel                                                                                 |
|     |      |             | PMU Interrupt Select                                                                      |
|     |      |             | When the hibernation functionality is selected                                            |
|     |      |             | using the configuration option                                                            |
|     |      |             | OTG_EN_PWR_OPT = 2, a write to this bit with                                              |
|     |      |             | 1'b1 enables the PMU to generate interrupts to                                            |
| 0   | RW   | 0×0         | the application. During this state all interrupts from the core module are blocked to the |
| 0   | KVV  | OXO .       | application. Note: This bit must be set to 1'b1                                           |
|     |      | • ~ ~       | before the core is put into hibernation                                                   |
|     |      | A A Y       | 1'b0: Internal otg_core interrupt is selected                                             |
|     |      |             | 1'b1: the external otg_pmu interrupt is                                                   |
|     | A 4  |             | selected                                                                                  |
|     |      | 7           | Note: This bit must not be written to during                                              |
|     |      | Y           | normal mode of operation.                                                                 |

### **USBOTG\_GDFIFOCFG**

Address: Operational Base + offset (0x005c)

Global DFIFO Software Config Register

| Bit   | Attr | Reset Value | Description                                     |
|-------|------|-------------|-------------------------------------------------|
|       |      |             | EPInfoBaseAddr                                  |
| 31:16 | RW   | 0x0000      | This field provides the start address of the EP |
|       |      |             | info controller.                                |



| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0 | RW   | 0x0000      | GDFIFOCfg This field is for dynamic programming of the DFIFO Size. This value takes effect only when the application programs a non zero value to this register. The core does not have any corrective logic if the FIFO sizes are programmed incorrectly. |

# USBOTG\_GADPCTL

Address: Operational Base + offset (0x0060) ADP Timer, Control and Status Register

| Bit      | Attr  | Reset Value                           | Description                                    |
|----------|-------|---------------------------------------|------------------------------------------------|
| 31:29    | RO    | 0x0                                   | reserved                                       |
|          |       |                                       | AR                                             |
|          |       |                                       | Access Request                                 |
|          |       |                                       | 2'b00 Read/Write Valid (updated by the         |
| 28:27    | R/WSC | 0x0                                   | core)                                          |
|          |       |                                       | 2'b01 Read                                     |
|          |       |                                       | 2'b10 Write                                    |
|          |       |                                       | 2'b11 Reserved                                 |
|          |       |                                       | AdpTmoutMsk                                    |
|          |       |                                       | ADP Timeout Interrupt Mask                     |
| 26       | RW    | 0x0                                   | When this bit is set, it unmasks the interrupt |
|          |       |                                       | because of AdpTmoutInt. This bit is valid only |
|          |       | . ()                                  | if OTG_Ver = 1'b1(GOTGCTL[20]).                |
|          |       | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | AdpSnsIntMsk                                   |
|          |       |                                       | ADP Sense Interrupt Mask                       |
| 25       | RW    | 0x0                                   | When this bit is set, it unmasks the interrupt |
|          | 1     |                                       | due to AdpSnsInt. This bit is valid only if    |
|          | 63    | ,                                     | OTG_Ver = 1'b1(GOTGCTL[20]).                   |
| /        |       |                                       | AdpPrbIntMsk                                   |
| $\Omega$ |       |                                       | ADP Probe Interrupt Mask                       |
| 24       | RW    | 0x0                                   | When this bit is set, it unmasks the interrupt |
| <b>Y</b> |       |                                       | due to AdpPrbInt.This bit is valid only if     |
|          |       |                                       | $OTG_Ver = 1'b1(GOTGCTL[20]).$                 |



| Bit | Attr   | Reset Value | Description                                        |
|-----|--------|-------------|----------------------------------------------------|
|     |        |             | AdpTmoutInt                                        |
|     |        |             | ADP Timeout Interrupt                              |
|     |        |             | This bit is relevant only for an ADP probe.        |
|     |        |             | When this bit is set, it means that the            |
| 22  | W/1 C  | 00          | ramp time has completed (GADPCTL.RTIM has          |
| 23  | W1C    | 0x0         | reached its terminal value of                      |
|     |        |             | 0x7FF). This is a debug feature that allows        |
|     |        |             | software to read the ramp time after               |
|     |        |             | each cycle. This bit is valid only if OTG_Ver =    |
|     |        |             | 1'b1.                                              |
|     |        |             | AdpSnsInt                                          |
|     |        |             | ADP Sense Interrupt                                |
| 22  | W/1 C  | 00          | When this bit is set, it means that the VBUS       |
| 22  | W1C    | 0x0         | voltage is greater than VadpSns                    |
|     |        |             | value or VadpSns is reached. This bit is valid     |
|     |        |             | only if OTG_Ver = 1'b1 (GOTGCTL[20]).              |
|     |        |             | AdpPrbInt                                          |
|     |        |             | ADP Probe Interrupt                                |
| 21  | W1C    | 0.40        | When this bit is set, it means that the VBUS       |
| 21  | W1C    | 0×0         | voltage is greater than VadpPrb or                 |
|     |        |             | VadpPrb is reached. This bit is valid only if      |
|     |        |             | OTG_Ver = 1'b1 (GOTGCTL[20]).                      |
|     |        |             | ADPEn                                              |
|     | RW     | 0x0         | ADP Enable                                         |
| 20  |        |             | When set, the core performs either ADP             |
| 20  |        |             | probing or sensing based on EnaPrb or              |
|     |        |             | EnaSns. This bit is valid only if OTG_Ver = 1'b1   |
|     |        |             | (GOTGCTL[20]).                                     |
|     | 11     |             | ADPRes                                             |
|     |        |             | ADP Reset                                          |
| 19  | R/WSC  | 0×0         | When set, ADP controller is reset. This bit is     |
|     | ,,,,,, | UXU         | auto-cleared after the reset procedure is          |
|     | ·      |             | complete in ADP controller. This bit is valid only |
| 7   |        |             | if OTG_Ver = 1'b1 (GOTGCTL[20]).                   |
|     |        |             | EnaSns                                             |
|     |        | 0×0         | Enable Sense                                       |
| 18  | RW     |             | When programmed to 1'b1, the core performs         |
|     |        |             | a sense operation. This bit is valid only if       |
|     |        |             | $OTG_Ver = 1'b1 (GOTGCTL[20]).$                    |



prb\_per== 2'b10 => 800 ADP clocks prb\_per==2'b11 => 1000 ADP clocks)



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                         |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:2 | RW   | 0x0         | PrbDelta Probe Delta These bits set the resolution for RTIM value. The bits are defined in units of 32 kHz clock cycles as follows: 2'b00 - 1 cycles 2'b01 - 2 cycles 2'b10 - 3 cycles 2'b11 - 4 cycles For example if this value is chosen to 2'b01, it means that RTIM increments for every three |
| 1:0 | RW   | 0×0         | PrbDschg Probe Discharge These bits set the times for TadpDschg. These bits are defined as follows:  2'b00 4 msec (Scaledown 2 32Khz clock cycles)  2'b01 8 msec (Scaledown 4 32Khz clock cycles)  2'b10 16 msec (Scaledown 8 32Khz clock cycles)  2'b11 32 msec (Scaledown 16 32Khz clock cycles)  |

#### **USBOTG\_HPTXFSIZ**

Address: Operational Base + offset (0x0100) Host Periodic Transmit FIFO Size Register



| Bit   | Attr | Reset Value | Description                                      |
|-------|------|-------------|--------------------------------------------------|
|       |      |             | PTxFSize                                         |
|       |      |             | Host Periodic TxFIFO Depth                       |
|       |      |             | This value is in terms of 32-bit words.          |
|       |      |             | Minimum value is 16                              |
|       |      |             | Maximum value is 32,768                          |
|       |      |             | The power-on reset value of this register is     |
|       |      |             | specified as the Largest Host Mode Periodic Tx   |
|       |      |             | Data FIFO Depth (parameter                       |
| 31:16 | RW   | 0x0000      | OTG_TX_HPERIO_DFIFO_DEPTH). If Enable            |
|       |      |             | Dynamic FIFO Sizing? was deselected              |
|       |      |             | (parameter OTG_DFIFO_DYNAMIC = 0), these         |
|       |      |             | flops are optimized, and reads returnthe         |
|       |      |             | power-on value. If Enable Dynamic FIFO Sizing?   |
|       |      |             | was selected (parameter                          |
|       |      |             | OTG_DFIFO_DYNAMIC = 1), you can write a          |
|       |      |             | new value in this field. Programmed values       |
|       |      |             | must not exceed the power-on value .             |
|       |      |             | PTxFStAddr                                       |
|       |      |             | Host Periodic TxFIFO Start Address               |
|       |      |             | The power-on reset value of this register is the |
|       |      |             | sum of the Largest Rx Data FIFO Depth and        |
|       |      |             | Largest Non-periodic Tx Data FIFO Depth          |
|       |      |             | specified.                                       |
|       |      |             | These parameters are:                            |
|       |      |             | In shared FIFO operation:                        |
|       |      | 1           | OTG_RX_DFIFO_DEPTH +                             |
|       |      | A           | OTG_TX_NPERIO_DFIFO_DEPTH.                       |
| 15:0  | RW   | 0x0000      | In dedicated FIFO mode:                          |
|       | A 4  |             | OTG_RX_DFIFO_DEPTH +                             |
|       |      |             | OTG_TX_HNPERIO_DFIFO_DEPTH.                      |
|       |      | 7           | If Enable Dynamic FIFO Sizing? was deselected    |
|       |      |             | (parameter OTG_DFIFO_DYNAMIC = $0$ ), these      |
| V     |      |             | flops are optimized, and reads return the        |
| -     |      |             | power-on value.                                  |
|       |      |             | If Enable Dynamic FIFO Sizing? was selected      |
|       |      |             | (parameter OTG_DFIFO_DYNAMIC = 1), you           |
|       |      |             | can write a new value in this field. Programmed  |
|       |      |             | values must not exceed the power-on value.       |

### **USBOTG\_DIEPTXFn**

Address: Operational Base + offset (0x0104 + 0x4 \* n)  $0 \le n \le 14$ 

Device Periodic Transmit FIFO-n Size Register

| 1 | Device Feriodic Transmit Fir O II Size Register |      |                    |             |  |
|---|-------------------------------------------------|------|--------------------|-------------|--|
|   | Bit                                             | Attr | <b>Reset Value</b> | Description |  |



power-on value set.



#### **USBOTG\_HCFG**

Address: Operational Base + offset (0x0400)

Host Configuration Register

| Bit   | Attr | Reset Value | Description                                       |
|-------|------|-------------|---------------------------------------------------|
| 31:27 | RO   | 0x0         | reserved                                          |
|       |      |             | PerSchedEna                                       |
|       |      |             | Enable Periodic Scheduling                        |
|       |      |             | Applicable in Scatter/Gather DMA mode only.       |
|       |      |             | Enables periodic scheduling within the core.      |
|       |      |             | Initially, the bit is reset. The core will not    |
|       |      |             | process any periodic channels. As soon as this    |
|       |      |             | bit is set, the core will get ready to start      |
|       |      |             | scheduling periodic channels and sets             |
| 26    | RW   | 0×0         | HCFG.PerSchedStat. The setting of                 |
| 20    |      |             | HCFG.PerSchedStat indicates the core has          |
|       |      |             | enabled periodic scheduling. Once                 |
|       |      |             | HCFG.PerSchedEna is set, the application is       |
|       |      |             | not supposed to again reset the bit unless        |
|       |      |             | HCFG.PerSchedStat is set. As soon as this bit is  |
|       |      |             | reset, the core will get ready to stop scheduling |
|       |      |             | periodic channels and resets                      |
|       |      |             | HCFG.PerSchedStat. In non Scatter/Gather          |
|       |      |             | DMA mode, this bit is reserved.                   |
|       |      |             | FrListEn                                          |
|       |      | • 1         | Frame List Entries                                |
| 25:24 | RW   | 0x0         | The value in the register specifies the number    |
|       |      |             | of entries in the Frame list. This field is valid |
|       |      |             | only in Scatter/Gather DMA mode.                  |



| Bit   | Attr   | Reset Value | Description                                        |
|-------|--------|-------------|----------------------------------------------------|
| _     |        |             | DescDMA                                            |
|       |        |             | Enable Scatter/gather DMA in Host mode             |
|       |        |             | When the Scatter/Gather DMA option selected        |
|       |        |             | during configuration of the RTL, the               |
|       |        |             | application can set this bit during initialization |
|       |        |             | to enable the Scatter/Gather DMA operation.        |
|       |        |             | NOTE: This bit must be modified only once          |
|       |        |             | after a reset. The following combinations are      |
|       |        |             | available for programming:                         |
| 23    | RW     | 0x0         | GAHBCFG.DMAEn=0, HCFG.DescDMA=0 =>                 |
|       |        |             | Slave mode                                         |
|       |        |             | GAHBCFG.DMAEn=0, HCFG.DescDMA=1 =>                 |
|       |        |             | Invalid                                            |
|       |        |             | GAHBCFG.DMAEn=1, HCFG.DescDMA=0 =>                 |
|       |        |             | Buffered DMA mode                                  |
|       |        |             | GAHBCFG.DMAEn=1, HCFG.DescDMA=1 =>                 |
|       |        |             | Scatter/Gather DMA mode                            |
|       |        |             | In non Scatter/Gather DMA mode, this bit is        |
|       |        |             | reserved.                                          |
| 22:16 | RO     | 0x0         | reserved                                           |
|       |        |             | ResValid                                           |
|       |        |             | Resume Validation Period                           |
|       |        |             | This field is effective only when                  |
| 15:8  | RW     | 0x00        | HCFG.Ena32KHzS is set. It controls the             |
|       |        | • 0         | resume period when the core resumes from           |
|       |        |             | suspend. The core counts the ResValid number       |
|       |        |             | of clock cycles to detect a valid resume when      |
|       |        |             | this is set. Ena32KHzS                             |
|       |        |             | Enable 32-KHz Suspend Mode                         |
|       |        | Y           | This bit can only be set if the USB 1.1            |
|       |        |             | Full-Speed Serial Transceiver Interface has        |
| Q'    | $\cup$ |             | been selected. If USB 1.1 Full-Speed Serial        |
| 7     | RW     | 0×0         | Transceiver Interface has not been selected,       |
|       |        |             | this bit must be zero. When the USB 1.1            |
|       |        |             | Full-Speed Serial Transceiver Interface is         |
|       |        |             | chosen and this bit is set, the core expects the   |
|       |        |             | 48-MHz PHY clock to be switched to 32 KHz          |
|       |        |             | during a suspend.                                  |
| 6:3   | RO     | 0x0         | reserved                                           |



| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | RW   | 0x0         | FSLSSupp FS- and LS-Only Support The application uses this bit to control the core enumeration speed. Using this bit, the application can make the core enumerate as a FS host, even if the connected device supports HS traffic. Do not make changes to this field after initial programming.  1'b0: HS/FS/LS, based on the maximum speed supported by the connected device  1'b1: FS/LS-only, even if the connected device can support HS |
| 1:0 | RW   | 0x0         | FSLSPclkSel FS/LS PHY Clock Select 2'b00: PHY clock is running at 30/60 MHz 2'b01: PHY clock is running at 48 MHz Others: Reserved                                                                                                                                                                                                                                                                                                          |

#### **USBOTG\_HFIR**

Address: Operational Base + offset (0x0404)

Host Frame Interval Register

Rockchil

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



| Bit         | Attr | Reset Value         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------|------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit<br>15:0 | Attr | Reset Value  0×0000 | FrInt Frame Interval The value that the application programs to this field specifies the interval between two consecutive SOFs (FS) or micro-SOFs (HS) or Keep-Alive tokens (HS). This field contains the number of PHY clocks that constitute the required frame interval. The default value set in this field for a FS operation when the PHY clock frequency is 60 MHz. The application can write a value to this register only after the Port Enable bit of the Host Port Control and Status register (HPRT.PrtEnaPort) has been set. If no value is programmed, the core calculates the |
|             |      |                     | Enable bit of the Host Port Control and Status register (HPRT.PrtEnaPort) has been set. If no value is programmed, the core calculates the value based on the PHY clock specified in the FS/LS PHY Clock Select field of the Host                                                                                                                                                                                                                                                                                                                                                            |
|             |      |                     | Configuration register (HCFG.FSLSPclkSel).  Do not change the value of this field after the initial configuration.  125 us * (PHY clock frequency for HS)  1 ms * (PHY clock frequency for FS/LS)                                                                                                                                                                                                                                                                                                                                                                                            |

# **USBOTG\_HFNUM**

Address: Operational Base + offset (0x0408)

Host Frame Number/Frame Time Remaining Register

| Bit      | Attr      | Reset Value | Description                                         |
|----------|-----------|-------------|-----------------------------------------------------|
|          |           |             | FrRem                                               |
|          |           |             | Frame Time Remaining                                |
|          | 1         |             | Indicates the amount of time remaining in the       |
|          |           | <del></del> | current microframe (HS) or frame (FS/LS), in        |
| 31:16    | RO        | 0x0000      | terms of PHY clocks. This field decrements on       |
|          |           |             | each PHY clock. When it reaches zero, this field    |
|          | ,         |             | is reloaded with the value in the Frame Interval    |
| <b>Y</b> |           |             | register and a new SOF is transmitted on the        |
|          |           |             | USB.                                                |
|          |           |             | FrNum                                               |
|          |           |             | Frame Number                                        |
|          |           |             | This field increments when a new SOF is             |
| 15:0     | RO 0xffff | 0xffff      | transmitted on the USB, and is reset to 0 when      |
| 13.0     | KO        | OXIIII      | it reaches 16'h3FFF. This field is writable only if |
|          |           |             | Remove Optional Features? was not selected          |
|          |           |             | $(OTG_RM_OTG_FEATURES = 0)$ . Otherwise,            |
|          |           |             | reads return the frame number value.                |



Address: Operational Base + offset (0x0410) Host Periodic Transmit FIFO/Queue Status Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      |             | PTxQTop                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 31:24 | RO   | 0×00        | Top of the Periodic Transmit Request Queue This indicates the entry in the Periodic Tx Request Queue that is currently being processes by the MAC. This register is used for debugging. Bit [31]: Odd/Even (micro)frame 1'b0: send in even (micro)frame 1'b1: send in odd (micro)frame Bits [30:27]: Channel/endpoint number Bits [26:25]: Type 2'b00: IN/OUT 2'b01: Zero-length packet 2'b10: CSPLIT 2'b11: Disable channel command Bit [24]: Terminate (last entry for the selected channel/endpoint) |
| 23:16 | RO   | 0×00        | PTxQSpcAvail Periodic Transmit Request Queue Space Available Indicates the number of free locations available to be written in the Periodic Transmit Request Queue. This queue holds both IN and OUT requests. 8'h0: Periodic Transmit Request Queue is full 8'h1: 1 location available 8'h2: 2 locations available n: n locations available (0 <=n <= 16) Others: Reserved                                                                                                                             |



| Bit  | Attr | Reset Value | Description                                 |
|------|------|-------------|---------------------------------------------|
|      |      |             | PTxFSpcAvail                                |
|      |      |             | Periodic Transmit Data FIFO Space Available |
|      |      |             | Indicates the number of free locations      |
|      |      |             | available to be written to in the Periodic  |
|      | RW   | 0×0000      | TxFIFO. Values are in terms of 32-bit words |
| 15:0 |      |             | . 16'h0: Periodic TxFIFO is full            |
| 15.0 |      |             | . 16'h1: 1 word available                   |
|      |      |             | . 16'h2: 2 words available                  |
|      |      |             | . 16'hn: n words available (where 0 . n .   |
|      |      |             | 32,768)                                     |
|      |      |             | . 16'h8000: 32,768 words available          |
|      |      |             | . Others: Reserved                          |

#### **USBOTG\_HAINT**

Address: Operational Base + offset (0x0414)

Host All Channels Interrupt Reigster

| Bit   | Attr | Reset Value | Description                                      |
|-------|------|-------------|--------------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                         |
|       | RO   | 0×0000      | HAINT                                            |
| 15.0  |      |             | Channel Interrupts                               |
| 15:0  |      |             | One bit per channel: Bit 0 for Channel 0, bit 15 |
|       |      |             | for Channel 15                                   |

#### **USBOTG\_HAINTMSK**

Address: Operational Base + offset (0x0418)

Host All Channels Interrupt Mask Register

| Bit   | Attr | Reset Value | Description                                      |
|-------|------|-------------|--------------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                         |
|       | 1    |             | HAINTMsk                                         |
| 15.0  | RW   | 10x0000     | Channel Interrupt Mask                           |
| 15:0  |      |             | One bit per channel: Bit 0 for channel 0, bit 15 |
|       |      |             | for channel 15                                   |

#### **USBOTG\_HPRT**

Address: Operational Base + offset (0x0440)

Host Port Control and Status Register

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



| Bit   | Attr  | Reset Value | Description                                       |
|-------|-------|-------------|---------------------------------------------------|
|       |       |             | PrtSpd                                            |
|       |       |             | Port Speed                                        |
|       |       |             | Indicates the speed of the device attached to     |
| 18:17 | RO    | 0×0         | this port.                                        |
| 10.17 | KU    | UXU         | 2'b00: High speed                                 |
|       |       |             | 2'b01: Full speed                                 |
|       |       |             | 2'b10: Low speed                                  |
|       |       |             | 2'b11: Reserved                                   |
|       |       |             | PrtTstCtl                                         |
|       |       |             | Port Test Control                                 |
|       |       |             | The application writes a nonzero value to this    |
|       |       |             | field to put the port into a Test mode, and the   |
|       |       |             | corresponding pattern is signaled on the port.    |
| 16:13 | RW    | 0×0         | 4'b0000: Test mode disabled                       |
| 10.15 | IXVV  | 0.00        | 4'b0001: Test_J mode                              |
|       |       |             | 4'b0010: Test_K mode                              |
|       |       |             | 4'b0011: Test_SE0_NAK mode                        |
|       |       |             | 4'b0100: Test_Packet mode                         |
|       |       |             | 4'b0101: Test_Force_Enable                        |
|       |       |             | Others: Reserved                                  |
|       |       |             | PrtPwr                                            |
|       | R/WSC | 0×0         | Port Power                                        |
|       |       |             | The application uses this field to control power  |
| 12    |       |             | to this port (write 1'b1 to set to 1'b1and write  |
|       | .,    | • (         | 1'b0 to set to 1'b0), and the core can clear this |
|       |       |             | bit on an over current condition.                 |
|       |       | V A         | 1'b0: Power off                                   |
|       |       |             | 1'b1: Power on                                    |
|       | 11    |             | PrtLnSts                                          |
| 44.40 | DC 3  | 0.0         | Port Line Status                                  |
| 11:10 | RO    | 0x0         | Indicates the current logic level USB data lines  |
|       |       |             | Bit [10]: Logic level of D+                       |
|       |       |             | Bit [11]: Logic level of D                        |
| 9     | RO    | 0x0         | reserved                                          |



| Bit | Attr  | Reset Value | Description                                       |
|-----|-------|-------------|---------------------------------------------------|
|     |       |             | PrtRst                                            |
|     |       |             | Port Reset                                        |
|     |       |             | When the application sets this bit, a reset       |
|     |       |             | sequence is started on this port. The             |
|     |       |             | application must time the reset period and        |
|     |       |             | clear this bit after the reset sequence is        |
|     |       |             | complete.                                         |
|     |       |             | 1'b0: Port not in reset                           |
|     |       |             | 1'b1: Port in reset                               |
|     |       |             | To start a reset on the port, the application     |
| 8   | RW    | 0x0         | must leave this bit set for at least the          |
|     |       |             | minimum duration mentioned below, as              |
|     |       |             | specified in the USB 2.0 specification,           |
|     |       |             | Section 7.1.7.5. The application can leave it     |
|     |       |             | set for another 10 ms in addition to the          |
|     |       |             | required minimum duration, before clearing        |
|     |       |             | the bit, even though there is no                  |
|     |       |             | maximum limit set by the USB standard.            |
|     |       |             | High speed: 50 ms                                 |
|     |       |             | Full speed/Low speed: 10 ms                       |
|     |       | 0x0         | PrtSusp                                           |
|     |       |             | Port Suspend                                      |
|     |       |             | The application sets this bit to put this port in |
|     |       |             | Suspend mode. The core only stops sending         |
|     |       |             | SOFs when this is set. To stop the PHY clock,     |
| 7   |       |             | the application must set the Port Clock Stop      |
|     | R/WSC |             | bit, which asserts the suspend input pin of the   |
|     |       |             | PHY.                                              |
|     |       |             | The read value of this bit reflects the current   |
|     |       |             | suspend status of the port. This bit is cleared   |
|     |       |             | by the core after a remote wakeup signal is       |
|     |       |             | detected or the application sets the Port Reset   |
|     |       |             | bit or Port Resume bit in this register or the    |
| -   |       |             | Resume/Remote Wakeup Detected Interrupt           |
|     |       |             | bit or Disconnect Detected Interrupt bit in the   |
|     |       |             | Core Interrupt register (GINTSTS.WkUpInt or       |
|     |       |             | GINTSTS.DisconnInt, respectively).                |
|     |       |             | 1'b0: Port not in Suspend mode                    |
|     |       |             | 1'b1: Port in Suspend mode                        |



register changes.



| Bit      | Attr | Reset Value | Description                                      |
|----------|------|-------------|--------------------------------------------------|
|          |      |             | PrtOvrCurrAct                                    |
|          |      |             | Port Overcurrent Active                          |
| 4        | RO   | 0x0         | Indicates the overcurrent condition of the port. |
|          |      |             | 1'b0: No overcurrent condition                   |
|          |      |             | 1'b1: Overcurrent condition                      |
|          |      |             | PrtEnChng                                        |
|          |      |             | Port Enable/Disable Change                       |
| 3        | W1C  | 0x0         | The core sets this bit when the status of the    |
|          |      |             | Port Enable bit [2] of this register             |
|          |      |             | changes.                                         |
|          |      |             | PrtEna                                           |
|          |      |             | Port Enable                                      |
|          |      |             | A port is enabled only by the core after a reset |
|          |      |             | sequence, and is disabled by an                  |
|          |      |             | overcurrent condition, a disconnect condition,   |
| 2        | W1C  | 0x0         | or by the application clearing this bit.The      |
| _        | WIC  | 0.00        | application cannot set this bit by a register    |
|          |      |             | write. It can only clear it to disable the port. |
|          |      |             | This bit does not trigger any interrupt to the   |
|          |      |             | application.                                     |
|          |      |             | 1'b0: Port disabled                              |
|          |      |             | 1'b1: Port enabled                               |
|          |      |             | PrtConnDet                                       |
| 1        |      |             | Port Connect Detected                            |
|          |      | . ()        | The core sets this bit when a device connection  |
|          | W1C  | 0×0         | is detected to trigger an interrupt to the       |
|          |      |             | application using the Host Port Interrupt bit of |
|          |      | CY          | the Core Interrupt register                      |
|          | 11   |             | (GINTSTS.PrtInt). The application must write a   |
|          | N    | 7           | 1 to this bit to clear the interrupt.            |
|          |      |             | PrtConnSts                                       |
| 0        | RO   | 0×0         | Port Connect Status                              |
|          | ,    |             | 0: No device is attached to the port.            |
| <b>Y</b> |      |             | 1: A device is attached to the port.             |

### **USBOTG\_HCCHARn**

Address: Operational Base + offset (0x0500 + 0x20 \* n)0≤n≤15

Host Channel-n Characteristics Register

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
|-----|------|-------------|-------------|



| Bit   | Attr    | Reset Value | Description                                                                |
|-------|---------|-------------|----------------------------------------------------------------------------|
|       |         |             | ChEna                                                                      |
|       |         |             | Channel Enable                                                             |
|       |         |             | When Scatter/Gather mode is enabled                                        |
|       |         |             | 1'b0: Indicates that the descriptor structure                              |
|       |         |             | is not yet ready.                                                          |
|       |         |             | 1'b1: Indicates that the descriptor structure                              |
| 31    | R/WSC   | 0x0         | and data buffer with data is setup and this                                |
|       |         |             | channel can access the descriptor.                                         |
|       |         |             | When Scatter/Gather mode is disabled, This                                 |
|       |         |             | field is set by the application and cleared by                             |
|       |         |             | the OTG host.                                                              |
|       |         |             | 1'b0: Channel disabled                                                     |
|       |         |             | 1'b1: Channel enabled                                                      |
|       |         |             | ChDis                                                                      |
|       |         |             | Channel Disable                                                            |
|       |         |             | The application sets this bit to stop                                      |
| 30    | R/WSC   | 0×0         | transmitting/receiving data on a channel,                                  |
|       | liy WSC | UXU         | even before the transfer for that channel is                               |
|       |         |             | complete. The application must wait for the                                |
|       |         |             | Channel Disabled interrupt before treating the                             |
|       |         |             | channel as disabled.                                                       |
|       |         |             | OddFrm                                                                     |
|       |         |             | Odd Frame                                                                  |
|       |         |             | This field is set (reset) by the application to                            |
|       |         | • 1         | indicate that the OTG host must perform a                                  |
|       |         |             | transfer in an odd (micro)frame. This field is                             |
| 29    | RW      | 0×0         | applicable for only periodic (isochronous and                              |
|       |         |             | interrupt) transactions.                                                   |
|       | 11      |             | 1'b0: Even (micro)frame                                                    |
|       | 63      |             | 1'b1: Odd (micro)frame                                                     |
|       |         |             | This field is not applicable for Scatter/Gather                            |
|       |         |             | DMA mode and need not be programmed by                                     |
|       | /       |             | the application and is ignored by the core.                                |
| 7     |         |             | DevAddr                                                                    |
| 28:22 | RW      | 0x00        | Device Address  This field selects the specific device serving as          |
|       |         |             | This field selects the specific device serving as the data source or sink. |
|       | ]       |             | the data source of Silik.                                                  |



| MC_EC Multi Count (MC) / Error Count (EC) When the Split Enable bit of the Host Channel-n Split Control register (HCSPLTn.SpltEna) is reset (1'b0), this field indicates to the host the number of transactions that must be executed per microframe for this periodic endpoint. For non periodic transfers, this field is used only in DMA mode, and specifies the number packets to be fetched for this channel before the internal DMA engine changes arbitration. 2'b00: Reserved This field yields undefined results. 2'b01: 1 transaction 2'b10: 2 transactions to be issued for this endpoint per microframe 2'b11: 3 transactions to be issued for this endpoint per microframe When HCSPLTn.SpltEna is set (1'b1), this field indicates the number of immediate retries to be performed for a periodic split transactions on transaction errors. This field must be set to at least 2'b01.  EPType Endpoint Type Indicates the transfer type selected. 2'b00: Control 2'b01: Isochronous 2'b10: Bulk 2'b11: Interrupt  LSpdDev Low-Speed Device  17 RW 0x0 This field is set by the application to indicate that this channel is communicating to a low-speed device.  16 RO 0x0 reserved  EPDir Endpoint Direction | Bit   | Attr   | Reset Value | Description                                    |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|-------------|------------------------------------------------|
| When the Split Enable bit of the Host Channel-n Split Control register (HCSPLTn.SpltEna) is reset (1'b0), this field indicates to the host the number of transactions that must be executed per microframe for this periodic endpoint. For non periodic transfers, this field is used only in DMA mode, and specifies the number packets to be fetched for this channel before the internal DMA engine changes arbitration. 2'b00: Reserved This field yields undefined results. 2'b01: 1 transaction 2'b10: 2 transactions to be issued for this endpoint per microframe 2'b11: 3 transactions to be issued for this endpoint per microframe When HCSPLTn.SpltEna is set (1'b1), this field indicates the number of immediate retries to be performed for a periodic split transactions on transaction errors. This field must be set to at least 2'b01.  EPType Endpoint Type Indicates the transfer type selected. 2'b00: Control 2'b01: Isochronous 2'b10: Bulk 2'b11: Interrupt  LSpdDev Low-Speed Device This field is set by the application to indicate that this channel is communicating to a low-speed device.  16 RO 0x0 reserved EPDir                                                                          |       |        |             | MC_EC                                          |
| Channel-n Split Control register (HCSPLTn.SpltEna) is reset (1'b0), this field indicates to the host the number of transactions that must be executed per microframe for this periodic endpoint. For non periodic transfers, this field is used only in DMA mode, and specifies the number packets to be fetched for this channel before the internal DMA engine changes arbitration.  2'b00: Reserved This field yields undefined results.  2'b01: 1 transaction  2'b10: 2 transactions to be issued for this endpoint per microframe  2'b11: 3 transactions to be issued for this endpoint per microframe  When HCSPLTn.SpltEna is set (1'b1), this field indicates the number of immediate retries to be performed for a periodic split transactions on transaction errors. This field must be set to at least 2'b01.  EPType Endpoint Type Indicates the transfer type selected.  2'b00: Control 2'b01: Isochronous 2'b10: Bulk 2'b11: Interrupt  LSpdDev Low-Speed Device  This field is set by the application to indicate that this channel is communicating to a low-speed device.  16 RO 0x0 reserved  EPDir                                                                                                        |       |        |             | Multi Count (MC) / Error Count (EC)            |
| (HCSPLTn.SpltEna) is reset (1'b0), this field indicates to the host the number of transactions that must be executed per microframe for this periodic endpoint. For non periodic transfers, this field is used only in DMA mode, and specifies the number packets to be fetched for this channel before the internal DMA engine changes arbitration.  2'b00: Reserved This field yields undefined results.  2'b01: 1 transaction  2'b10: 2 transactions to be issued for this endpoint per microframe  2'b11: 3 transactions to be issued for this endpoint per microframe  When HCSPLTn.SpltEna is set (1'b1), this field indicates the number of immediate retries to be performed for a periodic split transactions on transaction errors. This field must be set to at least 2'b01.  EPType Endpoint Type Indicates the transfer type selected.  2'b00: Control  2'b01: Isochronous  2'b10: Bulk  2'b11: Interrupt  LSpdDev  Low-Speed Device  This field is set by the application to indicate that this channel is communicating to a low-speed device.  16 RO 0x0 reserved  EPDir                                                                                                                                     |       |        |             | When the Split Enable bit of the Host          |
| indicates to the host the number of transactions that must be executed per microframe for this periodic endpoint. For non periodic transfers, this field is used only in DMA mode, and specifies the number packets to be fetched for this channel before the internal DMA engine changes arbitration.  2'b00: Reserved This field yields undefined results.  2'b01: 1 transaction  2'b10: 2 transactions to be issued for this endpoint per microframe  2'b11: 3 transactions to be issued for this endpoint per microframe  When HCSPLTn.SpitEna is set (1'b1), this field indicates the number of immediate retries to be performed for a periodic split transactions on transaction errors. This field must be set to at least 2'b01.  EPType Endpoint Type Indicates the transfer type selected.  2'b00: Control  2'b00: Control  2'b01: Isochronous  2'b10: Bulk  2'b11: Interrupt  LSpdDev  Low-Speed Device  17 RW 0x0 reserved  EPDir                                                                                                                                                                                                                                                                               |       |        |             | Channel-n Split Control register               |
| transactions that must be executed per microframe for this periodic endpoint. For non periodic transfers, this field is used only in DMA mode, and specifies the number packets to be fetched for this channel before the internal DMA engine changes arbitration.  2'b00: Reserved This field yields undefined results.  2'b01: 1 transaction  2'b10: 2 transactions to be issued for this endpoint per microframe  2'b11: 3 transactions to be issued for this endpoint per microframe  When HCSPLTn.SpltEna is set (1'b1), this field indicates the number of immediate retries to be performed for a periodic split transactions on transaction errors. This field must be set to at least 2'b01.  EPType Endpoint Type Indicates the transfer type selected.  2'b10: Bulk  2'b11: Interrupt  LSpdDev  Low-Speed Device  This field is set by the application to indicate that this channel is communicating to a low-speed device.  16 RO 0x0 reserved  EPDir                                                                                                                                                                                                                                                           |       |        |             | (HCSPLTn.SpltEna) is reset (1'b0), this field  |
| microframe for this periodic endpoint. For non periodic transfers, this field is used only in DMA mode, and specifies the number packets to be fetched for this channel before the internal DMA engine changes arbitration.  2'b00: Reserved This field yields undefined results.  2'b01: 1 transaction  2'b10: 2 transactions to be issued for this endpoint per microframe  2'b11: 3 transactions to be issued for this endpoint per microframe  When HCSPLTn.SpltEna is set (1'b1), this field indicates the number of immediate retries to be performed for a periodic split transactions on transaction errors. This field must be set to at least 2'b01.  EPType Endpoint Type Indicates the transfer type selected.  2'b00: Control  2'b10: Bulk  2'b11: Interrupt  LSpdDev  Low-Speed Device  This field is set by the application to indicate that this channel is communicating to a low-speed device.  16 RO 0x0 reserved  EPDir                                                                                                                                                                                                                                                                                  |       |        |             | indicates to the host the number of            |
| periodic transfers, this field is used only in DMA mode, and specifies the number packets to be fetched for this channel before the internal DMA engine changes arbitration.  2'b00: Reserved This field yields undefined results.  2'b10: 1 transaction  2'b10: 2 transactions to be issued for this endpoint per microframe  2'b11: 3 transactions to be issued for this endpoint per microframe  When HCSPLTn.SpltEna is set (1'b1), this field indicates the number of immediate retries to be performed for a periodic split transactions on transaction errors. This field must be set to at least 2'b01.  EPType Endpoint Type Indicates the transfer type selected.  2'b00: Control  2'b01: Isochronous  2'b10: Bulk  2'b11: Interrupt  LSpdDev  Low-Speed Device  This field is set by the application to indicate that this channel is communicating to a low-speed device.  16 RO 0x0 reserved  EPDir                                                                                                                                                                                                                                                                                                             |       |        |             | transactions that must be executed per         |
| DMA mode, and specifies the number packets to be fetched for this channel before the internal DMA engine changes arbitration.  2'b00: Reserved This field yields undefined results.  2'b01: 1 transaction  2'b10: 2 transactions to be issued for this endpoint per microframe  2'b11: 3 transactions to be issued for this endpoint per microframe  When HCSPLTn.SpltEna is set (1'b1), this field indicates the number of immediate retries to be performed for a periodic split transactions on transaction errors. This field must be set to at least 2'b01.  EPType  Endpoint Type Indicates the transfer type selected.  2'b00: Control  2'b01: Isochronous  2'b10: Bulk  2'b11: Interrupt  LSpdDev  Low-Speed Device  This field is set by the application to indicate that this channel is communicating to a low-speed device.  16 RO 0x0 reserved  EPDir                                                                                                                                                                                                                                                                                                                                                           |       |        |             | microframe for this periodic endpoint. For non |
| to be fetched for this channel before the internal DMA engine changes arbitration. 2'b00: Reserved This field yields undefined results. 2'b01: 1 transaction 2'b10: 2 transactions to be issued for this endpoint per microframe 2'b11: 3 transactions to be issued for this endpoint per microframe When HCSPLTn.SpltEna is set (1'b1), this field indicates the number of immediate retries to be performed for a periodic split transactions on transaction errors. This field must be set to at least 2'b01.  EPType Endpoint Type Indicates the transfer type selected. 2'b00: Control 2'b01: Isochronous 2'b10: Bulk 2'b11: Interrupt  LSpdDev Low-Speed Device 17 RW 0x0 This field is set by the application to indicate that this channel is communicating to a low-speed device.  16 RO 0x0 reserved EPDir                                                                                                                                                                                                                                                                                                                                                                                                         |       |        |             | periodic transfers, this field is used only in |
| 21:20 RW 0x0 internal DMA engine changes arbitration. 2'b00: Reserved This field yields undefined results. 2'b01: 1 transaction 2'b10: 2 transactions to be issued for this endpoint per microframe 2'b11: 3 transactions to be issued for this endpoint per microframe When HCSPLTn.SpltEna is set (1'b1), this field indicates the number of immediate retries to be performed for a periodic split transactions on transaction errors. This field must be set to at least 2'b01.  EPType Endpoint Type Indicates the transfer type selected. 2'b00: Control 2'b01: Isochronous 2'b10: Bulk 2'b11: Interrupt  LSpdDev Low-Speed Device 17 RW 0x0 This field is set by the application to indicate that this channel is communicating to a low-speed device.  16 RO 0x0 reserved  EPDir                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |        |             | DMA mode, and specifies the number packets     |
| 2'b00: Reserved This field yields undefined results. 2'b01: 1 transaction 2'b10: 2 transactions to be issued for this endpoint per microframe 2'b11: 3 transactions to be issued for this endpoint per microframe When HCSPLTn.SpltEna is set (1'b1), this field indicates the number of immediate retries to be performed for a periodic split transactions on transaction errors. This field must be set to at least 2'b01.  EPType Endpoint Type Indicates the transfer type selected. 2'b00: Control 2'b01: Isochronous 2'b10: Bulk 2'b11: Interrupt  LSpdDev Low-Speed Device 17 RW 0x0 This field is set by the application to indicate that this channel is communicating to a low-speed device.  16 RO 0x0 reserved EPDir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |        |             | to be fetched for this channel before the      |
| 2'b00: Reserved This field yields undefined results. 2'b01: 1 transaction 2'b10: 2 transactions to be issued for this endpoint per microframe 2'b11: 3 transactions to be issued for this endpoint per microframe When HCSPLTn.SpltEna is set (1'b1), this field indicates the number of immediate retries to be performed for a periodic split transactions on transaction errors. This field must be set to at least 2'b01.  EPType Endpoint Type Indicates the transfer type selected.  19:18 RW 0x0 2'b00: Control 2'b01: Isochronous 2'b10: Bulk 2'b11: Interrupt  LSpdDev Low-Speed Device 17 RW 0x0 This field is set by the application to indicate that this channel is communicating to a low-speed device.  16 RO 0x0 reserved EPDir                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 21.20 | DW     | 0.0         | internal DMA engine changes arbitration.       |
| 2'b01: 1 transaction 2'b10: 2 transactions to be issued for this endpoint per microframe 2'b11: 3 transactions to be issued for this endpoint per microframe When HCSPLTn.SpltEna is set (1'b1), this field indicates the number of immediate retries to be performed for a periodic split transactions on transaction errors. This field must be set to at least 2'b01.  EPType Endpoint Type Indicates the transfer type selected.  2'b00: Control 2'b01: Isochronous 2'b10: Bulk 2'b11: Interrupt  LSpdDev Low-Speed Device  17 RW 0x0 This field is set by the application to indicate that this channel is communicating to a low-speed device.  16 RO 0x0 reserved EPDir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 21.20 | I NV   | OXO         | 2'b00: Reserved This field yields undefined    |
| 2'b10: 2 transactions to be issued for this endpoint per microframe 2'b11: 3 transactions to be issued for this endpoint per microframe When HCSPLTn.SpltEna is set (1'b1), this field indicates the number of immediate retries to be performed for a periodic split transactions on transaction errors. This field must be set to at least 2'b01.  EPType Endpoint Type Indicates the transfer type selected.  2'b00: Control 2'b01: Isochronous 2'b10: Bulk 2'b11: Interrupt  LSpdDev Low-Speed Device  This field is set by the application to indicate that this channel is communicating to a low-speed device.  16 RO 0x0 reserved  EPDir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |        |             | results.                                       |
| endpoint per microframe 2'b11: 3 transactions to be issued for this endpoint per microframe When HCSPLTn.SpltEna is set (1'b1), this field indicates the number of immediate retries to be performed for a periodic split transactions on transaction errors. This field must be set to at least 2'b01.  EPType Endpoint Type Indicates the transfer type selected.  2'b00: Control 2'b01: Isochronous 2'b10: Bulk 2'b11: Interrupt  LSpdDev Low-Speed Device  This field is set by the application to indicate that this channel is communicating to a low-speed device.  16 RO 0x0 reserved  EPDir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |        |             |                                                |
| 2'b11: 3 transactions to be issued for this endpoint per microframe When HCSPLTn.SpltEna is set (1'b1), this field indicates the number of immediate retries to be performed for a periodic split transactions on transaction errors. This field must be set to at least 2'b01.  EPType Endpoint Type Indicates the transfer type selected.  2'b00: Control 2'b01: Isochronous 2'b10: Bulk 2'b11: Interrupt  LSpdDev Low-Speed Device 17 RW 0x0 This field is set by the application to indicate that this channel is communicating to a low-speed device.  16 RO 0x0 reserved EPDir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |        |             | 2'b10: 2 transactions to be issued for this    |
| endpoint per microframe When HCSPLTn.SpltEna is set (1'b1), this field indicates the number of immediate retries to be performed for a periodic split transactions on transaction errors. This field must be set to at least 2'b01.  EPType Endpoint Type Indicates the transfer type selected. 2'b00: Control 2'b01: Isochronous 2'b10: Bulk 2'b11: Interrupt  LSpdDev Low-Speed Device 17 RW 0x0 This field is set by the application to indicate that this channel is communicating to a low-speed device.  16 RO 0x0 reserved EPDir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |        |             |                                                |
| When HCSPLTn.SpltEna is set (1'b1), this field indicates the number of immediate retries to be performed for a periodic split transactions on transaction errors. This field must be set to at least 2'b01.  EPType Endpoint Type Indicates the transfer type selected. 2'b00: Control 2'b01: Isochronous 2'b10: Bulk 2'b11: Interrupt  LSpdDev Low-Speed Device 17 RW 0x0 This field is set by the application to indicate that this channel is communicating to a low-speed device.  16 RO 0x0 reserved EPDir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |        |             |                                                |
| indicates the number of immediate retries to be performed for a periodic split transactions on transaction errors. This field must be set to at least 2'b01.  EPType Endpoint Type Indicates the transfer type selected. 2'b00: Control 2'b01: Isochronous 2'b10: Bulk 2'b11: Interrupt  LSpdDev Low-Speed Device 17 RW 0x0 This field is set by the application to indicate that this channel is communicating to a low-speed device.  16 RO 0x0 reserved EPDir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |        |             |                                                |
| be performed for a periodic split transactions on transaction errors. This field must be set to at least 2'b01.  EPType Endpoint Type Indicates the transfer type selected. 2'b00: Control 2'b01: Isochronous 2'b10: Bulk 2'b11: Interrupt  LSpdDev Low-Speed Device This field is set by the application to indicate that this channel is communicating to a low-speed device.  16 RO 0x0 reserved EPDir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |        |             |                                                |
| on transaction errors. This field must be set to at least 2'b01.  EPType Endpoint Type Indicates the transfer type selected.  2'b00: Control 2'b01: Isochronous 2'b10: Bulk 2'b11: Interrupt  LSpdDev Low-Speed Device This field is set by the application to indicate that this channel is communicating to a low-speed device.  16 RO 0x0 reserved EPDir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |        |             | , ( ) y                                        |
| at least 2'b01.  EPType Endpoint Type Indicates the transfer type selected.  2'b00: Control 2'b01: Isochronous 2'b10: Bulk 2'b11: Interrupt  LSpdDev Low-Speed Device This field is set by the application to indicate that this channel is communicating to a low-speed device.  16 RO 0x0 reserved EPDir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |        |             |                                                |
| EPType Endpoint Type Indicates the transfer type selected.  2'b00: Control 2'b01: Isochronous 2'b10: Bulk 2'b11: Interrupt  LSpdDev Low-Speed Device This field is set by the application to indicate that this channel is communicating to a low-speed device.  16 RO 0x0 reserved EPDir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |        |             |                                                |
| Endpoint Type Indicates the transfer type selected.  2'b00: Control 2'b01: Isochronous 2'b10: Bulk 2'b11: Interrupt  LSpdDev Low-Speed Device This field is set by the application to indicate that this channel is communicating to a low-speed device.  RW 0x0 reserved  EPDir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |        |             |                                                |
| Indicates the transfer type selected.  2'b00: Control 2'b01: Isochronous 2'b10: Bulk 2'b11: Interrupt  LSpdDev Low-Speed Device  This field is set by the application to indicate that this channel is communicating to a low-speed device.  16 RO 0x0 reserved  EPDir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |        | • 0         | 1                                              |
| 19:18 RW 0x0 2'b00: Control 2'b01: Isochronous 2'b10: Bulk 2'b11: Interrupt  LSpdDev Low-Speed Device 17 RW 0x0 This field is set by the application to indicate that this channel is communicating to a low-speed device.  16 RO 0x0 reserved  EPDir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |        |             | ' ' '                                          |
| 2'b01: Isochronous 2'b10: Bulk 2'b11: Interrupt  LSpdDev Low-Speed Device This field is set by the application to indicate that this channel is communicating to a low-speed device.  RO 0x0 reserved  EPDir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 10.10 | DW     | 0.40        | 1                                              |
| 2'b10: Bulk 2'b11: Interrupt  LSpdDev Low-Speed Device  This field is set by the application to indicate that this channel is communicating to a low-speed device.  RO 0x0 reserved  EPDir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 19:18 | KVV    | UXU         |                                                |
| 2'b11: Interrupt  LSpdDev Low-Speed Device  This field is set by the application to indicate that this channel is communicating to a low-speed device.  RO 0x0 reserved  EPDir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |        |             |                                                |
| LSpdDev Low-Speed Device This field is set by the application to indicate that this channel is communicating to a low-speed device.  RO 0x0 reserved EPDir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       | 03     | ,           |                                                |
| Low-Speed Device This field is set by the application to indicate that this channel is communicating to a low-speed device.  RO 0x0 reserved  EPDir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |        |             |                                                |
| 17 RW 0x0 This field is set by the application to indicate that this channel is communicating to a low-speed device.  16 RO 0x0 reserved EPDir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0     | $\cup$ |             | · .                                            |
| that this channel is communicating to a low-speed device.  16 RO 0x0 reserved  EPDir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 17    | RW     | 0×0         | · ·                                            |
| low-speed device.  16 RO 0x0 reserved EPDir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |        |             |                                                |
| 16 RO 0x0 reserved EPDir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |        |             |                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 16    | RO     | 0x0         | •                                              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |        |             |                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |        |             |                                                |
| Indicates whether the transaction is IN or                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 4 =   | D)A    |             | · .                                            |
| 15 RW 0x0 OUT.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 15    | KW     | UXU         | OUT.                                           |
| 1'b0: OUT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |        |             | 1'b0: OUT                                      |
| 1'b1: IN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |        |             | 1'b1: IN                                       |



associated endpoint.

#### **USBOTG\_HCSPLTn**

Address: Operational Base + offset (0x0504 + 0x20 \* n)  $0 \le n \le 15$ 

Host Channel-n Split Control Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      |             | SpltEna Split Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 31    | RW   | 0x0         | The application sets this field to indicate that this channel is enabled to perform split transactions.                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 30:17 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 16    | RW   | 0x0         | CompSplt Do Complete Split The application sets this field to request the OTG host to perform a complete split transaction.                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 15:14 | RW   | 0x0         | Transaction Position This field is used to determine whether to send all, first, middle, or last payloads with each OUT transaction.  2'b11: All. This is the entire data payload is of this transaction (which is less than or equal to 188 bytes).  2'b10: Begin. This is the first data payload of this transaction (which is larger than 188 bytes).  2'b00: Mid. This is the middle payload of this transaction (which is larger than 188bytes).  2'b01: End. This is the last payload of this transaction (which is larger than 188bytes). |
| 13:7  | RW   | 0×00        | HubAddr Hub Address This field holds the device address of the transaction translator's hub.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |



| Bit | Attr | Reset Value | Description                                    |
|-----|------|-------------|------------------------------------------------|
| 6:1 | RO   | 0x0         | reserved                                       |
| 0   | RW   | 10x0        | PrtAddr                                        |
|     |      |             | Port Address                                   |
|     |      |             | This field is the port number of the recipient |
|     |      |             | transaction translator.                        |

### **USBOTG\_HCINTn**

Address: Operational Base + offset (0x0508 + 0x20 \* n)  $0 \le n \le 15$ 

Host Channel-n Interrupt Register

| Bit   | Attr | Reset Value | Description                                    |
|-------|------|-------------|------------------------------------------------|
| 31:14 | RO   | 0x0         | reserved                                       |
|       |      |             | DESC_LST_ROLLIntr                              |
|       |      |             | Descriptor rollover interrupt                  |
|       |      |             | This bit is valid only when Scatter/Gather DMA |
| 13    | W1C  | 0x0         | mode is enabled. The core sets this bit when   |
|       |      |             | the corresponding channel's descriptor list    |
|       |      |             | rolls over. For non Scatter/Gather DMA mode,   |
|       |      |             | this bit is reserved.                          |
|       |      |             | XCS_XACT_ERR                                   |
|       |      |             | Excessive Transaction Error                    |
|       |      |             | This bit is valid only when Scatter/Gather DMA |
| 12    | W1C  | 0×0         | mode is enabled. The core sets this bit when 3 |
| 12    | WIC  | UXU         | consecutive transaction errors occurred on the |
|       |      |             | USB bus. XCS_XACT_ERR will not be              |
|       |      | • 0         | generated for Isochronous channels. For non    |
|       |      |             | Scatter/Gather DMA mode, this bit is reserved. |
|       |      | 0×0         | BNAIntr                                        |
|       |      |             | BNA (Buffer Not Available) Interrupt           |
|       |      |             | This bit is valid only when Scatter/Gather DMA |
| 11    | W1C  |             | mode is enabled. The core generates this       |
| 3     |      |             | interrupt when the descriptor accessed is not  |
|       |      |             | ready for the Core to process. BNA will not be |
|       |      |             | generated for Isochronous channels. For non    |
|       |      |             | Scatter/Gather DMA mode, this bit is reserved. |
| 10    | W1C  | 0×0         | DataTglErr                                     |
|       |      |             | Data Toggle Error                              |
|       |      |             | In Scatter/Gather DMA mode, the interrupt      |
|       |      |             | due to this bit is masked in the core.         |
|       |      |             | FrmOvrun                                       |
| 9     | W1C  | 0×0         | Frame Overrun                                  |
|       |      | -           | In Scatter/Gather DMA mode, the interrupt      |
|       |      |             | due to this bit is masked in the core          |



| Bit      | Attr | Reset Value                            | Description                                      |
|----------|------|----------------------------------------|--------------------------------------------------|
|          |      |                                        | BblErr                                           |
| 0        | W/1C | 0.40                                   | Babble Error                                     |
| 8        | W1C  | UXU                                    | In Scatter/Gather DMA mode, the interrupt        |
|          |      |                                        | due to this bit is masked in the core.           |
|          |      |                                        | XactErr                                          |
|          |      |                                        | Transaction Error                                |
|          |      |                                        | Indicates one of the following errors occurred   |
| 7        | W1C  | 0x0                                    | on the USB: CRC check failure, Timeout, Bit      |
|          |      |                                        | stuff error, False EOP. In Scatter/Gather DMA    |
|          |      |                                        | mode, the interrupt due to this bit is masked in |
|          |      |                                        | the core.                                        |
|          |      |                                        | NYET                                             |
| 6        | wo   | 0.0                                    | NYET Response Received Interrupt                 |
| 0        | WO   | UXU                                    | In Scatter/Gather DMA mode, the interrupt        |
|          |      |                                        | due to this bit is masked in the core.           |
|          |      |                                        | ACK                                              |
| 5        | W1C  | 0.0                                    | ACK Response Received/Transmitted Interrupt      |
| ٦        | WIC  | UXU                                    | In Scatter/Gather DMA mode, the interrupt        |
|          |      |                                        | due to this bit is masked in the core.           |
|          |      |                                        | NAK                                              |
| 4        | W1C  | 0×0                                    | NAK Response Received Interrupt                  |
| 7        | WIC  | 0.00                                   | In Scatter/Gather DMA mode, the interrupt        |
|          |      | 0x0  0x0  0x0  0x0  0x0  0x0           | due to this bit is masked in the core.           |
|          |      |                                        | STALL                                            |
| 3        | W1C  | 0.0                                    | STALL Response Received Interrupt                |
| 3        | WIC  | UXU                                    | In Scatter/Gather DMA mode, the interrupt        |
|          |      | 10 y                                   | due to this bit is masked in the core.           |
|          |      |                                        | AHBErr                                           |
|          | 11   |                                        | AHB Error                                        |
|          | CV   | <b>Y</b>                               | This is generated only in DMA mode when          |
| 2        | W1C  | 0x0  0x0  0x0  0x0  0x0  0x0  0x0  0x0 | there is an AHB error during AHB                 |
|          |      |                                        | read/write.The application can read the          |
|          | -    |                                        | corresponding channel's DMA address register     |
| <b>Y</b> |      |                                        | to get the error address.                        |



| Bit | Attr | Reset Value | Description                                      |
|-----|------|-------------|--------------------------------------------------|
|     |      |             | ChHltd                                           |
|     |      |             | Channel Halted                                   |
|     |      |             | In non Scatter/Gather DMA mode, it indicates     |
|     |      |             | the transfer completed abnormally either         |
|     |      |             | because of any USB transaction error or in       |
|     |      |             | response to disable request by the application   |
| 1   | W1C  | 0x0         | or because of a completed transfer.In            |
|     |      |             | Scatter/Gather DMA mode, this indicates that     |
|     |      |             | transfer completed due to any of the following:  |
|     |      |             | EOL being set in descriptor, AHB error,          |
|     |      |             | Excessive transaction errors, In response to     |
|     |      |             | disable request by the application,Babble,       |
|     |      |             | Stall, Buffer Not Available (BNA)                |
|     |      |             | XferCompl                                        |
|     |      |             | Transfer Completed                               |
|     |      |             | For Scatter/Gather DMA mode, it indicates that   |
| 0   | W1C  | 0×0         | current descriptor processing got                |
|     | ***  | OXO .       | completed with IOC bit set in its descriptor. In |
|     |      |             | non Scatter/Gather DMA mode, it indicates        |
|     |      |             | that Transfer completed normally without any     |
|     |      |             | errors.                                          |

# **USBOTG\_HCINTMSKn**

Address: Operational Base + offset (0x050c + 0x20 \* n)  $0 \le n \le 15$ 

Host Channel-n Interrupt Mask Register

| Bit      | Attr | Reset Value       | Description                                      |
|----------|------|-------------------|--------------------------------------------------|
| 31:14    | RO   | 0x0               | reserved                                         |
|          |      |                   | DESC_LST_ROLLIntrMsk                             |
|          | 11   |                   | Descriptor rollover interrupt Mask register      |
| 13       | RW   | 0x0               | This bit is valid only when Scatter/Gather DMA   |
|          |      |                   | mode is enabled. In non Scatter/Gather DMA       |
|          |      |                   | mode, this bit is reserved.                      |
| 12       | RO   | 0x0               | reserved                                         |
| <b>Y</b> |      |                   | BNAIntrMsk                                       |
|          |      |                   | BNA (Buffer Not Available) Interrupt mask        |
| 11       | RW   | 0×0               | register                                         |
|          | INVV | 0×0<br>0×0<br>0×0 | This bit is valid only when Scatter/Gather DMA   |
|          |      |                   | mode is enabled. In non Scatter/Gather DMA       |
|          |      |                   | mode, this bit is reserved.                      |
|          |      |                   | DataTglErrMsk                                    |
| 10       | RW   | 0×0               | Data Toggle Error Mask                           |
|          | INVV | 0.00              | This bit is not applicable in Scatter/Gather DMA |
|          |      |                   | mode.                                            |



| Bit | Attr  | Reset Value | Description                                      |
|-----|-------|-------------|--------------------------------------------------|
|     |       |             | FrmOvrunMsk                                      |
|     | DW    | 0.40        | Frame Overrun Mask                               |
| 9   | RW    | 0x0         | This bit is not applicable in Scatter/Gather DMA |
|     |       |             | mode.                                            |
|     |       |             | BblErrMsk                                        |
| 8   | RW    | 0×0         | Babble Error Mask                                |
| 0   | KVV   | UXU         | This bit is not applicable in Scatter/Gather DMA |
|     |       |             | mode.                                            |
|     |       |             | XactErrMsk                                       |
| 7   | RW    | 0.40        | Transaction Error Mask                           |
| 7   | KVV   | 0×0         | This bit is not applicable in Scatter/Gather DMA |
|     |       |             | mode                                             |
|     |       |             | NyetMsk                                          |
| 6   | RW    | 0×0         | NYET Response Received Interrupt Mask            |
| 6   | KVV   | UXU         | This bit is not applicable in Scatter/Gather DMA |
|     |       |             | mode.                                            |
|     |       |             | AckMsk                                           |
|     |       |             | ACK Response Received/Transmitted Interrupt      |
| 5   | RW    | 0x0         | Mask                                             |
|     |       |             | This bit is not applicable in Scatter/Gather DMA |
|     |       |             | mode.                                            |
|     |       |             | NakMsk                                           |
| 4   | RW    | 0×0         | NAK Response Received Interrupt Mask             |
| 4   | IK VV | UXU         | This bit is not applicable in Scatter/Gather DMA |
|     |       |             | mode.                                            |
|     |       | 1           | StallMsk                                         |
| 2   | RW    | 0.0         | STALL Response Received Interrupt Mask           |
| 3   | KVV   | UXU         | This bit is not applicable in Scatter/Gather DMA |
|     | 1     |             | mode.                                            |
|     |       |             | AHBErrMsk                                        |
| 2   | RW    | 0×0         | AHB Error Mask                                   |
|     | KW .  | UXU         | Note: This bit is only accessible when           |
|     | V     |             | OTG_ARCHITECTURE = 2                             |
| 1   | RW    | 0x0         | ChHltdMsk                                        |
| 1   | FLVV  | 0.00        | Channel Halted Mask                              |
|     |       |             | XferComplMsk                                     |
|     |       |             | Transfer Completed Mask                          |
| 0   | RW    | 0x0         | This bit is valid only when Scatter/Gather DMA   |
|     |       |             | mode is enabled. In non Scatter/Gather DMA       |
|     |       |             | mode, this bit is reserved.                      |

# USBOTG\_HCTSIZn



Address: Operational Base + offset (0x0510 + 0x20 \* n)0≤n≤15 Host Channel-n Transfer Size Register(In Scatter/Gather DMA mode)

| Bit   | Attr | Reset Value | Description                                         |
|-------|------|-------------|-----------------------------------------------------|
|       |      |             | DoPng                                               |
|       |      |             | Do Ping                                             |
|       |      |             | This bit is used only for OUT transfers. Setting    |
| 31    | RW   | 0×0         | this field to 1 directs the host to do PING         |
| 31    | KVV  |             | protocol.                                           |
|       |      |             | Note: Do not set this bit for IN transfers. If this |
|       |      |             | bit is set for IN transfers it disables the         |
|       |      |             | channel.                                            |
|       |      |             | Pid                                                 |
|       |      | PID         |                                                     |
|       |      |             | The application programs this field with the        |
|       |      |             | type of PID to use for the initial transaction.     |
| 30:29 | RW   | 0×0         | The host maintains this field for the rest of the   |
| 30.29 | IXVV | 0.00        | transfer.                                           |
|       |      |             | 2'b00: DATA0                                        |
|       |      |             | 2'b01: DATA2                                        |
|       |      |             | 2'b10: DATA1                                        |
|       |      |             | 2'b11: MDATA (non-control)/SETUP (control)          |
| 28:16 | RO   | 0x0         | reserved                                            |

| Attr | Reset Value | Description                                                         |
|------|-------------|---------------------------------------------------------------------|
|      |             | NTD                                                                 |
|      |             | Number of Transfer Descriptors                                      |
|      |             | (Non Isochronous) This value is in terms of                         |
|      |             | number of descriptors. Maximum number of                            |
|      |             | descriptor that can be present in the list is 64.                   |
|      |             | The values can be from 0 to 63.                                     |
|      |             | • 0 – 1 descriptor.                                                 |
|      |             | • 63 – 64 descriptors                                               |
|      |             | This field indicates the total number of                            |
|      |             | descriptors present in that list. The core will                     |
|      |             | wrap around after servicing NTD number of                           |
|      |             | descriptors for that list.                                          |
|      |             | (Isochronous) This field indicates the number                       |
| RW   | 0×000       | of descriptors present in that list.µframe.                         |
|      |             | The possible values for FS are                                      |
|      |             | • 1 – 2 descriptors                                                 |
|      |             | • 3 – 4 descriptors                                                 |
|      |             | • 7 – 8 descriptors                                                 |
|      |             | • 15 – 16 descriptors                                               |
|      |             | • 31 – 32 descriptors                                               |
|      |             | • 63 – 64 descriptors                                               |
|      |             | The possible values for HS are                                      |
|      |             | • 7 – 8 descriptors                                                 |
|      |             | • 15 – 16 descriptors                                               |
|      | • ()        | • 31 – 32 descriptors                                               |
|      |             | <ul><li>63 – 64 descriptors</li><li>127 – 128 descriptors</li></ul> |
|      |             | • 255 – 256 descriptors                                             |
|      | RW          |                                                                     |



| Bit Attr Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18:0 RW 0x00000      | SCHED_INFO Schedule information Every bit in this 8 bit register indicates scheduling for that microframe. Bit 0 indicates scheduling for 1st microframe and bit 7 indicates scheduling for 8th microframe in that frame. A value of 8'b11111111 indicates that the corresponding interrupt channel is scheduled to issue a token every microframe in that frame. A value of 8'b10101010 indicates that the corresponding interrupt channel is scheduled to issue a token every alternate microframe starting with second microframe. Note that this field is applicable only for periodic (Isochronous and Interrupt) channels. |

Host Channel-n Transfer Size Register(In Non Scatter/Gather DMA mode)

| Bit   | Attr | Reset Value                           | Description                                         |
|-------|------|---------------------------------------|-----------------------------------------------------|
|       |      |                                       | DoPng                                               |
|       |      |                                       | Do Ping                                             |
|       |      |                                       | This bit is used only for OUT transfers. Setting    |
| 31    | RW   | 0x0                                   | this field to 1 directs the host to do PING         |
|       |      | • 1                                   | protocol. Note: Do not set this bit for IN          |
|       |      | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | transfers. If this bit is set for IN transfers it   |
|       |      |                                       | disables the channel.                               |
|       |      |                                       | Pid                                                 |
|       |      |                                       | PID                                                 |
|       | C    | >                                     | The application programs this field with the        |
|       |      |                                       | type of PID to use for the initial transaction. The |
| 30:29 | RW   | 0×0                                   | host maintains this field for the rest of the       |
| 30.29 | KW   | UXU                                   | transfer.                                           |
| ,     |      |                                       | 2'b00: DATA0                                        |
|       |      |                                       | 2'b01: DATA2                                        |
|       |      |                                       | 2'b10: DATA1                                        |
|       |      |                                       | 2'b11: MDATA (non-control)/SETUP (control)          |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28:19 | RW   | 0×000       | PktCnt Packet Count This field is programmed by the application with the expected number of packets to be transmitted (OUT) or received (IN). The host decrements this count on every successful transmission or reception of an OUT/IN packet. Once this count reaches zero, the application is interrupted to indicate normal completion. The width of this counter is specified as Width of Packet Counters (parameter OTG_PACKET_COUNT_WIDTH).                  |
| 18:0  | RW   | 0×00000     | Transfer Size For an OUT, this field is the number of data bytes the host sends during the transfer. For an IN, this field is the buffer size that the application has Reserved for the transfer. The application is expected to program this field as an integer multiple of the maximum packet size for IN transactions (periodic and non-periodic). The width of this counter is specified as Width of Transfer Size Counters (parameter OTG_TRANS_COUNT_WIDTH). |

#### **USBOTG\_HCDMAn**

Address: Operational Base + offset (0x0514 + 0x20 \* n)  $0 \le n \le 15$ 

Host Channel-n DMA Address Register

| Bit  | Attr | Reset Value | Description                                  |
|------|------|-------------|----------------------------------------------|
|      |      | ·           | DMAAddr                                      |
|      |      |             | DMA Address                                  |
|      |      |             | This field holds the start address in the    |
| 31:0 | RW   | 0x00000000  | external memory from which the data for the  |
|      |      |             | endpoint must be fetched or to which it must |
|      |      |             | be stored. This register is incremented on   |
|      |      |             | every AHB transaction.                       |

## **USBOTG\_HCDMABn**

Address: Operational Base + offset (0x051c + 0x20 \* n)  $0 \le n \le 15$ 

Host Channel-n DMA Buffer Address Register

|     | interest and the property of t |             |             |  |  |  |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------------|--|--|--|
| Bit | Attr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Reset Value | Description |  |  |  |



| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                 |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0×00000000  | HCDMABn Holds the current buffer address This register is updated as and when the data transfer for the corresponding end point is in progress. This register is present only in Scatter/Gather DMA mode. Otherwise this field is reserved. |

Host Channel - DMA Decriptor Address Pegister

| Host Channel-n DMA Decriptor Address Re |      |             |                                                                                                  | ister                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                    |
|-----------------------------------------|------|-------------|--------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|
| Bit                                     | Attr | Reset Value |                                                                                                  | Descripti                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | on                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                    |
| 31:N<br>(Isoc)<br>31:9<br>(Non<br>Isoc) | RW   | 0×00000000  | address of the descriptor in address. The be ready. The from the CTI holds the ad locations in v | nous: This field the 512 bytes parties the list should be first descriptone core starts properties of the 2* which the isochwhere N is base of the 2* where N is base of the 1.3 of th | age. The locate r may be rocessing ronous: The first formus of the ronous depends on the first formus depends on t | first ed in this or may not the list his field bytes of escriptors |



| Bit                                     | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------------------------------------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| N-1:3<br>(Isoc)<br>8:3<br>(Non<br>Isoc) | RW   | 0×00000000  | CTD Current Transfer Desc Non Isochronous: This value is in terms of number of descriptors. The values can be from 0 to 63. 0 – 1 descriptor. 63- 64 descriptors. This field indicates the current descriptor processed in the list. This field is updated both by application and the core. For example, if the application enables the channel after programming CTD=5, then the core will start processing the 6th descriptor. The address is obtained by adding a value of (8bytes*5=) 40(decimal) to DMAAddr. Isochronous: CTD for isochronous is based on the current frame/µframe value. Need to be set to zero by application. |
| 2:0                                     | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

## USBOTG\_DCFG

Address: Operational Base + offset (0x0800)
Device Configuration Register

| DCVICC ( | connigui | ation Register     |                                                   |
|----------|----------|--------------------|---------------------------------------------------|
| Bit      | Attr     | <b>Reset Value</b> | Description                                       |
|          |          |                    | ResValid                                          |
|          |          |                    | Resume Validation Period                          |
|          |          | . <                | This field controls the period when the core      |
| 31:26    | RW       | 0x02               | resumes from a suspend. When this bit is set, the |
|          |          | N y                | core counts for the ResValid number of clock      |
|          |          |                    | cycles to detect a valid resume. This field is    |
|          | 1        |                    | effective only when DCFG.Ena32KHzSusp is set.     |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25:24 | RW   | 0×0         | PerSchIntvl Periodic Scheduling Interval PerSchIntvl must be programmed only for Scatter/Gather DMA mode. Description: This field specifies the amount of time the Internal DMA engine must allocate for fetching periodic IN endpoint data. Based on the number of periodic endpoints, this value must be specified as 25,50 or 75% of (micro)frame. When any periodic endpoints are active, the internal DMA engine allocates the specified amount of time in fetching periodic IN endpoint data. When no periodic endpoints are active, then the internal DMA engine services nonperiodic endpoints, ignoring this field. After the specified time within a (micro)frame, the DMA switches to fetching for nonperiodic endpoints. 2'b00: 25% of (micro)frame. 2'b01: 50% of (micro)frame. 2'b11: Reserved. |
| 23    | RW   | 0×0         | DescDMA Enable Scatter/Gather DMA in Device mode When the Scatter/Gather DMA option selected during configuration of the RTL, the application can set this bit during initialization to enable the Scatter/Gather DMA operation. NOTE: This bit must be modified only once after a reset. The following combinations are available for programming: GAHBCFG.DMAEn=0,DCFG.DescDMA=0 => Slave mode GAHBCFG.DMAEn=0,DCFG.DescDMA=1 => Invalid GAHBCFG.DMAEn=1,DCFG.DescDMA=0 => Buffered DMA mode GAHBCFG.DMAEn=1,DCFG.DescDMA=1 => Scatter/Gather DMA mode                                                                                                                                                                                                                                                      |



| Bit   | Attr | Reset Value | Description                                          |
|-------|------|-------------|------------------------------------------------------|
|       |      |             | EPMisCnt                                             |
|       |      |             | IN Endpoint Mismatch Count                           |
|       |      |             | This field is valid only in shared FIFO              |
|       |      |             | operation.The application programs this filed        |
|       |      |             | with a count that determines when the core           |
| 22.10 | RW   | 0x08        | generates an Endpoint Mismatch interrupt             |
| 22:18 | KVV  | UXU8        | (GINTSTS.EPMis). The core loads this value into      |
|       |      |             | an internal counter and decrements it. The           |
|       |      |             | counter is reloaded whenever there is a match or     |
|       |      |             | when the counter expires. The width of this          |
|       |      |             | counter depends on the depth of the Token            |
|       |      |             | Queue.                                               |
| 17:13 | RO   | 0x0         | reserved                                             |
|       |      |             | PerFrInt                                             |
|       |      |             | Periodic Frame Interval                              |
|       |      |             | Indicates the time within a (micro)frame at          |
|       |      |             | which the application must be notified using the     |
|       |      |             | End Of Periodic Frame Interrupt. This can be         |
| 12:11 | RW   | 0x0         | used to determine if all the isochronous traffic for |
|       |      |             | that (micro)frame is complete.                       |
|       |      |             | 2'b00: 80% of the (micro)frame interval              |
|       |      |             | 2'b01: 85%                                           |
|       |      |             | 2'b10: 90%                                           |
|       |      |             | 2'b11: 95%                                           |
|       |      | . <         | DevAddr                                              |
| 10:4  | RW   | W 0x00      | Device Address                                       |
| 10.4  |      |             | The application must program this field after        |
|       |      |             | every SetAddress control command.                    |
|       | 1    |             | Ena32KHzS                                            |
|       |      |             | Enable 32-KHz Suspend Mode                           |
|       |      | 7           | When the USB 1.1 Full-Speed Serial Transceiver       |
|       |      | 0×0         | Interface is chosen and this bit is set, the core    |
| 3     | ŔW   |             | expects the 48-MHz PHY clock to be switched to       |
|       |      |             | 32 KHz during a suspend. This bit can only be set    |
|       |      |             | if USB 1.1 Full-Speed Serial Transceiver             |
|       |      |             | Interface has been selected. If USB 1.1              |
|       |      |             | Full-Speed Serial Transceiver Interface has not      |
|       |      |             | been selected, this bit must be zero.                |



| Bit | Attr | Reset Value | Description                                                                         |
|-----|------|-------------|-------------------------------------------------------------------------------------|
|     |      |             | NZStsOUTHShk                                                                        |
|     |      |             | Non-Zero-Length Status OUT Handshake                                                |
|     |      |             | The application can use this field to select the                                    |
|     |      |             | handshake the core sends on receiving a                                             |
|     |      |             | nonzero-length data packet during the OUT                                           |
|     |      |             | transaction of a control transfer's Status stage. 1'b1: Send a STALL handshake on a |
| 2   | RW   | 0x0         | nonzero-length status OUT transaction and do                                        |
|     |      |             | not send the received OUT packet to the application.                                |
|     |      |             | 1'b0: Send the received OUT packet to the                                           |
|     |      |             | application (zero-length or nonzerolength) and                                      |
|     |      |             | send a handshake based on the NAK and STALL                                         |
|     |      |             | bits for the endpoint in the Device Endpoint                                        |
|     |      |             | Control register.                                                                   |
|     |      |             | DevSpd                                                                              |
|     |      |             | Device Speed                                                                        |
|     |      |             | Indicates the speed at which the application                                        |
|     |      |             | requires the core to enumerate, or the maximum                                      |
|     |      |             | speed the application can support. However, the                                     |
|     |      |             | actual bus speed is determined only after the                                       |
|     |      |             | chirp sequence is completed, and is based on the                                    |
| 1:0 | RW   | 0x0         | speed of the USB host to which the core is                                          |
|     |      |             | connected.                                                                          |
|     |      | • 1         | 2'b00: High speed (USB 2.0 PHY clock is 30 MHz or 60 MHz)                           |
|     |      | Y           | 2'b01: Full speed (USB 2.0 PHY clock is 30 MHz                                      |
|     |      |             | or 60 MHz)                                                                          |
|     |      |             | 2'b10: Reserved                                                                     |
|     |      | C7          | 2'b11: Full speed (USB 1.1 transceiver clock is                                     |
|     |      |             | 48 MHz)                                                                             |

# USBOTG\_DCTL

Address: Operational Base + offset (0x0804)

Device Control Register

| Bit   | Attr | Reset Value | Description                             |
|-------|------|-------------|-----------------------------------------|
| 31:17 | RO   | 0x0         | reserved                                |
| 16    |      | 0×0         | NakOnBble                               |
|       | DW   |             | Set NAK automatically on babble         |
|       | RW   |             | The core sets NAK automatically for the |
|       |      |             | endpoint on which babble is received.   |



| Bit      | Attr | Reset Value | Description                                      |
|----------|------|-------------|--------------------------------------------------|
|          |      |             | IgnrFrmNum                                       |
|          |      |             | Ignore frame number for isochronous              |
|          |      |             | endpoints in case of Scatte                      |
|          |      |             | Do NOT program IgnrFrmNum bit to 1'b1 when       |
|          |      |             | the core is operating in Threshold mode. Note:   |
|          |      |             | When Scatter/Gather DMA mode is enabled          |
|          |      |             | this feature is not applicable to highspeed,     |
|          |      |             | high-bandwidth transfers. When this bit is       |
|          |      |             | enabled, there must be only one packet per       |
|          |      |             | descriptor.                                      |
|          |      |             | 0: The core transmits the packets only in the    |
|          |      |             | frame number in which they are                   |
|          |      |             | intended to be transmitted.                      |
|          |      |             | 1: The core ignores the frame number,            |
|          |      |             | sending packets immediately as the packets       |
|          |      |             | are ready.                                       |
|          |      |             | Scatter/Gather:                                  |
|          |      |             | In Scatter/Gather DMA mode, when this bit is     |
| 15       | RW   | 0×0         | enabled, the packets are not flushed when an     |
|          | IXVV | 0.00        | ISOC IN token is received for an elapsed         |
|          |      |             | frame.                                           |
|          |      |             | When Scatter/Gather DMA mode is disabled,        |
|          |      |             | this field is used by the application to enable  |
|          |      |             | periodic transfer interrupt. The application can |
|          |      |             | program periodic endpoint transfers for          |
|          |      | 1           | multiple (micro)frames.                          |
|          |      | My y        | 0: Periodic transfer interrupt feature is        |
|          |      |             | disabled; the application must program           |
|          | 1    |             | transfers for periodic endpoints every           |
|          |      | 7           | (micro)frame                                     |
|          |      |             | 1: Periodic transfer interrupt feature is        |
|          |      |             | enabled; the application can program             |
|          | _    |             | transfers for multiple (micro)frames for         |
| <b>*</b> |      |             | periodic endpoints.                              |
|          |      |             | In non-Scatter/Gather DMA mode, the              |
|          |      |             | application receives transfer complete           |
|          |      |             | interrupt after transfers for multiple           |
|          |      |             | (micro)frames are completed.                     |



| Bit   | Attr | Reset Value | Description                                      |
|-------|------|-------------|--------------------------------------------------|
|       |      |             | GMC                                              |
|       |      |             | Global Multi Count                               |
|       |      |             | GMC must be programmed only once after           |
|       |      |             | initialization. Applicable only for              |
|       |      |             | Scatter/Gather DMA mode. This indicates the      |
|       |      |             | number of packets to be serviced for that end    |
| 14.12 | DW   | 01          | point before moving to the next end point. It is |
| 14:13 | RW   | 0×1         | only for nonperiodic end points.                 |
|       |      |             | 2'b00: Invalid.                                  |
|       |      |             | 2'b01: 1 packet.                                 |
|       |      |             | 2'b10: 2 packets.                                |
|       |      |             | 2'b11: 3 packets.                                |
|       |      |             | When Scatter/Gather DMA mode is disabled,        |
|       |      |             | this field is reserved. and reads 2'b00.         |
| 12    | RO   | 0x0         | reserved                                         |
|       |      |             | PWROnPrgDone                                     |
|       |      |             | Power-On Programming Done                        |
| 11    | RW   | 0x0         | The application uses this bit to indicate that   |
|       |      |             | register programming is completed after a        |
|       |      |             | wake-up from Power Down mode.                    |
|       |      |             | CGOUTNak                                         |
| 10    | WO   | 0x0         | Clear Global OUT NAK                             |
|       |      |             | A write to this field clears the Global OUT NAK. |
|       |      |             | SGOUTNak                                         |
|       |      | . (         | Set Global OUT NAK                               |
|       |      |             | A write to this field sets the Global OUT NAK.   |
|       |      |             | The application uses this bit to send a NAK      |
| 9     | WO   | 0x0         | handshake on all OUT endpoints. The              |
|       | 1    |             | application must set the this bit only after     |
|       |      | 7           | making sure that the Global OUT NAK Effective    |
| ,     |      |             | bit in the Core Interrupt Register               |
|       |      |             | (GINTSTS.GOUTNakEff) is cleared.                 |
|       | V    |             | CGNPInNak                                        |
| 8     | wo   | 0×0         | Clear Global Non-periodic IN NAK                 |
|       |      |             | A write to this field clears the Global          |
|       |      |             | Non-periodic IN NAK.                             |



| Bit | Attr | Reset Value | Description                                        |
|-----|------|-------------|----------------------------------------------------|
|     |      |             | SGNPInNak                                          |
|     |      |             | Set Global Non-periodic IN NAK                     |
|     |      |             | A write to this field sets the Global Non-periodic |
|     |      |             | IN NAK.The application uses this bit to send a     |
|     |      |             | NAK handshake on all non-periodic IN               |
| 7   | wo   | 0×0         | endpoints. The core can also set this bit when a   |
| '   | VVO  | UXU         | timeout condition is detected on a non-periodic    |
|     |      |             | endpoint in shared FIFO operation. The             |
|     |      |             | application must set this bit only after making    |
|     |      |             | sure that the Global IN NAK Effective bit in the   |
|     |      |             | Core Interrupt Register (GINTSTS.GINNakEff)        |
|     |      |             | is cleared.                                        |
|     |      |             | TstCtl                                             |
|     |      |             | Test Control                                       |
|     |      |             | 3'b000: Test mode disabled                         |
|     |      |             | 3'b001: Test_J mode                                |
| 6:4 | RW   | 0x0         | 3'b010: Test_K mode                                |
|     |      |             | 3'b011: Test_SE0_NAK mode                          |
|     |      |             | 3'b100: Test_Packet mode                           |
|     |      |             | 3'b101: Test_Force_Enable                          |
|     |      |             | Others: Reserved                                   |
|     |      |             | GOUTNakSts                                         |
|     |      |             | Global OUT NAK Status                              |
|     |      |             | 1'b0: A handshake is sent based on the FIFO        |
|     |      |             | Status and the NAK and STALL bit                   |
| 3   | RO   | 0x0         | settings.                                          |
|     |      | OXO .       | 1'b1: No data is written to the RxFIFO,            |
|     |      |             | irrespective of space availability. Sends a NAK    |
|     | 1    |             | handshake on all packets, except on SETUP          |
|     |      | ·           | transactions. All isochronous OUT packets are      |
|     |      |             | dropped                                            |
|     |      |             | GNPINNakSts                                        |
|     |      |             | Global Non-periodic IN NAK Status                  |
| _   |      |             | 1'b0: A handshake is sent out based on the         |
| 2   | RO   | 0x0         | data availability in the transmit FIFO.            |
|     |      |             | 1'b1: A NAK handshake is sent out on all           |
|     |      |             | non-periodic IN endpoints, irrespective of the     |
|     |      |             | data availability in the transmit FIFO.            |



| Bit | Attr | Reset Value      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----|------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit | Attr | Reset Value  0x0 | SftDiscon Soft Disconnect The application uses this bit to signal the OTG core to do a soft disconnect. As long as this bit is set, the host does not see that the device is connected, and the device does not receive signals on the USB. The core stays in the disconnected state until the application clears this bit.  1'b0: Normal operation. When this bit is cleared after a soft disconnect, the core drives the phy_opmode_o signal on the UTMI+ to 2'b00, which generates a device connect                                                                                                                                                                                                                                                                                                                |
|     |      |                  | event to the USB host. When the device is reconnected, the USB host restarts device enumeration.  1'b1: The core drives the phy_opmode_o signal on the UTMI+ to 2'b01, which generates a device disconnect event to the USB host.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0   | RW   | 0×0              | Remote Wakeup Signaling When the application sets this bit, the core initiates remote signaling to wake the USB host. The application must set this bit to instruct the core to exit the Suspend state. As specified in the USB 2.0 specification, the application must clear this bit 1 mms after setting it. If LPM is enabled and the core is in the L1 (Sleep) state, when the application sets this bit, the core initiates L1 remote signaling to wake up the USB host. The application must set this bit to instruct the core to exit the Sleep state. As specified in the LPM specification, the hardware automatically clears this bit 50 us (TL1DevDrvResume) after being set by the application. The application must not set this bit when GLPMCFG bRemoteWake from the previous LPM transaction is zero. |

## **USBOTG\_DSTS**

Address: Operational Base + offset (0x0808)

Device Status Register



| Bit   | Attr   | Reset Value                           | Description                                              |
|-------|--------|---------------------------------------|----------------------------------------------------------|
| 31:22 | RO     | 0x0                                   | reserved                                                 |
|       |        |                                       | SOFFN                                                    |
|       |        |                                       | Frame or Microframe Number of the Received               |
|       |        |                                       | SOF                                                      |
| 21:8  | RW     | 0x0000                                | When the core is operating at high speed, this           |
|       |        |                                       | field contains a microframe number. When the             |
|       |        |                                       | core is operating at full or low speed, this field       |
|       |        |                                       | contains a frame number.                                 |
| 7:4   | RO     | 0x0                                   | reserved                                                 |
|       |        |                                       | ErrticErr                                                |
|       |        |                                       | Erratic Error                                            |
|       |        |                                       | The core sets this bit to report any erratic             |
|       |        |                                       | errors (phy_rxvalid_i/phy_rxvldh_i or                    |
|       |        |                                       | phy_rxactive_i is asserted for at least 2 ms,            |
|       |        |                                       | due to PHY error) seen on the UTMI+. Due to              |
| 3     | RW     | 0x0                                   | erratic errors, the OTG core goes into                   |
|       |        |                                       | Suspended state and an interrupt is generated            |
|       |        |                                       | to the application with Early Suspend bit of the         |
|       |        |                                       | Core Interrupt register (GINTSTS.ErlySusp). If           |
|       |        |                                       | the early suspend is asserted due to an erratic          |
|       |        |                                       | error, the application can only perform a soft           |
|       |        |                                       | disconnect recover.                                      |
|       |        |                                       | EnumSpd                                                  |
|       |        |                                       | Enumerated Speed                                         |
|       |        | • 1                                   | Indicates the speed at which the OTG core has            |
|       |        | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | come up after speed detection through a chirp            |
|       |        |                                       | sequence.                                                |
|       |        |                                       | 2'b00: High speed (PHY clock is running at 30            |
| 2.1   | DW     | 0.40                                  | or 60 MHz)                                               |
| 2:1   | RW     | 0x0                                   | 2'b01: Full speed (PHY clock is running at 30 or 60 MHz) |
|       |        |                                       | 2'b10: Low speed (PHY clock is running at 48             |
| Q     | $\cup$ |                                       | MHz, internal phy_clk at 6 MHz)                          |
|       |        |                                       | 2'b11: Full speed (PHY clock is running at 48            |
|       |        |                                       | MHz)                                                     |
|       |        |                                       | Low speed is not supported for devices using a           |
|       |        |                                       | UTMI+ PHY.                                               |
|       |        |                                       | OTITE IIII                                               |



| Bit | Attr | Reset Value | Description                                     |
|-----|------|-------------|-------------------------------------------------|
|     |      |             | SuspSts                                         |
|     |      |             | Suspend Status                                  |
|     |      |             | In Device mode, this bit is set as long as a    |
|     |      | 0x0         | Suspend condition is detected on the USB. The   |
|     | RW   |             | core enters the Suspended state when there is   |
| 0   |      |             | no activity on the utmi_linestate signal for an |
|     | KVV  |             | extended period of time. The core comes out of  |
|     |      |             | the suspend: When there is any activity on the  |
|     |      |             | utmi_linestate signal, When the application     |
|     |      |             | writes to the Remote Wakeup Signaling bit in    |
|     |      |             | the Device Control register                     |
|     |      |             | (DCTL.RmtWkUpSig).                              |

# **USBOTG\_DIEPMSK**

Address: Operational Base + offset (0x0810)

Device IN Endpoint common interrupt mask register

| Bit   | Attr   | Reset Value | Description                              |
|-------|--------|-------------|------------------------------------------|
| 31:14 | RO     | 0x0         | reserved                                 |
| 13    | RW     | 0x0         | NAKMsk                                   |
| 13    | KVV    | 0.00        | NAK interrupt Mask                       |
| 12:10 | RO     | 0x0         | reserved                                 |
| 9     | RW     | 0×0         | BNAInIntrMsk                             |
| 9     | IXVV   | 0.00        | BNA Interrupt Mask                       |
| 8     | RW     | 0x0         | TxfifoUndrnMsk                           |
| 0     | IX V V | 0.00        | Fifo Underrun Mask                       |
| 7     | RO     | 0x0         | reserved                                 |
| 6     | RW     | 0x0         | INEPNakEffMsk                            |
| 0     | IXVV   | UXU         | IN Endpoint NAK Effective Mask           |
| 5     | RW     | 0×0         | INTknEPMisMsk                            |
| 5     |        |             | IN Token received with EP Mismatch Mask  |
| 4 RW  | RW     | /  ()x()    | INTknTXFEmpMsk                           |
|       | IXV    |             | IN Token Received When TxFIFO Empty Mask |
| 3     | RW     | 0x0         | TimeOUTMsk                               |
| J /   | IXVV   |             | Timeout Condition Mask                   |
| 2     | RW     | 0×0         | AHBErrMsk                                |
|       | IXVV   | 0.00        | AHB Error Mask                           |
| 1     | RW     | 0×0         | EPDisbldMsk                              |
| 1     | IXVV   | UXU         | Endpoint Disabled Interrupt Mask         |
| 0     | RW     | 0×0         | XferComplMsk                             |
| U     | IK VV  | VV UXU      | Transfer Completed Interrupt Mask        |

### **USBOTG\_DOEPMSK**



Address: Operational Base + offset (0x0814)

Device OUT Endpoint common interrupt mask register

| Bit   | Attr | Reset Value                       | Description                               |
|-------|------|-----------------------------------|-------------------------------------------|
| 31:15 | RO   | 0x0                               | reserved                                  |
| 14    | RW   | 0x0                               | NYETMsk                                   |
| 14    | KVV  | UXU                               | NYET Interrupt Mask                       |
| 13    | RW   | 0×0                               | NAKMsk                                    |
| 13    | KVV  | UXU                               | NAK Interrupt Mask                        |
| 12    | RW   | 0×0                               | BbleErrMsk                                |
| 12    | KVV  | UXU                               | Babble Interrupt Mask                     |
| 11:10 | RO   | 0x0                               | reserved                                  |
| 9     | RW   | 0×0                               | BnaOutIntrMsk                             |
| 9     | KVV  | 0.00                              | BNA interrupt Mask                        |
| 8     | RW   | 0×0                               | OutPktErrMsk                              |
| 0     | KVV  | 0x0                               | OUT Packet Error Mask                     |
| 7     | RO   | 0x0                               | reserved                                  |
|       |      | 0x0                               | Back2BackSETup                            |
| 6     | RW   |                                   | Back-to-Back SETUP Packets Received Mask  |
|       |      |                                   | Applies to control OUT endpoints only.    |
| 5     | RO   | 0x0                               | reserved                                  |
|       |      |                                   | OUTTknEPdisMsk                            |
| 4     | RW   | 0×0                               | OUT Token Received when Endpoint Disabled |
| -     |      |                                   | Mask                                      |
|       |      |                                   | Applies to control OUT endpoints only.    |
|       |      |                                   | SetUPMsk                                  |
| 3     | RW   | 0x0                               | SETUP Phase Done Mask                     |
|       |      | 1.5                               | Applies to control endpoints only.        |
| 2     | RW   | 0x0                               | AHBErrMsk                                 |
| _     | 1200 | SAG /                             | AHB Error                                 |
| 1     | RW   | 0×0                               | EPDisbldMsk                               |
|       |      |                                   | Endpoint Disabled Interrupt Mask          |
| 0     | RW   | RW 0x0                            | XferComplMsk                              |
| C KVV |      | Transfer Completed Interrupt Mask |                                           |

## **USBOTG\_DAINT**

Address: Operational Base + offset (0x0818)

Device All Endpoints interrupt register

| Bit   | Attr | Reset Value | Description                              |
|-------|------|-------------|------------------------------------------|
|       | RO   | 0x0000      | OutEPInt                                 |
| 21.16 |      |             | OUT Endpoint Interrupt Bits              |
| 31:16 |      |             | One bit per OUT endpoint: Bit 16 for OUT |
|       |      |             | endpoint 0, bit 31 for OUT endpoint 15   |



| Bit  | Attr | Reset Value | Description                                    |
|------|------|-------------|------------------------------------------------|
| 15:0 | RO   | 0×0000      | InEpInt                                        |
|      |      |             | IN Endpoint Interrupt Bits                     |
|      |      |             | One bit per IN Endpoint: Bit 0 for IN endpoint |
|      |      |             | 0, bit 15 for endpoint 15                      |

## **USBOTG\_DAINTMSK**

Address: Operational Base + offset (0x081c)Device All Endpoint interrupt mask register

| Bit   | Attr | Reset Value | Description                                     |
|-------|------|-------------|-------------------------------------------------|
|       |      | 0x0000      | OutEpMsk                                        |
| 21.16 | RW   |             | OUT EP Interrupt Mask Bits                      |
| 31:16 | KVV  |             | One per OUT Endpoint: Bit 16 for OUT EP 0, bit  |
|       |      |             | 31 for OUT EP 15                                |
| 15:0  | RW   | 0×0000      | InEpMsk                                         |
|       |      |             | IN EP Interrupt Mask Bits                       |
|       |      |             | One bit per IN Endpoint: Bit 0 for IN EP 0, bit |
|       |      |             | 15 for IN EP 15                                 |

### **USBOTG\_DTKNQR1**

Address: Operational Base + offset (0x0820)

Device IN token sequence learning queue read register1

| Bit  | Attr | Reset Value                           | Description                                      |
|------|------|---------------------------------------|--------------------------------------------------|
|      |      |                                       | EPTkn                                            |
|      |      |                                       | Endpoint Token                                   |
|      |      | • 1                                   | Four bits per token represent the endpoint       |
|      |      | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | number of the token:                             |
| 31:8 | RO   | 0x000000                              | Bits [31:28]: Endpoint number of Token 5         |
|      |      |                                       | Bits [27:24]: Endpoint number of Token 4         |
|      | 1    |                                       |                                                  |
|      |      | 7                                     | Bits [15:12]: Endpoint number of Token 1         |
| /    |      |                                       | Bits [11:8]: Endpoint number of Token 0          |
|      |      |                                       | WrapBit                                          |
| 7    | DO.  | 00                                    | Wrap Bit                                         |
| /    | RO   | 0x0                                   | This bit is set when the write pointer wraps. It |
|      |      |                                       | is cleared when the learning queue is cleared.   |
| 6:5  | RO   | 0x0                                   | reserved                                         |
| 4.0  | DO.  | 0.00                                  | INTknWPtr                                        |
| 4:0  | RO   | 0×00                                  | IN Token Queue Write Pointer                     |

## USBOTG\_DTKNQR2

Address: Operational Base + offset (0x0824)

Device IN token sequence learning queue read register2



| Bit  | Attr | Reset Value | Description                                |
|------|------|-------------|--------------------------------------------|
|      |      |             | EPTkn                                      |
|      |      |             | Endpoint Token                             |
|      |      |             | Four bits per token represent the endpoint |
|      |      |             | number of the token:                       |
| 31:0 | RW   | 0x00000000  | Bits [31:28]: Endpoint number of Token 13  |
|      |      |             | Bits [27:24]: Endpoint number of Token 12  |
|      |      |             |                                            |
|      |      |             | Bits [7:4]: Endpoint number of Token 7     |
|      |      |             | Bits [3:0]: Endpoint number of Token 6     |

### **USBOTG\_DVBUSDIS**

Address: Operational Base + offset (0x0828)

Device VBUS discharge time register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                      |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                         |
| 15:0  | RW   | 0x0b8f      | DVBUSDis Device VBUS Discharge Time Specifies the VBUS discharge time after VBUS pulsing during SRP. This value equals:VBUS discharge time in PHY clocks / 1,024.The value you use depends whether the PHY is operating at 30 MHz (16-bit data width) or 60 MHz (8-bit data width). Depending on |
|       |      | . <         | your VBUS load, this value can need adjustment.                                                                                                                                                                                                                                                  |

# USBOTG\_DVBUSPULSE

Address: Operational Base + offset (0x082c)

Device VBUS Pulsing Timer Register

| Bit   | Attr   | Reset Value | Description                                 |
|-------|--------|-------------|---------------------------------------------|
| 31:12 | RO     | 0x0         | reserved                                    |
|       | $\cup$ |             | DVBUSPulse                                  |
|       |        |             | Device VBUS Pulsing Time                    |
| 11:0  | RW     | 0×000       | Specifies the VBUS pulsing time during SRP. |
|       |        |             | This value equals: VBUS pulsing time in PHY |
|       |        |             | clocks / 1,024.The value you use depends    |
|       |        |             | whether the PHY is operating at 30 MHz      |
|       |        |             | (16-bit data width) or 60 MHz (8-bit data   |
|       |        |             | width).                                     |

### **USBOTG\_DTHRCTL**

Address: Operational Base + offset (0x0830)



**Device Threshold Control Register** 

|       | hreshold Control Register |             |                                                    |  |
|-------|---------------------------|-------------|----------------------------------------------------|--|
| Bit   | Attr                      | Reset Value | Description                                        |  |
| 31:28 | RO                        | 0x0         | reserved                                           |  |
|       |                           |             | ArbPrkEn                                           |  |
|       |                           |             | Arbiter Parking Enable                             |  |
|       |                           |             | This bit controls internal DMA arbiter parking     |  |
|       |                           |             | for IN endpoints. When thresholding is enabled     |  |
| 27    | RW                        | 0x1         | and this bit is set to one, then the arbiter parks |  |
|       |                           |             | on the IN endpoint for which there is a token      |  |
|       |                           |             | received on the USB. This is done to avoid         |  |
|       |                           |             | getting into underrun conditions. By default       |  |
|       |                           |             | the parking is enabled.                            |  |
| 26    | RO                        | 0x0         | reserved                                           |  |
|       |                           |             | RxThrLen                                           |  |
|       |                           |             | Receive Threshold Length                           |  |
|       |                           |             | This field specifies Receive thresholding size in  |  |
|       |                           |             | DWORDS. This field also specifies the amount       |  |
|       |                           |             | of data received on the USB before the core        |  |
| 25:17 | RW                        | 0x008       | can start transmitting on the AHB. The             |  |
|       |                           |             | threshold length has to be at least eight          |  |
|       |                           |             | DWORDS.                                            |  |
|       |                           |             | The recommended value for ThrLen is to be the      |  |
|       |                           |             | same as the programmed AHB Burst Length            |  |
|       |                           |             | (GAHBCFG.HBstLen).                                 |  |
|       |                           |             | RxThrEn                                            |  |
| 16    | RW                        | 0x0         | Receive Threshold Enable                           |  |
|       |                           |             | When this bit is set, the core enables             |  |
| 15.10 | D.O.                      |             | thresholding in the receive direction.             |  |
| 15:13 | RO                        | 0x0         | reserved                                           |  |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12:11 | RW   | 0×0         | AHBThrRatio AHB Threshold Ratio These bits define the ratio between the AHB threshold and the MAC threshold for the transmit path only. The AHB threshold always remains less than or equal to the USB threshold, because this does not increase overhead. Both the AHB and the MAC threshold must be DWORD-aligned. The application needs to program TxThrLen and the AHBThrRatio to make the AHB Threshold value DWORD aligned. If the AHB threshold value is not DWORD aligned, the core might not behave correctly. When programming the TxThrLen and AHBThrRatio, the application must ensure that the minimum AHB threshold value does not go below 8 DWORDS to meet the USB turnaround time requirements. 2'b00: AHB threshold = MAC threshold / 2 2'b10: AHB threshold = MAC threshold / 4 2'b11: AHB threshold = MAC threshold / 8 |
| 10:2  | RW   | 0x008       | TxThrLen Transmit Threshold Length This field specifies Transmit thresholding size in DWORDS. This field also forms the MAC threshold and specifies the amount of data, in bytes, to be in the corresponding endpoint transmit FIFO before the core can start a transmit on the USB. When the value of AHBThrRatio is 2'h00, the threshold length must be at least 8 DWORDS. If the AHBThrRatio is nonzero, the application must ensure that the AHB threshold value does not go below the recommended 8 DWORDs. This field controls both isochronous and non-isochronous IN endpoint thresholds. The recommended value for ThrLen is to be the same as the programmed AHB Burst Length (GAHBCFG.HBstLen).                                                                                                                                  |



| Bit | Attr | Reset Value | Description                                |
|-----|------|-------------|--------------------------------------------|
|     |      | 0×0         | ISOThrEn                                   |
| 1   | RW   |             | ISO IN Endpoints Threshold Enable          |
| 1   | KVV  |             | When this bit is set, the core enables     |
|     |      |             | thresholding for isochronous IN endpoints. |
|     | RW   | 0x0         | NonISOThrEn                                |
| 0   |      |             | Non-ISO IN Endpoints Threshold Enable      |
|     |      |             | When this bit is set, the core enables     |
|     |      |             | thresholding for Non Isochronous IN        |
|     |      |             | endpoints.                                 |

#### **USBOTG\_DIEPEMPMSK**

Address: Operational Base + offset (0x0834)

Device IN endpoint FIFO empty interrupt mask register

| Bit   | Attr | Reset Value | Description                                |
|-------|------|-------------|--------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                   |
|       |      |             | InEpTxfEmpMsk                              |
|       |      |             | IN EP Tx FIFO Empty Interrupt Mask Bits    |
|       |      |             | These bits acts as mask bits for DIEPINTn. |
| 15:0  | RW   | 0x0000      | TxFEmp interrupt One bit per IN Endpoint:  |
|       |      |             | Bit 0 for IN endpoint 0                    |
|       |      |             |                                            |
|       |      |             | Bit 15 for endpoint 15                     |

#### **USBOTG\_DEACHINT**

Address: Operational Base + offset (0x0838)Device each endpoint interrupt register

Bit Attr **Reset Value Description** EchOutEPInt **OUT Endpoint Interrupt Bits** One bit per OUT endpoint: 31:16 RO 0x0000 Bit 16 for OUT endpoint 0 Bit 31 for OUT endpoint 15 EchInEpInt IN Endpoint Interrupt Bits One bit per IN Endpoint: 15:0 RO 0x0000 Bit 0 for IN endpoint 0 Bit 15 for endpoint 15

#### **USBOTG DEACHINTMSK**

Address: Operational Base + offset (0x083c)



Device each endpoint interrupt register mask

| Bit   | Attr | Reset Value | Description                |
|-------|------|-------------|----------------------------|
|       |      |             | EchOutEpMsk                |
|       |      |             | OUT EP Interrupt Mask Bits |
| 31:16 | RW   | 0×0000      | One per OUT Endpoint:      |
| 31:16 | KVV  | 00000       | Bit 16 for IN endpoint 0   |
|       |      |             |                            |
|       |      |             | Bit 31 for endpoint 15     |
|       |      |             | EchInEpMsk                 |
|       |      |             | IN EP Interrupt Mask Bits  |
| 15.0  | DW   | 0×0000      | One bit per IN Endpoint:   |
| 15:0  | RW   | 0x0000      | Bit 0 for IN endpoint 0    |
|       |      |             |                            |
|       |      |             | Bit 15 for endpoint 15     |

## **USBOTG\_DIEPEACHMSKn**

Address: Operational Base + offset (0x0840 + 0x4 \* n)

Device each IN endpoint -n interrupt Register

| Bit   | Attr  | <b>Reset Value</b> | Description                              |
|-------|-------|--------------------|------------------------------------------|
| 31:14 | RO    | 0x0                | reserved                                 |
| 13    | RW    | 0x0                | NAKMsk                                   |
| 13    | KVV   | UXU                | NAK interrupt Mask                       |
| 12:10 | RO    | 0x0                | reserved                                 |
| 9     | RW    | 0x0                | BNAInIntrMsk                             |
| 9     | KVV   | UXU                | BNA interrupt Mask                       |
| 8     | RW    | 0×0                | TxfifoUndrnMsk                           |
| 0     | KVV   | OXO                | Fifo Under run Mask                      |
| 7     | RO    | 0x0                | reserved                                 |
| 6     | RW    | 0x0                | INEPNakEffMsk                            |
| 0     | KVV   |                    | IN Endpoint NAK Effective Mask           |
| 5     | RW    | 0x0                | INTknEPMisMsk                            |
| 3     | KVV   |                    | IN Token received with EP Mismatch Mask  |
| 4     | RW    | 0x0                | INTknTXFEmpMsk                           |
| Т     | IXVV  |                    | IN Token Received When TxFIFO Empty Mask |
| ,     |       |                    | TimeOUTMsk                               |
| 3     | RW    | 0x0                | Timeout Condition Mask(Non-isochronous   |
|       |       |                    | endpoints)                               |
| 2     | RW    | 0×0                | AHBErrMsk                                |
|       | IXVV  | UXU                | AHB Error Mask                           |
| 1     | RW    | 0x0                | EPDisbldMsk                              |
| 1     | IVV   |                    | Endpoint Disabled Interrupt Mask         |
| 0     | RW    | 0×0                | XferComplMsk                             |
| U     | IK VV | UXU                | Transfer Completed Interrupt Mask        |



## **USBOTG\_DOEPEACHMSKn**

Address: Operational Base + offset (0x0880 + 0x4 \* n)  $0 \le n \le 15$ 

Device each out endpoint-n interrupt register

| Bit   | Attr | Reset Value | Description                               |
|-------|------|-------------|-------------------------------------------|
| 31:15 | RO   | 0x0         | reserved                                  |
| 14    | RW   | 0x0         | NYETMsk                                   |
| 14    | KW   | UXU         | NYET interrupt Mask                       |
| 13    | RW   | 0×0         | NAKMsk                                    |
| 13    | KVV  | UXU         | NAK interrupt Mask                        |
| 12    | RW   | 0×0         | BbleErrMsk                                |
| 12    | INVV | 0.00        | Babble interrupt Mask                     |
| 11:10 | RO   | 0x0         | reserved                                  |
| 9     | RW   | 0×0         | BnaOutIntrMsk                             |
|       | IXVV | 0.00        | BNA interrupt Mask                        |
| 8     | RW   | 0×0         | OutPktErrMsk                              |
|       | IXVV | 0.00        | OUT Packet Error Mask                     |
| 7     | RO   | 0x0         | reserved                                  |
|       |      |             | Back2BackSETup                            |
| 6     | RW   | 0x0         | Back-to-Back SETUP Packets Received Mask  |
|       |      |             | Applies to control OUT endpoints only.    |
| 5     | RO   | 0x0         | reserved                                  |
|       |      |             | OUTTknEPdisMsk                            |
| 4     | RW   | 0×0         | OUT Token Received when Endpoint Disabled |
| •     | INVV |             | Mask                                      |
|       |      |             | Applies to control OUT endpoints only.    |
|       |      |             | SetUPMsk                                  |
| 3     | RW   | 0x0         | SETUP Phase Done Mask                     |
|       |      | A Y         | Applies to control endpoints only.        |
| 2     | RW 1 | 0x0         | AHBErrMsk                                 |
| _     | KVV  | UXU         | AHB Error                                 |
| 1     | RW   | 0x0         | EPDisbldMsk                               |
|       | IXVV |             | Endpoint Disabled Interrupt Mask          |
| 0     | RW   | 0x0         | XferComplMsk                              |
| 0     | ILAA |             | Transfer Completed Interrupt Mask         |

### **USBOTG\_DIEPCTLO**

Address: Operational Base + offset (0x0900) Device control IN endpoint 0 control register

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|



| Bit   | Attr  | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|-------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | R/WSC | 0x0         | EPEna Endpoint Enable When Scatter/Gather DMA mode is enabled, for IN endpoints this bit indicates that the descriptor structure and data buffer with data ready to transmit is setup. When Scatter/Gather DMA mode is disabled-such as in buffer-pointer based DMA mode-this bit indicates that data is ready to be transmitted on the endpoint. The core clears this bit before setting the following interrupts on this endpoint: Endpoint Disabled; Transfer Completed. |
| 30    | R/WSC | 0x0         | EPDis Endpoint Disable The application sets this bit to stop transmitting data on an endpoint, even before the transfer for that endpoint is complete. The application must wait for the Endpoint Disabled interrupt before treating the endpoint as disabled. The core clears this bit before setting the Endpoint Disabled Interrupt. The application must set this bit only if Endpoint Enable is already set for this endpoint.                                         |
| 29:28 | RO    | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 27    | wo    | 0x0         | SNAK Set NAK A write to this bit sets the NAK bit for the endpoint. Using this bit, the application can control the transmission of NAK handshakes on an endpoint. The core can also set this bit for an endpoint after a SETUP packet is received on that endpoint.                                                                                                                                                                                                        |
| 26    | WO    | 0x0         | CNAK Clear NAK A write to this bit clears the NAK bit for the endpoint.                                                                                                                                                                                                                                                                                                                                                                                                     |
| 25:23 | RO    | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |



| Bit   | Attr   | Reset Value | Description                                     |
|-------|--------|-------------|-------------------------------------------------|
|       |        |             | TxFNum                                          |
|       |        |             | TxFIFO Number                                   |
|       |        |             | For Shared FIFO operation, this value is        |
| 22    | DW     | 00          | always set to 0, indicating that control IN     |
| 22    | RW     | 0x0         | endpoint 0 data is always written in the        |
|       |        |             | Non-Periodic Transmit FIFO. For Dedicated       |
|       |        |             | FIFO operation, this value is set to the FIFO   |
|       |        |             | number that is assigned to IN Endpoint 0.       |
|       |        |             | Stall                                           |
|       |        |             | STALL Handshake                                 |
|       |        |             | The application can only set this bit, and the  |
| 2.1   | D /MCC | 00          | core clears it, when a SETUP token is received  |
| 21    | R/WSC  | 0x0         | for this endpoint. If a NAK bit, Global         |
|       |        |             | Non-periodic IN NAK, or Global OUT NAK is set   |
|       |        |             | along with this bit, the STALL bit takes        |
|       |        |             | priority.                                       |
| 20    | RO     | 0x0         | reserved                                        |
|       |        |             | EPType                                          |
| 19:18 | RO     | 0x0         | Endpoint Type                                   |
|       |        |             | Hardcoded to 00 for control                     |
|       |        |             | NAKSts                                          |
|       |        |             | NAK Status                                      |
|       |        |             | Indicates the following:                        |
|       |        |             | 1'b0: The core is transmitting non-NAK          |
|       |        | • ()        | handshakes based on the FIFO status             |
|       |        | . 7.5       | 1'b1: The core is transmitting NAK              |
| 17    | RO     | 0x0         | handshakes on this endpoint.                    |
|       |        |             | When this bit is set, either by the application |
|       | 11     |             | or core, the core stops transmitting data, even |
|       | 63     | ,           | if there is data available in the TxFIFO.       |
|       |        |             | Irrespective of this bit's setting, the core    |
| 0     |        |             | always responds to SETUP data packets with      |
|       | 1      |             | an ACK handshake.                               |
| 16    | RO     | 0x0         | reserved                                        |
|       |        |             | USBActEP                                        |
|       |        |             | USB Active Endpoint                             |
| 15    | RO     | 0x1         | This bit is always set to 1, indicating that    |
|       |        |             | control endpoint 0 is always active in all      |
|       |        |             | configurations and interfaces.                  |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                             |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14:11 | RW   | 0x0         | NextEp Next Endpoint Applies to non-periodic IN endpoints only. Indicates the endpoint number to be fetched after the data for the current endpoint is fetched. The core can access this field, even when the Endpoint Enable (EPEna) bit is not set. This field is not valid in Slave mode. Note: This field is valid only for Shared FIFO operations. |
| 10:2  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                |
| 1:0   | RW   | 0×0         | MPS Maximum Packet Size Applies to IN and OUT endpoints. The application must program this field with the maximum packet size for the current logical endpoint.  2'b00: 64 bytes 2'b01: 32 bytes 2'b10: 16 bytes 2'b11: 8 bytes                                                                                                                         |

## **USBOTG\_DIEPINTn**

Address: Operational Base + offset (0x0908 + 0x20 \* n)  $0 \le n \le 15$ 

Device Endpoint-n Interrupt Register

| Bit   | Attr | Reset Value | Description                                       |
|-------|------|-------------|---------------------------------------------------|
| 31:15 | RO   | 0x0         | reserved                                          |
|       |      |             | NYETIntrpt                                        |
|       | 1    |             | NYET interrupt                                    |
| 14    | W1C  | 0x0         | The core generates this interrupt when a NYET     |
|       |      |             | response is transmitted for a non                 |
|       |      |             | isochronous OUT endpoint.                         |
|       |      |             | NAKIntrpt                                         |
| Y     |      |             | NAK interrupt                                     |
|       |      |             | The core generates this interrupt when a NAK is   |
| 13    | W1C  | 0x0         | transmitted or received by the device. In case of |
|       |      |             | isochronous IN endpoints the interrupt gets       |
|       |      |             | generated when a zero length packet is            |
|       |      |             | transmitted due to un-availability of data in the |
|       |      |             | TXFifo.                                           |



| Bit | Attr | Reset Value | Description                                      |
|-----|------|-------------|--------------------------------------------------|
|     |      |             | BbleErrIntrpt                                    |
| 12  | W1C  | 0×0         | BbleErr (Babble Error) interrupt                 |
| 12  | WIC  | UXU         | The core generates this interrupt when babble    |
|     |      |             | is received for the endpoint.                    |
|     |      |             | PktDrpSts                                        |
|     |      |             | Packet Dropped Status                            |
|     |      |             | This bit indicates to the application that an    |
|     |      |             | ISOC OUT packet has been dropped. This bit       |
| 11  | W1C  | 0x0         | does not have an associated mask bit and does    |
|     |      |             | not generate an interrupt. Dependency: This      |
|     |      |             | bit is valid in non Scatter/Gather DMA mode      |
|     |      |             | when periodic transfer interrupt feature is      |
|     |      |             | selected.                                        |
| 10  | RO   | 0x0         | reserved                                         |
|     |      |             | BNAIntr                                          |
|     |      |             | BNA (Buffer Not Available) Interrupt             |
|     |      |             | The core generates this interrupt when the       |
| 9   | W1C  | 0x0         | descriptor accessed is not ready for the Core to |
|     |      |             | process, such as Host busy or DMA done           |
|     |      |             | Dependency: This bit is valid only when          |
|     |      |             | Scatter/Gather DMA mode is enabled.              |
|     |      |             | TxfifoUndrn                                      |
|     |      |             | FIFO Underrun                                    |
|     |      |             | Applies to IN endpoints only. The core           |
|     |      |             | generates this interrupt when it detects a       |
|     |      |             | transmit FIFO underrun condition for this        |
|     |      |             | endpoint. Dependency: This interrupt is valid    |
|     |      |             | only when both of the following conditions are   |
| 8   | W1C  | 0×0         | true: Parameter OTG_EN_DED_TX_FIFO==1;           |
|     |      | )<br>)      | Thresholding is enabled; OUT Packet              |
|     |      |             | Error(OutPktErr). Applies to OUT endpoints       |
|     |      |             | only. This interrupt is asserted when the core   |
|     | ~    |             | detects an overflow or a CRC error for an OUT    |
| 7   |      |             | packet. Dependency: This interrupt is valid only |
|     |      |             | when both of the following conditions are true:  |
|     |      |             | Parameter OTG_EN_DED_TX_FIFO==1;                 |
|     |      |             | Thresholding is enabled.                         |

| Bit | Attr | Reset Value | Description                                        |
|-----|------|-------------|----------------------------------------------------|
|     |      |             | TxFEmp                                             |
|     |      |             | Transmit FIFO Empty                                |
|     |      |             | This bit is valid only for IN Endpoints.This       |
|     |      |             | interrupt is asserted when the TxFIFO for this     |
| 7   | W1C  | 0x0         | endpoint is either half or completely empty.       |
|     |      |             | The half or completely empty status is             |
|     |      |             | determined by the TxFIFO Empty Level bit in        |
|     |      |             | the Core AHB Configuration register                |
|     |      |             | (GAHBCFG.NPTxFEmpLvI)).                            |
|     |      |             | INEPNakEff                                         |
|     |      |             | IN Endpoint NAK Effective                          |
|     |      | 0×0         | Applies to periodic IN endpoints only. This bit    |
|     |      |             | can be cleared when the application clears the     |
|     |      |             | IN endpoint NAK by writing to DIEPCTLn.CNAK.       |
|     |      |             | This interrupt indicates that the core has         |
|     | W1C  |             | sampled the NAK bit set (either by the             |
|     |      |             | application or by the core). The interrupt         |
|     |      |             | indicates that the IN endpoint NAK bit set by      |
| 6   |      |             | the application has taken effect in the core. This |
|     |      |             | interrupt does not guarantee that a NAK            |
|     |      |             | handshake is sent on the USB. A STALL bit          |
|     |      |             | takes priority over a NAK bit. This bit is         |
|     |      |             | applicable only when the endpoint is enabled.      |
|     |      |             | Back-to-Back SETUP Packets Received                |
|     |      |             | (Back2BackSETup) Applies to Control OUT            |
|     |      |             | endpoints only.                                    |
|     |      | N. Y        | This bit indicates that the core has received      |
|     |      |             | more than three back-to-back SETUP                 |
|     | A 1  |             | packets for this particular endpoint.              |



| Bit | Attr | Reset Value | Description                                        |
|-----|------|-------------|----------------------------------------------------|
|     |      |             | INTknEPMis                                         |
|     |      |             | IN Token Received with EP Mismatch                 |
|     |      |             | Applies to non-periodic IN endpoints only.         |
|     |      |             | Indicates that the data in the top of the          |
|     |      |             | non-periodic TxFIFO belongs to an endpoint         |
|     |      |             | other than the one for which the IN token was      |
|     |      |             | received. This interrupt is asserted on the        |
|     |      |             | endpoint for which the IN token was received.      |
|     |      |             | Status Phase Received For Control Write            |
|     |      |             | (StsPhseRcvd)                                      |
|     |      |             | This interrupt is valid only for Control OUT       |
| 5   | W1C  | 0x0         | endpoints and only in Scatter Gather DMA           |
|     |      |             | mode. This interrupt is generated only after the   |
|     |      |             | core has transferred all the data that the host    |
|     |      |             | has sent during the data phase of a control        |
|     |      |             | write transfer, to the system memory buffer.       |
|     |      |             | The interrupt indicates to the application that    |
|     |      |             | the host has switched from data phase to the       |
|     |      |             | status phase of a Control Write transfer. The      |
|     |      |             | application can use this interrupt to ACK or       |
|     |      |             | STALL the Status phase, after it has decoded       |
|     |      |             | the data phase. This is applicable only in case of |
|     |      |             | Scatter Gather DMA mode.                           |
|     |      |             | INTknTXFEmp                                        |
|     |      |             | IN Token Received When TxFIFO is Empty             |
|     |      | 1           | Indicates that an IN token was received when       |
|     |      | My y        | the associated TxFIFO periodic/nonperiodic)        |
|     |      |             | was empty. This interrupt is asserted on the       |
| 4   | W1C  | 0x0         | endpoint for which the IN token was received.      |
|     |      | 7           | OUT Token Received When Endpoint Disabled          |
|     |      |             | (OUTTknEPdis) Indicates that an OUT token          |
|     |      |             | was received when the endpoint was not yet         |
|     | ·    |             | enabled. This interrupt is asserted on the         |
|     |      |             | endpoint for which the OUT token was received.     |

| Bit | Attr | Reset Value | Description                                     |
|-----|------|-------------|-------------------------------------------------|
|     |      |             | TimeOUT                                         |
|     |      |             | Timeout Condition                               |
|     |      |             | In shared TX FIFO mode, applies to              |
|     |      |             | non-isochronous IN endpoints only. In           |
|     |      | 0×0         | dedicated FIFO mode, applies only to Control    |
|     |      |             | IN endpoints. In Scatter/Gather DMA mode,       |
|     |      |             | the TimeOUT interrupt is not asserted.          |
|     |      |             | Indicates that the core has detected a timeout  |
| 3   | W1C  |             | condition on the USB for the last IN token on   |
|     |      |             | this endpoint.                                  |
|     |      |             | SETUP Phase Done (SetUp) Applies to control     |
|     |      |             | OUT endpoints only. Indicates that the SETUP    |
|     |      |             | phase for the control endpoint is complete and  |
|     |      |             | no more back-to-back SETUP packets were         |
|     |      |             | received for the current control transfer. On   |
|     |      |             | this interrupt, the application can decode the  |
|     |      |             | received SETUP data packet.                     |
|     |      | 0×0         | AHBErr                                          |
|     |      |             | AHB Error                                       |
|     |      |             | Applies to IN and OUT endpoints. This is        |
| 2   | W1C  |             | generated only in Internal DMA mode when        |
|     | Wic  |             | there is an AHB error during an AHB read/write. |
|     |      |             | The application can read the corresponding      |
|     |      |             | endpoint DMA address register to get the error  |
|     |      |             | address.                                        |
| 1   |      | 0x0         | EPDisbld                                        |
|     |      |             | Endpoint Disabled Interrupt                     |
|     | W1C  |             | Applies to IN and OUT endpoints. This bit       |
|     | 1    |             | indicates that the endpoint is disabled per the |
|     |      | 7           | application's request.                          |



| Bit        | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b> | W1C  | 0x0         | XferCompl Transfer Completed Interrupt Applies to IN and OUT endpoints. When Scatter/Gather DMA mode is enabled: For IN endpoint this field indicates that the requested data from the descriptor is moved from external system memory to internal FIFO. For OUT endpoint this field indicates that the requested data from the internal FIFO is moved to external system memory. This interrupt is generated only when the corresponding endpoint descriptor is closed, and the IOC bit for the corresponding descriptor is set. When Scatter/Gather DMA mode is disabled, this field indicates that the programmed transfer is complete on the AHB as well as on the USB, for this endpoint. |

### **USBOTG\_DIEPTSIZn**

Address: Operational Base + offset  $(0x0910 + 0x20 * n)1 \le n \le 15$ 

Device endpoint n transfer size register

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



| Bit   | Attr       | Reset Value | Description                                        |
|-------|------------|-------------|----------------------------------------------------|
|       |            |             | MC                                                 |
|       |            |             | Multi Count                                        |
|       |            |             | Applies to IN endpoints only. For periodic IN      |
|       |            |             | endpoints, this field indicates the number of      |
|       |            |             | packets that must be transmitted per               |
|       |            |             | microframe on the USB. The core uses this field    |
|       |            |             | to calculate the data PID for isochronous IN       |
|       |            |             | endpoints.                                         |
|       |            |             | 2'b01: 1 packet                                    |
|       |            |             | 2'b10: 2 packets                                   |
|       |            |             | 2'b11: 3 packets                                   |
|       |            |             | For non-periodic IN endpoints, this field is valid |
|       |            |             | only in Internal DMA mode. It specifies the        |
|       |            |             | number of packets the core must fetch for an IN    |
|       |            |             | endpoint before it switches to the endpoint        |
|       |            |             | pointed to by the Next Endpoint field of the       |
| 30:29 | RW         | 0x0         | Device Endpoint-n Control register                 |
|       |            |             | (DIEPCTLn.NextEp). Received Data PID               |
|       |            |             | (RxDPID)                                           |
|       |            |             | Applies to isochronous OUT endpoints only.         |
|       |            |             | This is the data PID received in the last packet   |
|       |            |             | for this endpoint.                                 |
|       |            |             | 2'b00: DATA0                                       |
|       |            |             | 2'b01: DATA2                                       |
|       |            |             | 2'b10: DATA1                                       |
|       |            | 1           | 2'b11: MDATA                                       |
|       |            | V Y         | SETUP Packet Count (SUPCnt).Applies to             |
|       |            |             | control OUT Endpoints only. This field specifies   |
|       | <b>A</b> 1 |             | the number of back-to-back SETUP data              |
|       |            |             | packets the endpoint can receive.                  |
|       |            |             | 2'b01: 1 packet                                    |
|       |            |             | 2'b10: 2 packets                                   |
|       |            |             | 2'b11: 3 packets                                   |



| Bit   | Attr | Reset Value | Description                                        |
|-------|------|-------------|----------------------------------------------------|
|       |      |             | PktCnt                                             |
|       |      |             | Packet Count                                       |
|       |      |             | Indicates the total number of USB packets that     |
|       |      |             | constitute the Transfer Size amount of data for    |
|       |      |             | this endpoint. The power-on value is specified     |
|       |      |             | for Width of Packet Counters during IP             |
| 20.10 | RW   | 0,,000      | configuration (parameter                           |
| 28:19 | KVV  | 0x000       | OTG_PACKET_COUNT_WIDTH). IN Endpoints:             |
|       |      |             | This field is decremented every time a packet      |
|       |      |             | (maximum size or short packet) is read from        |
|       |      |             | the TxFIFO. OUT Endpoints: This field is           |
|       |      |             | decremented every time a packet (maximum           |
|       |      |             | size or                                            |
|       |      |             | short packet) is written to the RxFIFO.            |
|       |      |             | XferSize                                           |
|       |      |             | Transfer Size                                      |
|       |      |             | This field contains the transfer size in bytes for |
|       |      |             | the current endpoint. The power-on value is        |
|       |      |             | specified for Width of Transfer Size Counters      |
|       |      |             | during IP configuration (parameter                 |
|       |      |             | OTG_TRANS_COUNT_WIDTH). The core only              |
|       |      |             | interrupts the application after it has exhausted  |
| 18:0  | RW   | 0x00000     | the transfer size amount of data. The transfer     |
|       |      |             | size can be set to the maximum packet size of      |
|       |      | • 4         | the endpoint, to be interrupted at the end of      |
|       |      |             | each packet. IN Endpoints: The core                |
|       |      |             | decrements this field every time a packet from     |
|       |      | ()          | the external memory is written to the              |
|       | 1    |             | TxFIFO.OUT Endpoints: The core decrements          |
|       |      | · ·         | this field every time a packet is read from the    |
|       |      |             | RxFIFO and written to the external memory.         |

## USBOTG\_DIEPDMAn

Address: Operational Base + offset (0x0914 + 0x20 \* n)  $0 \le n \le 15$ 

Device endpoint-n DMA address register

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
|-----|------|-------------|-------------|



| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0×00000000  | DMAAddr DMA Address Holds the start address of the external memory for storing or fetching endpoint data. Note: For control endpoints, this field stores control OUT data packets as well as SETUP transaction data packets. When more than three SETUP packets are received back-to-back, the SETUP data packet in the memory is overwritten. This register is incremented on every AHB transaction. The application can give only a DWORD-aligned address. When Scatter/Gather DMA mode is not enabled, the application programs the start address value in this field. When Scatter/Gather DMA mode is enabled, this field indicates the base pointer for the descriptor list. |

## **USBOTG\_DTXFSTSn**

Address: Operational Base + offset (0x0918 + 0x20 \* n)0≤n≤15

Device IN endpoint transmit FIFO status register

| Bit   | Attr | Reset Value | Description                                     |
|-------|------|-------------|-------------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                        |
|       |      | . ()        | INEPTxFSpcAvail                                 |
|       |      |             | IN Endpoint TxFIFO Space Avail                  |
|       |      |             | Indicates the amount of free space available in |
|       |      |             | the Endpoint TxFIFO.Values are in terms of      |
|       | 11   |             | 32-bit words.                                   |
| 15:0  | RW   | 0×0000      | 16'h0: Endpoint TxFIFO is full                  |
| 13.0  | KVV  | 00000       | 16'h1: 1 word available                         |
|       |      |             | 16'h2: 2 words available                        |
|       | ,    |             | 16'hn: n words available (where 0 . n .         |
|       |      |             | 32,768)                                         |
|       |      |             | 16'h8000: 32,768 words available                |
|       |      |             | Others: Reserved                                |

## **USBOTG\_DIEPDMABn**

Address: Operational Base + offset (0x091c + 0x20 \* n)  $0 \le n \le 15$ 

Device endpoint-n DMA buffer address register

| Bit Attr Reset Value Description |
|----------------------------------|
|----------------------------------|



| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                           |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0×00000000  | DMABufferAddr DMA Buffer Address Holds the current buffer address. This register is updated as and when the data transfer for the corresponding end point is in progress. This register is present only in Scatter/Gather DMA mode. Otherwise this field is reserved. |

## USBOTG\_DIEPCTLn

Address: Operational Base + offset (0x0920 + 0x20 \* n)  $0 \le n \le 14$ 

Device endpoint-n control register

| Bit | Attr     | Reset Value   | Description                                      |
|-----|----------|---------------|--------------------------------------------------|
|     |          |               | EPEna                                            |
|     |          |               | Endpoint Enable                                  |
|     |          |               | Applies to IN and OUT endpoints. When            |
|     |          |               | Scatter/Gather DMA mode is enabled, For IN       |
|     |          |               | endpoints this bit indicates that the descriptor |
|     |          |               | structure and data buffer with data ready to     |
|     |          |               | transmit is setup. For OUT endpoint it           |
|     |          |               | indicates that the descriptor structure and      |
|     |          |               | data buffer to receive data is setup. When       |
|     |          |               | Scatter/Gather DMA mode is enabled-such as       |
| 31  | R/WSC    | 0x0           | for buffer-pointer based DMA mode: For IN        |
|     | 1,4,11,5 | • 0           | endpoints, this bit indicates that data is ready |
|     |          | A ~ Y         | to be transmitted on the endpoint; For OUT       |
|     |          |               | endpoints, this bit indicates that the           |
|     |          | $C_{\lambda}$ | application has allocated the memory to start    |
|     |          |               | receiving data from the USB. The core clears     |
|     | (3)      | · _           | this bit before setting any of the following     |
|     |          |               | interrupts on this endpoint: SETUP Phase         |
|     | $\cup$   |               | Done, Endpoint Disabled, Transfer                |
|     | 1        |               | Completed. Note: For control endpoints in        |
|     |          |               | DMA mode, this bit must be set to be able to     |
|     |          |               | transfer SETUP data packets in memory.           |



| Bit | Attr  | Reset Value | Description                                     |
|-----|-------|-------------|-------------------------------------------------|
|     |       |             | EPDis                                           |
|     |       |             | Endpoint Disable                                |
|     |       |             | Applies to IN and OUT endpoints. The            |
|     |       |             | application sets this bit to stop               |
|     |       |             | transmitting/receiving data on an endpoint,     |
|     |       |             | even before the transfer for that endpoint is   |
| 30  | R/WSC | 0x0         | complete. The application must wait for the     |
|     |       |             | Endpoint Disabled interrupt before treating the |
|     |       |             | endpoint as disabled. The core clears this bit  |
|     |       |             | before setting the Endpoint Disabled interrupt. |
|     |       |             | The application must set this bit only if       |
|     |       |             | Endpoint Enable is already set for this         |
|     |       |             | endpoint.                                       |
|     |       |             | SetD1PID                                        |
|     |       |             | Set DATA1 PID                                   |
|     |       |             | Applies to interrupt/bulk IN and OUT            |
|     |       |             | endpoints only. Writing to this field sets the  |
|     |       |             | Endpoint Data PID (DPID) field in this register |
|     |       |             | to DATA1.This field is applicable both for      |
| 29  | WO    | 0x0         | Scatter/Gather DMA mode and                     |
|     |       |             | non-Scatter/Gather DMA mode. Set Odd            |
|     |       |             | (micro)frame (SetOddFr). Applies to             |
|     |       |             | isochronous IN and OUTendpoints only.           |
|     |       |             | Writing to this field sets the Even/Odd         |
|     |       | • . 1       | (micro)frame (EO_FrNum) field to odd            |
|     |       |             | (micro)frame. This field is not applicable for  |
|     |       |             | Scatter/Gather DMA mode.                        |



| Bit | Attr | Reset Value | Description                                           |
|-----|------|-------------|-------------------------------------------------------|
|     |      |             | SetD0PID                                              |
|     |      |             | Set DATA0 PID                                         |
|     |      |             | Applies to interrupt/bulk IN and OUT                  |
|     |      |             | endpoints only.Writing to this field sets the         |
|     |      |             | Endpoint Data PID (DPID) field in this register       |
|     |      |             | to DATA0.This field is applicable both for            |
|     |      |             | Scatter/Gather DMA mode and                           |
|     |      |             | non-Scatter/Gather DMA mode. In                       |
|     |      |             | non-Scatter/Gather DMA mode: Set Even                 |
| 28  | WO   | 0x0         | (micro)frame (SetEvenFr) Applies to                   |
|     |      |             | isochronous IN and OUT endpoints only.                |
|     |      |             | Writing to this field sets the Even/Odd               |
|     |      |             | (micro)frame (EO_FrNum) field to even                 |
|     |      |             | (micro)frame. When Scatter/Gather DMA                 |
|     |      |             | mode is enabled, this field is reserved. The          |
|     |      |             | frame number in which to send data is in the          |
|     |      |             | transmit descriptor structure. The frame in           |
|     |      |             | which to receive data is updated in receive           |
|     |      |             | descriptor structure.                                 |
|     |      |             | SNAK                                                  |
|     |      |             | Set NAK                                               |
|     |      |             | Applies to IN and OUT endpoints. A write to           |
|     |      |             | this bit sets the NAK bit for the endpoint. Using     |
| 27  | WO   | 0x0         | this bit, the application can control the             |
|     |      | • 40        | transmission of NAK handshakes on an                  |
|     |      |             | endpoint. The core can also set this bit for OUT      |
|     |      |             | endpoints on a Transfer Completed interrupt,          |
|     |      |             | or after a SETUP is received on the endpoint.         |
|     | 1    |             | CNAK                                                  |
| 26  | WO   | 0x0         | Clear NAK Applies to IN and OUT endpoints. A write to |
|     |      |             |                                                       |
|     |      |             | this bit clears the NAK bit for the endpoint.         |



| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25:22 | RW   | 0x0         | TxFNum TxFIFO Number Shared FIFO Operation:non-periodic endpoints must set this bit to zero. Periodic endpoints must map this to the corresponding Periodic TxFIFO number. 4'h0: Non-Periodic TxFIFO; Others: Specified Periodic TxFIFO number. Note: An interrupt IN endpoint can be configured as a non-periodic endpoint for applications such as mass storage. The core treats an IN endpoint as a non-periodic endpoint if the TxFNum field is set to 0. Otherwise, a separate periodic FIFO must be allocated for an interrupt IN endpoint, and the number of this FIFO must be programmed into the TxFNum field. Configuring an interrupt IN endpoint as a non-periodic endpoint saves the extra periodic FIFO area. Dedicated FIFO Operation:these bits specify the FIFO number associated with this endpoint. Each active IN endpoint must be programmed to a separate FIFO number. This field is valid only for IN endpoints. |
| 21    | RW   | 0x0         | Stall STALL Handshake Applies to non-control, non-isochronous IN and OUT endpoints only. The application sets this bit to stall all tokens from the USB host to this endpoint. If a NAK bit, Global Non-periodic IN NAK, or Global OUT NAK is set along with this bit, the STALL bit takes priority. Only the application can clear this bit, never the core. Applies to control endpoints only. The application can only set this bit, and the core clears it, when a SETUP token is received for this endpoint. If a NAK bit, Global Non-periodic IN NAK, or Global OUT NAK is set along with this bit, the STALL bit takes priority. Irrespective of this bit's setting, the core always responds to SETUP data packets with an ACK handshake.                                                                                                                                                                                       |



| Bit   | Attr | Reset Value | Description                                      |
|-------|------|-------------|--------------------------------------------------|
|       |      |             | Snp                                              |
|       |      |             | Snoop Mode                                       |
|       |      |             | Applies to OUT endpoints only. This bit          |
| 20    | RW   | 0x0         | configures the endpoint to Snoop mode. In        |
|       |      |             | Snoop mode, the core does not check the          |
|       |      |             | correctness of OUT packets before transferring   |
|       |      |             | them to application memory.                      |
|       |      |             | EPType                                           |
|       |      |             | Endpoint Type                                    |
|       |      |             | Applies to IN and OUT endpoints. This is the     |
|       |      |             | transfer type supported by this logical          |
| 19:18 | RW   | 0x0         | endpoint.                                        |
|       |      |             | 2'b00: Control                                   |
|       |      |             | 2'b01: Isochronous                               |
|       |      |             | 2'b10: Bulk                                      |
|       |      |             | 2'b11: Interrupt                                 |
|       |      |             | NAKSts                                           |
|       |      |             | NAK Status                                       |
|       |      |             | Applies to IN and OUT endpoints. Indicates the   |
|       |      |             | following:                                       |
|       |      |             | 1'b0: The core is transmitting non-NAK           |
|       |      |             | handshakes based on the FIFO status.             |
|       |      |             | 1'b1: The core is transmitting NAK               |
|       |      |             | handshakes on this endpoint.                     |
|       |      | . ()        | When either the application or the core sets     |
| 17    | RO   | 0x0         | this bit: The core stops receiving any data on   |
|       |      |             | an OUT endpoint, even if there is space in the   |
|       |      | ()          | RxFIFO to accommodate the incoming packet.       |
|       | 11   |             | For non-isochronous IN endpoints: The core       |
|       | C    | ,           | stops transmitting any data on an IN endpoint,   |
|       |      |             | even if there data is available in the TxFIFO.   |
|       |      |             | For isochronous IN endpoints: The core sends     |
|       | V    |             | out a zero-length data packet, even if there     |
| 7     |      |             | data is available in the TxFIFO. Irrespective of |
|       |      |             | this bit's setting, the core always responds to  |
|       |      |             | SETUP data packets with an ACK handshake.        |



| Bit | Attr   | Reset Value | Description                                                                          |
|-----|--------|-------------|--------------------------------------------------------------------------------------|
|     |        |             | DPID                                                                                 |
|     |        |             | Endpoint Data PID                                                                    |
|     |        |             | Applies to interrupt/bulk IN and OUT                                                 |
|     |        |             | endpoints only. Contains the PID of the packet                                       |
|     |        |             | to be received or transmitted on this endpoint.                                      |
|     |        |             | The application must program the PID of the                                          |
|     |        |             | first packet to be received or transmitted on                                        |
|     |        |             | this endpoint, after the endpoint is activated.                                      |
|     |        |             | The applications use the SetD1PID and                                                |
|     |        |             | SetD0PID fields of this register to program                                          |
|     |        |             | either DATA0 or DATA1 PID.                                                           |
|     |        |             | 1'b0: DATA0                                                                          |
|     |        |             | 1'b1: DATA1                                                                          |
|     |        |             | This field is applicable both for Scatter/Gather                                     |
|     |        |             | DMA mode and non-Scatter/Gather                                                      |
|     |        |             | DMA mode.Even/Odd (Micro)Frame                                                       |
| 16  | RO     | 0x0         | (EO_FrNum) In non-Scatter/Gather DMA                                                 |
|     |        | OXO .       | mode:                                                                                |
|     |        |             | Applies to isochronous IN and OUT endpoints                                          |
|     |        |             | only.Indicates the (micro) rame number in                                            |
|     |        |             | which the core transmits/receives isochronous                                        |
|     |        |             | data for this endpoint. The application must                                         |
|     |        |             | program the even/odd (micro) frame number                                            |
|     |        |             | in which it intends to transmit/receive                                              |
|     |        | • ()        | isochronous data for this endpoint using the                                         |
|     |        |             | SetEvnFr and SetOddFr fields in this register.                                       |
|     |        |             | 1'b0: Even (micro)frame                                                              |
|     |        | ()          | 1'b1: Odd (micro)frame                                                               |
|     | 11     |             | When Scatter/Gather DMA mode is enabled, this field is reserved. The frame number in |
|     | 63     | ,           | which to send data is provided in the transmit                                       |
|     |        |             | descriptor structure. The frame in which data                                        |
|     | $\cup$ |             | is received is updated in receive descriptor                                         |
|     | Y      |             |                                                                                      |
|     |        |             | structure.                                                                           |



| Bit   | Attr   | Reset Value | Description                                        |
|-------|--------|-------------|----------------------------------------------------|
|       |        |             | USBActEP                                           |
|       |        |             | USB Active Endpoint                                |
|       |        |             | Applies to IN and OUT endpoints.Indicates          |
|       |        |             | whether this endpoint is active in the current     |
| 15    | R/WSC  | 0×0         | configuration and interface. The core clears       |
|       | Ky WSC | UXU         | this bit for all endpoints (other than EP 0) after |
|       |        |             | detecting a USB reset. After receiving the         |
|       |        |             | SetConfiguration and SetInterface commands,        |
|       |        |             | the application must program endpoint              |
|       |        |             | registers accordingly and set this bit.            |
|       |        |             | NextEp                                             |
|       | RW     | 0x0         | Next Endpoint                                      |
|       |        |             | Applies to non-periodic IN endpoints               |
|       |        |             | only.Indicates the endpoint number to be           |
| 14:11 |        |             | fetched after the data for the current endpoint    |
| 17.11 | IXVV   | 0.00        | is fetched. The core can access this field, even   |
|       |        |             | when the Endpoint Enable (EPEna) bit is low.       |
|       |        |             | This field is not valid in Slave mode              |
|       |        |             | operation.Note: This field is valid only for       |
|       |        |             | Shared FIFO operations.                            |
|       |        |             | MPS                                                |
|       |        |             | Maximum Packet Size                                |
| 10:0  | RW     | 0x000       | Applies to IN and OUT endpoints.The                |
| 10.0  | INV    |             | application must program this field with the       |
|       |        |             | maximum packet size for the current logical        |
|       |        |             | endpoint. This value is in bytes.                  |

## USBOTG\_DOEPCTLn

Address: Operational Base + offset (0x0b00 + 0x20 \* n)  $1 \le n \le 15$ 

Device control OUT endpoint 0 control register

| Bit Attr Reset Value Description |
|----------------------------------|
|----------------------------------|



| Bit         | Attr  | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------|-------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31          | R/WSC | 0x0         | EPEna Endpoint Enable When Scatter/Gather DMA mode is enabled, for OUT endpoints this bit indicates that the descriptor structure and data buffer to receive data is setup. When Scatter/Gather DMA mode is disabled?such as for buffer-pointer based DMA mode)-this bit indicates that the application has allocated the memory to start receiving data from the USB. The core clears this bit before setting any of the following interrupts on this endpoint: SETUP Phase Done, Endpoint Disabled, Transfer Completed. Note: In DMA mode, this bit must be set for the core to transfer SETUP data packets into memory. |
| 30          | WO    | 0x0         | EPDis Endpoint Disable The application cannot disable control OUT endpoint 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 29:28       | RO    | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 27          | wo    | 0x0         | SNAK Set NAK A write to this bit sets the NAK bit for the endpoint. Using this bit, the application can control the transmission of NAK handshakes on an endpoint. The core can also set bit on a Transfer Completed interrupt, or after a SETUP is received on the endpoint.                                                                                                                                                                                                                                                                                                                                              |
| 26<br>25:22 | WO    | 0x0<br>0x0  | CNAK Clear NAK A write to this bit clears the NAK bit for the endpoint. reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |



| Bit   | Attr  | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|-------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21    | R/WSC | 0x0         | Stall STALL Handshake The application can only set this bit, and the core clears it, when a SETUP token is received for this endpoint. If a NAK bit or Global OUT NAK is set along with this bit, the STALL bit takes priority. Irrespective of this bit's setting, the core always responds to SETUP data packets with an ACK handshake.                                                                                                                     |
| 20    | RW    | 0x0         | Snp Snoop Mode This bit configures the endpoint to Snoop mode. In Snoop mode, the core does not check the correctness of OUT packets before transferring them to application memory.                                                                                                                                                                                                                                                                          |
| 19:18 | RO    | 0×0         | EPType Endpoint Type Hardcoded to 2'b00 for control.                                                                                                                                                                                                                                                                                                                                                                                                          |
| 17    | RO    | 0×0         | NAKSts NAK Status Indicates the following: 1'b0: The core is transmitting non-NAK handshakes based on the FIFO status. 1'b1: The core is transmitting NAK handshakes on this endpoint. When either the application or the core sets this bit, the core stops receiving data, even if there is space in the RxFIFO to accommodate the incoming packet. Irrespective of this bit setting, the core always responds to SETUP data packets with an ACK handshake. |
| 16    | RO    | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 15    | RO    | 0x0         | USBActEP USB Active Endpoint This bit is always set to 1, indicating that a control endpoint 0 is always active in all configurations and interfaces.                                                                                                                                                                                                                                                                                                         |
| 14:2  | RO    | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                      |



| Bit | Attr | Reset Value | Description                             |
|-----|------|-------------|-----------------------------------------|
|     |      | 0×0         | MPS                                     |
| 1:0 |      |             | Maximum Packet Size                     |
|     |      |             | The maximum packet size for control OUT |
|     | RO   |             | endpoint 0 is the same as what is       |
|     |      |             | programmed in control IN Endpoint 0.    |
|     |      |             | 2'b00: 64 bytes                         |
|     |      |             | 2'b01: 32 bytes                         |
|     |      |             | 2'b10: 16 bytes                         |
|     |      |             | 2'b11: 8 bytes                          |

## USBOTG\_DOEPINTn

Address: Operational Base + offset (0x0b08 + 0x20 \* n)

Device endpoint-n control register

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                          |
|-------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                             |
| 14    | W1C  | 0×0                | NYETIntrpt NYET interrupt The core generates this interrupt when a NYET response is transmitted for a non isochronous OUT endpoint.                                                                                                                                                                                  |
| 13    | W1C  | 0×0                | NAKIntrpt NAK interrupt The core generates this interrupt when a NAK is transmitted or received by the device. In case of isochronous IN endpoints the interrupt gets generated when a zero length packet is transmitted due to un-availability of data in the TXFifo.                                               |
| 12    | W1C  | 0×0                | BbleErrIntrpt BbleErr (Babble Error) interrupt The core generates this interrupt when babble is received for the endpoint.                                                                                                                                                                                           |
| 11    | W1C  | 0×0                | PktDrpSts Packet Dropped Status This bit indicates to the application that an ISOC OUT packet has been dropped. This bit does not have an associated mask bit and does not generate an interrupt. Dependency: This bit is valid in non Scatter/Gather DMA mode when periodic transfer interrupt feature is selected. |
| 10    | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                             |



| Bit | Attr | Reset Value | Description                                      |
|-----|------|-------------|--------------------------------------------------|
|     |      |             | BNAIntr                                          |
|     |      |             | BNA (Buffer Not Available) Interrupt             |
|     |      |             | The core generates this interrupt when the       |
| 9   | W1C  | 0x0         | descriptor accessed is not ready for the Core to |
|     |      |             | process, such as Host busy or DMA done.          |
|     |      |             | Dependency: This bit is valid only when          |
|     |      |             | Scatter/Gather DMA mode is enabled.              |
|     |      |             | TxfifoUndrn                                      |
|     |      |             | FIFO Underrun                                    |
|     |      |             | Applies to IN endpoints only. The core generates |
|     |      |             | this interrupt when it detects a transmit FIFO   |
|     |      |             | underrun condition for this endpoint.            |
|     |      | 0×0         | Dependency: This interrupt is valid only when    |
|     |      |             | both of the following conditions are true:       |
| 8   | W1C  |             | Parameter OTG_EN_DED_TX_FIFO==1,                 |
|     | WIC  |             | Thresholding is enabled, OUT Packet Error        |
|     |      |             | (OutPktErr). Applies to OUT endpoints only .     |
|     |      |             | This interrupt is asserted when the core detects |
|     |      |             | an overflow or a CRC error for an OUT packet.    |
|     |      |             | Dependency: This interrupt is valid only when    |
|     |      |             | both of the following conditions are true:       |
|     |      |             | Parameter OTG_EN_DED_TX_FIFO==1,                 |
|     |      |             | Thresholding is enabled.                         |
|     |      |             | TxFEmp                                           |
|     |      | • 1         | Transmit FIFO Empty                              |
| 7   |      | 0x0         | This bit is valid only for IN Endpoints. This    |
|     | W1C  |             | interrupt is asserted when the TxFIFO for this   |
|     |      |             | endpoint is either half or completely empty. The |
|     |      |             | half or completely empty status is determined    |
|     |      | <b>&gt;</b> | by the TxFIFO Empty Level bit in the Core AHB    |
|     |      |             | Configuration                                    |
|     |      |             | register(GAHBCFG.NPTxFEmpLvI)).                  |



| Bit | Attr   | Reset Value | Description                                          |
|-----|--------|-------------|------------------------------------------------------|
|     |        |             | INEPNakEff                                           |
|     |        |             | IN Endpoint NAK Effective                            |
|     |        |             | Applies to periodic IN endpoints only. This bit      |
|     |        |             | can be cleared when the application clears the       |
|     |        |             | IN endpoint NAK by writing to DIEPCTLn.CNAK.         |
|     |        |             | This interrupt indicates that the core has           |
|     |        |             | sampled the NAK bit set (either by the               |
|     |        |             | application or by the core). The interrupt           |
|     |        |             | indicates that the IN endpoint NAK bit set by the    |
| 6   | W1C    | 0x0         | application has taken effect in the core. This       |
|     |        |             | interrupt does not guarantee that a NAK              |
|     |        |             | handshake is sent on the USB. A STALL bit takes      |
|     |        |             | priority over a NAK bit. This bit is applicable only |
|     |        |             | when the endpoint is enabled. Back-to-Back           |
|     |        |             | SETUP Packets Received (Back2BackSETup)              |
|     |        |             | Applies to Control OUT endpoints only.               |
|     |        |             | This bit indicates that the core has received        |
|     |        |             | more than three back-to-back SETUP                   |
|     |        |             | packets for this particular endpoint.                |
|     |        |             | INTknEPMis                                           |
|     |        |             | IN Token Received with EP Mismatch                   |
|     |        |             | Applies to non-periodic IN endpoints only.           |
|     |        |             | Indicates that the data in the top of the            |
|     |        |             | non-periodic TxFIFO belongs to an endpoint           |
| _   |        |             | other than the one for which the IN token was        |
| 5   | W1C    | 0x0         | received. This interrupt is asserted on the          |
|     |        |             | endpoint for which the IN token was received.        |
|     |        |             | Status Phase Received For Control Write              |
|     |        |             | (StsPhseRcvd)                                        |
|     |        | ·           | This interrupt is valid only for Control OUT         |
|     |        |             | endpoints and only in Scatter Gather DMA mode.       |
|     | $\cup$ |             | INTknTXFEmp                                          |
|     |        |             | IN Token Received When TxFIFO is Empty               |
|     |        |             | Indicates that an IN token was received when         |
|     |        |             | the associated TxFIFO periodic/nonperiodic)          |
|     |        |             | was empty. This interrupt is asserted on the         |
| 4   | W1C    | 0x0         | endpoint for which the IN token was received.        |
|     |        |             | OUT Token Received When Endpoint Disabled            |
|     |        |             | (OUTTknEPdis) Indicates that an OUT token was        |
|     |        |             | received when the endpoint was not yet               |
|     |        |             | enabled. This interrupt is asserted on the           |
|     |        |             | endpoint for which the OUT token was received.       |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | W1C  | 0x0         | TimeOUT Timeout Condition In shared TX FIFO mode, applies to non-isochronous IN endpoints only. In dedicated FIFO mode, applies only to Control IN endpoints. In Scatter/Gather DMA mode, the TimeOUT interrupt is not asserted.Indicates that the core has detected a timeout condition on the USB for the last IN token on this endpoint. SETUP Phase Done (SetUp). Applies to control OUT endpoints only. Indicates that the SETUP phase for the control endpoint is complete and no more back-to-back SETUP packets were received for the current control transfer. On this interrupt, the application can decode the received SETUP data packet. |
| 2   | W1C  | 0×0         | AHBErr AHB Error Applies to IN and OUT endpoints. This is generated only in Internal DMA mode when there is an AHB error during an AHB read/write. The application can read the corresponding endpoint DMA address register to get the error address.                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1   | W1C  | 0x0         | EPDisbld Endpoint Disabled Interrupt Applies to IN and OUT endpoints. This bit indicates that the endpoint is disabled per the application's request.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |



## **USBOTG\_DOEPTSIZn**

Address: Operational Base + offset (0x0b10 + 0x20 \* n)1≤n≤15

Device endpoint n transfer size register

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



| Attr | <b>Reset Value</b> | Description                                        |
|------|--------------------|----------------------------------------------------|
|      |                    | MC                                                 |
|      |                    | Multi Count                                        |
|      |                    | Applies to IN endpoints only. For periodic IN      |
|      |                    | endpoints, this field indicates the number of      |
|      |                    | packets that must be transmitted per               |
|      |                    | microframe on the USB. The core uses this field    |
|      |                    | to calculate the data PID for isochronous IN       |
|      |                    | endpoints.                                         |
|      |                    | 2'b01: 1 packet                                    |
|      |                    | 2'b10: 2 packets                                   |
|      |                    | 2'b11: 3 packets                                   |
|      |                    | For non-periodic IN endpoints, this field is valid |
|      |                    | only in Internal DMA mode. It specifies the        |
|      |                    | number of packets the core must fetch for an IN    |
|      |                    | endpoint before it switches to the endpoint        |
|      |                    | pointed to by the Next Endpoint field of the       |
| RW   | 0x0                | Device Endpoint-n Control register                 |
|      |                    | (DIEPCTLn.NextEp). Received Data PID               |
|      |                    | (RxDPID)                                           |
|      |                    | Applies to isochronous OUT endpoints only.         |
|      |                    | This is the data PID received in the last packet   |
|      |                    | for this endpoint.                                 |
|      |                    | 2'b00: DATA0                                       |
|      |                    | 2'b01: DATA2                                       |
|      | • 4                | 2'b10: DATA1                                       |
|      |                    | 2'b11: MDATA                                       |
|      |                    | SETUP Packet Count (SUPCnt). Applies to            |
|      | CA                 | control OUT Endpoints only. This field specifies   |
| 1    |                    | the number of back-to-back SETUP data              |
|      | 7                  | packets the endpoint can receive.                  |
|      |                    | 2'b01: 1 packet<br>2'b10: 2 packets                |
|      |                    | 2'b11: 3 packets                                   |
|      |                    |                                                    |

| Bit   | Attr | Reset Value                           | Description                                                                                                                                   |
|-------|------|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
|       |      |                                       | PktCnt                                                                                                                                        |
|       |      |                                       | Packet Count                                                                                                                                  |
|       |      |                                       | Indicates the total number of USB packets that constitute the Transfer Size amount of data for this endpoint. The power-on value is specified |
|       |      |                                       | for Width of Packet Counters during IP                                                                                                        |
| 28:19 | RW   | 0x000                                 | configuration (parameter                                                                                                                      |
|       |      |                                       | OTG_PACKET_COUNT_WIDTH). IN Endpoints:                                                                                                        |
|       |      |                                       | This field is decremented every time a packet                                                                                                 |
|       |      |                                       | (maximum size or short packet) is read from                                                                                                   |
|       |      |                                       | the TxFIFO. OUT Endpoints: This field is                                                                                                      |
|       |      |                                       | decremented every time a packet (maximum                                                                                                      |
|       |      |                                       | size or short packet) is written to the RxFIFO.                                                                                               |
|       |      |                                       | XferSize                                                                                                                                      |
|       |      |                                       | Transfer Size                                                                                                                                 |
|       |      |                                       | This field contains the transfer size in bytes for                                                                                            |
|       |      |                                       | the current endpoint. The power-on value is                                                                                                   |
|       |      |                                       | specified for Width of Transfer Size Counters                                                                                                 |
|       |      |                                       | during IP configuration (parameter                                                                                                            |
|       |      |                                       | OTG_TRANS_COUNT_WIDTH). The core only                                                                                                         |
| 18:0  | RW   | 0x00000                               | interrupts the application after it has exhausted                                                                                             |
| 18:0  | KVV  | 000000                                | the transfer size amount of data. The transfer size can be set to the maximum packet size of                                                  |
|       |      |                                       | the endpoint, to be interrupted at the end of                                                                                                 |
|       |      |                                       | each packet. IN Endpoints: The core                                                                                                           |
|       |      | • 1                                   | decrements this field every time a packet from                                                                                                |
|       |      | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | the external memory is written to the TxFIFO.                                                                                                 |
|       |      |                                       | OUT Endpoints: The core decrements this field                                                                                                 |
|       |      | 0                                     | every time a packet is read from the RxFIFO                                                                                                   |
|       |      |                                       | and written to the external memory.                                                                                                           |

## USBOTG\_DOEPDMAn

Address: Operational Base + offset (0x0b14 + 0x20 \* n)  $0 \le n \le 15$ 

Device Endpoint-n DMA Address Register



| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0×0000000   | DMA Address Holds the start address of the external memory for storing or fetching endpoint data. Note: For control endpoints, this field stores control OUT data packets as well as SETUP transaction data packets. When more than three SETUP packets are received back-to-back, the SETUP data packet in the memory is overwritten. This register is incremented on every AHB transaction. The application can give only a DWORD-aligned address. When Scatter/Gather DMA mode is not enabled, the application programs the start address value in this field. When Scatter/Gather DMA mode is enabled, this field indicates the base pointer for the descriptor list. |

## USBOTG\_DOEPDMABn

Address: Operational Base + offset (0x0b1c + 0x20 \* n)0≤n≤15

Device endpoint-n DMA buffer address register

| Bit  | Attr | Reset Value | Description                                     |
|------|------|-------------|-------------------------------------------------|
|      |      |             | DMABufferAddr                                   |
|      |      | . ()        | DMA Buffer Address                              |
|      |      | 1           | Holds the current buffer address. This register |
| 31:0 | RO   | 0×00000000  | is updated as and when the data transfer for    |
|      |      |             | the corresponding end point is in progress.     |
|      |      |             | This register is present only in Scatter/Gather |
|      |      | 7           | DMA mode. Otherwise this field is reserved.     |

## USBOTG\_DOEPCTLn

Address: Operational Base + offset (0x0b20 + 0x20 \* n)  $0 \le n \le 14$ 

Device endpoint-n control register

| Bit Attr Reset Value Description |  |
|----------------------------------|--|
|----------------------------------|--|



| Bit | Attr  | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----|-------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31  | R/WSC | 0×0         | EPEna Endpoint Enable Applies to IN and OUT endpoints. When Scatter/Gather DMA mode is enabled, For IN endpoints this bit indicates that the descriptor structure and data buffer with data ready to transmit is setup. For OUT endpoint it indicates that the descriptor structure and data buffer to receive data is setup. When Scatter/Gather DMA mode is enabled-such as for buffer-pointer based DMA mode: For IN endpoints, this bit indicates that data is ready to be transmitted on the endpoint; For OUT endpoints, this bit indicates that the application has allocated the memory to start receiving data from the USB. The core clears this bit before setting any of the following interrupts on this endpoint: SETUP Phase Done, Endpoint Disabled, Transfer Completed. Note: For control endpoints in DMA mode, this bit must be set to be able to transfer SETUP data packets in memory. |
| 30  | R/WSC | 0×0         | EPDis Endpoint Disable Applies to IN and OUT endpoints. The application sets this bit to stop transmitting/receiving data on an endpoint, even before the transfer for that endpoint is complete. The application must wait for the Endpoint Disabled interrupt before treating the endpoint as disabled. The core clears this bit before setting the Endpoint Disabled interrupt. The application must set this bit only if Endpoint Enable is already set for this endpoint.                                                                                                                                                                                                                                                                                                                                                                                                                              |



| Bit      | Attr | Reset Value | Description                                       |
|----------|------|-------------|---------------------------------------------------|
|          |      |             | SetD1PID                                          |
|          |      |             | Field0001 Abstract                                |
|          |      |             | Applies to interrupt/bulk IN and OUT              |
|          |      |             | endpoints only. Writing to this field sets the    |
|          |      |             | Endpoint Data PID (DPID) field in this register   |
|          |      |             | to DATA1.This field is applicable both for        |
| 20       | DO.  | 0.40        | Scatter/Gather DMA mode and                       |
| 29       | RO   | 0x0         | non-Scatter/Gather DMA mode. Set Odd              |
|          |      |             | (micro)frame (SetOddFr). Applies to               |
|          |      |             | isochronous IN and OUT endpoints only.            |
|          |      |             | Writing to this field sets the Even/Odd           |
|          |      |             | (micro)frame (EO_FrNum) field to odd              |
|          |      |             | (micro)frame. This field is not applicable for    |
|          |      |             | Scatter/Gather DMA mode.                          |
|          |      |             | SetD0PID                                          |
|          |      |             | Set DATA0 PID                                     |
|          |      |             | Applies to interrupt/bulk IN and OUT              |
|          |      |             | endpoints only.Writing to this field sets the     |
|          |      |             | Endpoint Data PID (DPID) field in this register   |
|          |      |             | to DATA0.This field is applicable both for        |
|          |      |             | Scatter/Gather DMA mode and                       |
|          |      |             | non-Scatter/Gather DMA mode. In                   |
|          |      |             | non-Scatter/Gather DMA mode: Set Even             |
| 28       | WO   | 0x0         | (micro)frame (SetEvenFr) Applies to               |
|          |      | . ()        | isochronous IN and OUT endpoints only.            |
|          |      | 1,5         | Writing to this field sets the Even/Odd           |
|          |      | My y        | (micro)frame (EO_FrNum) field to even             |
|          |      |             | (micro)frame. When Scatter/Gather DMA             |
|          | 1    |             | mode is enabled, this field is reserved. The      |
|          |      | 7           | frame number in which to send data is in the      |
|          |      |             | transmit descriptor structure. The frame in       |
|          |      |             | which to receive data is updated in receive       |
|          |      |             | descriptor structure.                             |
| <b>Y</b> |      |             | SNAK                                              |
|          |      |             | Set NAK                                           |
|          |      |             | Applies to IN and OUT endpoints. A write to       |
|          |      |             | this bit sets the NAK bit for the endpoint. Using |
| 27       | WO   | 0x0         | this bit, the application can control the         |
|          |      |             | transmission of NAK handshakes on an              |
|          |      |             | endpoint. The core can also set this bit for OUT  |
|          |      |             | endpoints on a Transfer Completed interrupt,      |
|          |      |             | or after a SETUP is received on the endpoint.     |

| Bit   | Attr | Reset Value            | Description                                     |
|-------|------|------------------------|-------------------------------------------------|
|       |      |                        | CNAK                                            |
| 26    | wo   | 0×0                    | Clear NAK                                       |
| 20    | WO   | UXU                    | Applies to IN and OUT endpoints. A write to     |
|       |      |                        | this bit clears the NAK bit for the endpoint.   |
|       |      |                        | TxFNum                                          |
|       |      |                        | TxFIFO Number                                   |
|       |      |                        | Shared FIFO Operation:non-periodic              |
|       |      |                        | endpoints must set this bit to zero. Periodic   |
|       |      |                        | endpoints must map this to the corresponding    |
|       |      |                        | Periodic TxFIFO number. 4'h0: Non-Periodic      |
|       |      | 0×0                    | TxFIFO; Others: Specified Periodic TxFIFO       |
|       |      |                        | number. Note: An interrupt IN endpoint can be   |
|       |      |                        | configured as a non-periodic endpoint for       |
|       |      |                        | applications such as mass storage. The core     |
|       |      |                        | treats an IN endpoint as a non-periodic         |
| 25:22 | RW   |                        | endpoint if the TxFNum field is set to 0.       |
|       |      |                        | Otherwise, a separate periodic FIFO must be     |
|       |      |                        | allocated for an interrupt IN endpoint, and the |
|       |      |                        | number of this FIFO must be programmed into     |
|       |      |                        | the TxFNum field. Configuring an interrupt IN   |
|       |      |                        | endpoint as a non-periodic endpoint saves the   |
|       |      |                        | extra periodic FIFO area. Dedicated FIFO        |
|       |      |                        | Operation: these bits specify the FIFO number   |
|       |      |                        | associated with this endpoint. Each active IN   |
|       |      |                        | endpoint must be programmed to a separate       |
|       |      | 1                      | FIFO number. This field is valid only for IN    |
|       |      | $\lambda \cap \lambda$ | endpoints.                                      |



| Bit   | Attr   | Reset Value   | Description                                                                          |
|-------|--------|---------------|--------------------------------------------------------------------------------------|
|       |        |               | Stall                                                                                |
|       |        |               | STALL Handshake                                                                      |
|       |        |               | Applies to non-control, non-isochronous IN                                           |
|       |        |               | and OUT endpoints only. The application sets                                         |
|       |        |               | this bit to stall all tokens from the USB host to                                    |
|       |        |               | this endpoint. If a NAK bit, Global Non-periodic                                     |
|       |        |               | IN NAK, or Global OUT NAK is set along with                                          |
|       |        |               | this bit, the STALL bit takes priority. Only the                                     |
| 21    | RW     | 0×0           | application can clear this bit, never the core.                                      |
| 21    | IK VV  | UXU           | Applies to control endpoints only. The                                               |
|       |        |               | application can only set this bit, and the core                                      |
|       |        |               | clears it, when a SETUP token is received for                                        |
|       |        |               | this endpoint. If a NAK bit, Global Non-periodic                                     |
|       |        |               | IN NAK, or Global OUT NAK is set along with                                          |
|       |        |               | this bit, the STALL bit takes priority.                                              |
|       |        |               | Irrespective of this bit's setting, the core                                         |
|       |        |               | always responds to SETUP data packets with                                           |
|       |        |               | an ACK handshake.                                                                    |
|       |        |               | Snp                                                                                  |
|       |        |               | Snoop Mode                                                                           |
|       |        |               | Applies to OUT endpoints only. This bit                                              |
| 20    | RW     | 0x0           | configures the endpoint to Snoop mode. In                                            |
|       |        |               | Snoop mode, the core does not check the                                              |
|       |        |               | correctness of OUT packets before transferring                                       |
|       |        | •. 1          | them to application memory.                                                          |
|       |        |               | EPType                                                                               |
|       |        |               | Endpoint Type                                                                        |
|       | , ,    | $C_{\lambda}$ | Applies to IN and OUT endpoints. This is the transfer type supported by this logical |
| 19:18 | RW     | 0x0           | endpoint.                                                                            |
| 19.10 | 1744   | 0.00          | 2'b00: Control                                                                       |
|       |        |               | 2'b01: Isochronous                                                                   |
| Q'    | $\cup$ |               | 2'b10: Bulk                                                                          |
|       | V      |               | 2'b11: Interrupt                                                                     |
| -     |        |               | _ = 511. Interrupt                                                                   |



| Bit | Attr | <b>Reset Value</b> | Description                                    |
|-----|------|--------------------|------------------------------------------------|
|     |      |                    | NAKSts                                         |
|     |      |                    | NAK Status                                     |
|     |      |                    | Applies to IN and OUT endpoints. Indicates the |
|     | RO   |                    | following:                                     |
|     |      | 0×0                | 1'b0: The core is transmitting non-NAK         |
| 17  |      |                    | handshakes based on the FIFO status.           |
|     |      | UXU                | 1'b1: The core is transmitting NAK             |
|     |      |                    | handshakes on this endpoint.                   |
|     |      |                    | When either the application or the core sets   |
|     |      |                    | this bit: The core stops receiving any data on |
|     |      |                    | an OUT endpoint, even if there is space in the |
|     |      |                    | RxFIFO to accommodate the incoming packet.     |



| Bit | Attr | Reset Value | Description                                                                            |
|-----|------|-------------|----------------------------------------------------------------------------------------|
|     |      |             | DPID                                                                                   |
|     |      |             | Endpoint Data PID                                                                      |
|     |      |             | Applies to interrupt/bulk IN and OUT                                                   |
|     |      |             | endpoints only. Contains the PID of the packet                                         |
|     |      |             | to be received or transmitted on this endpoint.                                        |
|     |      |             | The application must program the PID of the                                            |
|     |      |             | first packet to be received or transmitted on                                          |
|     |      |             | this endpoint, after the endpoint is activated.                                        |
|     |      |             | The applications use the SetD1PID and                                                  |
|     |      |             | SetD0PID fields of this register to program                                            |
|     |      |             | either DATA0 or DATA1 PID.                                                             |
|     |      |             | 1'b0: DATA0                                                                            |
|     |      |             | 1'b1: DATA1                                                                            |
|     |      |             | This field is applicable both for Scatter/Gather                                       |
|     |      |             | DMA mode and non-Scatter/Gather                                                        |
|     |      | 0×0         | DMA mode. Even/Odd (Micro)Frame                                                        |
| 16  | RO   |             | (EO_FrNum). In non-Scatter/Gather DMA                                                  |
|     |      |             | mode: Applies to isochronous IN and OUT                                                |
|     |      |             | endpoints only. Indicates the (micro)frame number in which the core transmits/receives |
|     |      |             | isochronous data for this endpoint. The                                                |
|     |      |             | application must program the even/odd                                                  |
|     |      |             | (micro) frame number in which it intends to                                            |
|     |      |             | transmit/receive isochronous data for this                                             |
|     |      |             | endpoint using the SetEvnFr and SetOddFr                                               |
|     |      | ` \         | fields in this register.                                                               |
|     |      | 10 7        | 1'b0: Even (micro)frame                                                                |
|     |      |             | 1'b1: Odd (micro)frame                                                                 |
|     | A 1  | U'          | When Scatter/Gather DMA mode is enabled,                                               |
|     | 1    |             | this field is reserved. The frame number in                                            |
|     |      |             | which to send data is provided in the transmit                                         |
|     |      |             | descriptor structure. The frame in which data                                          |
| 1   |      |             | is received is updated in receive descriptor                                           |
|     |      |             | structure.                                                                             |



| Bit   | Attr  | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|-------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15    | R/WSC | 0x0         | USBActEP USB Active Endpoint Applies to IN and OUT endpoints. Indicates whether this endpoint is active in the current configuration and interface. The core clears this bit for all endpoints (other than EP 0) after detecting a USB reset. After receiving the SetConfiguration and SetInterface commands, the application must program endpoint                                                       |
| 14:11 | RW    | 0×0         | registers accordingly and set this bit.  NextEp  Next Endpoint  Applies to non-periodic IN endpoints only.  Indicates the endpoint number to be fetched after the data for the current endpoint is fetched. The core can access this field, even when the Endpoint Enable (EPEna) bit is low. This field is not valid in Slave mode operation. Note: This field is valid only for Shared FIFO operations. |
| 10:0  | RW    | 0×000       | MPS Maximum Packet Size Applies to IN and OUT endpoints. The application must program this field with the maximum packet size for the current logical endpoint. This value is in bytes.                                                                                                                                                                                                                   |

## USBOTG\_PCGCR

Address: Operational Base + offset (0x0b24)
Power and clock gating control register

| Bit | Attr Reset Value | Description |
|-----|------------------|-------------|
|-----|------------------|-------------|



| Bit   | Attr       | Reset Value | Description                                       |
|-------|------------|-------------|---------------------------------------------------|
|       |            |             | RestoreValue                                      |
|       |            |             | Restore Value                                     |
|       |            |             | (Applicable only when Hibernation is enabled      |
|       |            |             | (OTG_EN_PWROPT=2). Defines port clock             |
|       |            |             | select for different speeds.                      |
|       |            |             | [31] if_dev_mode                                  |
|       |            |             | - 1: Device mode, core restored as device         |
|       |            |             | - 0: Host mode, core restored as host             |
|       |            |             | [30:29] p2hd_prt_spd (PRT speed)                  |
|       |            |             | - 00: HS                                          |
|       |            |             | - 01: FS                                          |
|       |            |             | - 10: LS                                          |
|       |            |             | - 11: Reserved                                    |
|       |            |             | [28:27] p2hd_dev_enum_spd (Device                 |
|       |            |             | enumerated speed)                                 |
|       |            |             | - 00: HS                                          |
| 31:14 | RW         | 0x0802e     | - 01: FS (30/60 MHz clk)                          |
|       |            |             | - 10: LS                                          |
|       |            |             | - 11: FS (48 MHz clk)                             |
|       |            |             | [26:20] mac_dev_addr (MAC device address)         |
|       |            |             | Device address                                    |
|       |            |             | [19] mac_termselect (Termination selection)       |
|       |            |             | - 0: HS_TERM (Program for High Speed)             |
|       |            |             | - 1: FS_TERM (Program for Full Speed)             |
|       |            |             | [18:17] mac_xcvrselect (Transceiver select)       |
|       |            | * \         | - 00: HS_XCVR (High Speed)                        |
|       |            | AAY'        | - 01: FS_XCVR (Full Speed)                        |
|       |            |             | - 10: LS_XCVR (Low Speed)                         |
|       | <b>A</b> 4 |             | - 11: LFS_XCVR (Reserved)                         |
|       |            | 7           | [16] sh2pl_prt_ctl[0]                             |
|       |            | <i>Y</i>    | - 1: prt_power enabled                            |
|       |            |             | - 0: prt_power disabled                           |
|       |            |             | [15:14] prt_clk_sel (Refer prt_clk_sel table)     |
| -     |            |             | EssRegRestored                                    |
|       |            |             | Essential Register Values Restored                |
|       |            |             | (Applicable only when Hibernation is enabled      |
| 13    | RW         | 0x0         | (OTG_EN_PWROPT=2). When a value of 1 is           |
|       |            |             | written to this field, it indicates that register |
|       |            |             | values of essential registers have been           |
|       |            |             | restored.                                         |
| 12:10 | RO         | 0x0         | reserved                                          |



| Bit | Attr | Reset Value | Description                                      |
|-----|------|-------------|--------------------------------------------------|
|     |      |             | RestoreMode                                      |
|     |      |             | Restore Mode                                     |
|     |      |             | (Applicable only when Hibernation is enabled     |
|     |      |             | (OTG_EN_PWROPT=2). The application should        |
|     |      |             | program this bit to specify the restore mode     |
|     |      |             | during RESTORE POINT before programming          |
|     |      |             | PCGCCTL.EssRegRest bit is set.                   |
| 9   | RO   | 0x0         | Host Mode:                                       |
|     |      |             | 1'b0: Host Initiated Resume, Host Initiated      |
|     |      |             | Reset                                            |
|     |      |             | 1'b1: Device Initiated Remote Wake up            |
|     |      |             | Device Mode:                                     |
|     |      |             | 1'b0: Device Initiated Remote Wake up            |
|     |      |             | 1'b1: Host Initiated Resume, Host Initiated      |
|     |      |             | Reset                                            |
|     |      |             | ResetAfterSusp                                   |
|     |      |             | Reset After Suspend                              |
|     |      |             | Applicable in Partial power-down mode. In        |
|     |      |             | partial power-down mode of operation, this bit   |
|     |      |             | needs to be set in host mode before clamp is     |
|     |      |             | removed if the host needs to issue reset after   |
| 8   | RW   | 0×0         | suspend. If this bit is not set,then the host    |
|     | KW   | OXO .       | issues resume after suspend. This bit is not     |
|     |      | 3779        | applicable in device mode and non-partial        |
|     |      |             | power-down mode.In Hibernation mode, this        |
|     |      |             | bit needs to be set at RESTORE_POINT before      |
|     |      |             | PCGCCTL.EssRegRestored is set. In this case,     |
|     |      |             | PCGCCTL.restore_mode needs to be set to          |
|     | 1    |             | wait_restore.                                    |
|     |      |             | L1Suspended                                      |
| 7   | RO   | 0×0         | Deep Sleep                                       |
|     |      |             | This bit indicates that the PHY is in deep sleep |
|     | Y    |             | when in L1 state.                                |
| 7   |      |             | PhySleep                                         |
| 6   | RO   | 0×0         | PHY in Sleep                                     |
|     |      |             | This bit indicates that the PHY is in the Sleep  |
|     |      |             | state.                                           |
|     |      |             | Enbl_L1Gating                                    |
| 5   | RW   | 0×0         | Enable Sleep Clock Gating                        |
|     |      |             | When this bit is set, core internal clock gating |
|     |      |             | is enabled in Sleep state if the core cannot     |
|     |      |             | assert utmi_l1_suspend_n. When this bit is not   |
|     |      |             | set, the PHY clock is not gated in Sleep state.  |



| Bit | Attr | Reset Value | Description                                             |
|-----|------|-------------|---------------------------------------------------------|
| 4   | RO   | 0x0         | reserved                                                |
|     |      |             | RstPdwnModule                                           |
|     |      |             | Reset Power-Down Modules                                |
|     |      |             | This bit is valid only in Partial Power-Down            |
| 3   | RW   | 0x0         | mode. The application sets this bit when the            |
|     |      |             | power is turned off. The application clears this        |
|     |      |             | bit after the power is turned on and the PHY            |
|     |      |             | clock is up.                                            |
|     |      |             | PwrClmp                                                 |
|     |      |             | Power Clamp                                             |
|     |      |             | This bit is valid only in Partial Power-Down            |
|     |      |             | mode (OTG_EN_PWROPT = 1). The application               |
| 2   | RW   | 0x0         | sets this bit before the power is turned off to         |
|     |      |             | clamp the signals between the power-on                  |
|     |      |             | modules and the power-off modules. The                  |
|     |      |             | application clears the bit to disable the               |
|     |      |             | clamping before the power is turned on.                 |
|     |      |             | GateHclk                                                |
|     |      |             | Gate Hclk                                               |
|     |      |             | The application sets this bit to gate hclk to           |
| 1   | RW   | 0x0         | modules other than the AHB Slave and Master             |
|     |      | o A G       | and wakeup logic when the USB is suspended              |
|     |      |             | or the session is not valid.                            |
|     |      |             | The application clears this bit when the USB is         |
|     |      | • 1         | resumed or a new session starts.                        |
|     |      | A ~ > >     | StopPclk                                                |
|     |      |             | Stop Pclk The application sets this bit to stop the PHY |
|     |      |             | clock (phy_clk) when the USB is suspended,              |
| 0   | RW   | 0x0         | the session is not valid, or the device is              |
|     |      | <b>Y</b>    | disconnected. The application clears this bit           |
|     |      |             | when the USB is resumed or a new session                |
|     |      |             | starts.                                                 |
|     |      |             | otal to:                                                |

Address: Operational Base + offset (0x1000) Device endpoint 0 / host out channel 0 address

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
|-----|------|-------------|-------------|



| Bit  | Attr | Reset Value | Description                               |
|------|------|-------------|-------------------------------------------|
| 31:0 |      | 0×00000000  | EPBUF0                                    |
|      |      |             | Device endpoint 0 / host out channel 0    |
|      |      |             | address                                   |
|      | RW   |             | Device IN Endpoint 0 /Host OUT Channel 0: |
|      |      |             | DFIFO Write Access                        |
|      |      |             | Device OUT Endpoint 0 /Host IN Channel 0: |
|      |      |             | DFIFO Read Access                         |

Address: Operational Base + offset (0x2000) Device endpoint 1 / host out channel 1 address

| Bit  | Attr | Reset Value | Description                              |
|------|------|-------------|------------------------------------------|
| 31:0 |      | 0×00000000  | EPBUF1                                   |
|      |      |             | Device endpoint 1 / host out channel 1   |
|      | RW   |             | address                                  |
|      |      |             | Device IN Endpoint 1/Host OUT Channel 1: |
|      |      |             | DFIFO Write Access                       |
|      |      |             | Device OUT Endpoint 1/Host IN Channel 1: |
|      |      |             | DFIFO Read Access                        |

## USB\_EPBUF2

Address: Operational Base + offset (0x3000) Device endpoint 2 / host out channel 2 address

| Bit  | Attr | Reset Value | Description                              |
|------|------|-------------|------------------------------------------|
|      |      | • 0         | EPBUF2                                   |
|      |      |             | Device endpoint 2 / host out channel 2   |
|      |      |             | address                                  |
| 31:0 | RW   | 0×00000000  | Device IN Endpoint 2/Host OUT Channel 2: |
|      | 1    |             | DFIFO Write Access                       |
|      |      | 7           | Device OUT Endpoint 2/Host IN Channel 2: |
|      |      |             | DFIFO Read Access                        |

## USB\_EPBUF3

Address: Operational Base + offset (0x4000) Device endpoint 3 / host out channel 3 address

| Bit Attr Reset Value | Description |
|----------------------|-------------|
|----------------------|-------------|



| Bit  | Attr | Reset Value | Description                              |
|------|------|-------------|------------------------------------------|
|      |      | 0×00000000  | EPBUF3                                   |
|      |      |             | Device endpoint 3 / host out channel 3   |
| 31:0 | RW   |             | address                                  |
|      |      |             | Device IN Endpoint 3/Host OUT Channel 3: |
|      |      |             | DFIFO Write Access                       |
|      |      |             | Device OUT Endpoint 3/Host IN Channel 3: |
|      |      |             | DFIFO Read Access                        |

Address: Operational Base + offset (0x5000)Device endpoint 4 / host out channel 4 address

| Bit  | Attr | Reset Value | Description                              |
|------|------|-------------|------------------------------------------|
|      |      |             | EPBUF4                                   |
|      |      |             | Device endpoint 4 / host out channel 4   |
| 31:0 | RW   |             | address                                  |
|      |      |             | Device IN Endpoint 4/Host OUT Channel 4: |
|      |      |             | DFIFO Write Access                       |
|      |      |             | Device OUT Endpoint 4/Host IN Channel 4: |
|      |      |             | DFIFO Read Access                        |

## **USB\_EPBUF5**

Address: Operational Base + offset (0x6000)Device endpoint 5 / host out channel 5 address

| Bit  | Attr | Reset Value | Description                              |
|------|------|-------------|------------------------------------------|
|      |      | • 0         | EPBUF5                                   |
|      |      |             | Device endpoint 5 / host out channel 5   |
|      |      |             | address                                  |
| 31:0 | RW   | 0×00000000  | Device IN Endpoint 5/Host OUT Channel 5: |
|      | 1    |             | DFIFO Write Access                       |
|      |      | Y           | Device OUT Endpoint 5/Host IN Channel 5: |
|      |      |             | DFIFO Read Access                        |

## USB\_EPBUF6

Address: Operational Base + offset (0x7000) Device endpoint 6 / host out channel 6 address

| Bit Attr Reset Value | Description |
|----------------------|-------------|
|----------------------|-------------|



| Bit  | Attr | Reset Value | Description                              |
|------|------|-------------|------------------------------------------|
|      |      | 0×00000000  | EPBUF6                                   |
|      |      |             | Device endpoint 6 / host out channel 6   |
| 31:0 | RW   |             | address                                  |
|      |      |             | Device IN Endpoint 6/Host OUT Channel 6: |
|      |      |             | DFIFO Write Access                       |
|      |      |             | Device OUT Endpoint 6/Host IN Channel 6: |
|      |      |             | DFIFO Read Access                        |

Address: Operational Base + offset (0x8000) Device endpoint 7 / host out channel 7 address

| Bit  | Attr | Reset Value | Description                              |  |
|------|------|-------------|------------------------------------------|--|
| 31:0 | RW   | 0×00000000  | EPBUF7                                   |  |
|      |      |             | Device endpoint 7 / host out channel 7   |  |
|      |      |             | address                                  |  |
|      |      |             | Device IN Endpoint 7/Host OUT Channel 7: |  |
|      |      |             | DFIFO Write Access                       |  |
|      |      |             | Device OUT Endpoint 7/Host IN Channel 7: |  |
|      |      |             | DFIFO Read Access                        |  |

# 27.6 Interface description

Table 27-2 USB OTG 2.0 Interface Description

| Module Pin   | Direction | Pad Name    | pinmux                     |
|--------------|-----------|-------------|----------------------------|
| OTG_VSSAC    | AG        | OTG_VSSAC   | -                          |
| OTG_DVSS     | DG        | OTG_DVSS    | -                          |
| OTG_DVDD     | DP        | OTG_DVDD    | -                          |
| OTG_VDD25    | AP        | OTG_VDD25   | -                          |
| OTG_DM       | Α         | OTG_DM      | -                          |
| OTG_RKELVIN  | Α         | OTG_RKELVIN | -                          |
| OTG_DP       | Α         | OTG_DP      | -                          |
| OTG_VSSA     | AG        | OTG_VSSA    | -                          |
| OTG_VBUS     | Α         | OTG_VBUS    | -                          |
| OTG_VDD33    | AP        | OTG_VDD33   | -                          |
| OTG_ID       | Α         | OTG_ID      | -                          |
| otg_drv_vbus | 0         | GPIO0_A[5]  | GRF_GPIO0A_IOMUX<br>[10]=1 |

Note: A—Analog pad; AP—Analog power; AG—Analog ground; DP—Digital power; DG— Digital ground;

## Chapter 28 I2S/PCM0 Controller (8 channel)

### 28.1 Overview

The I2S/PCM0 controller is designed for interfacing between the AHB bus and the I2S bus.

The I2S bus (Inter-IC sound bus) is a serial link for digital audio data transfer between devices in the system and be invented by Philips Semiconductor. Now it is widely used by many semiconductor manufacturers.

Devices often use the I2S bus are ADC, DAC, DSP, CPU, etc. With the I2S interface, we can connect audio devices and the embedded SoC platform together and provide an audio interface solution for the system.

Not only I2S but also PCM mode surround audio output (up to 7.1channel) and stereo input are supported in I2S/PCM0 controller.

- Support five internal 32-bit wide and 32-location deep FIFOs, four for transmitting and one for receiving audio data
- Support AHB bus interface
- Support 16 ~ 32 bits audio data transfer
- Support master and slave mode
- Support DMA handshake interface and configurable DMA water level
- Support transmit FIFO empty, underflow, receive FIFO full, overflow interrupt and all interrupts can be masked
- Support configurable water level of transmit FIFO empty and receive FIFO full interrupt
- Support combine interrupt output
- Support 2,4,6,8 channels audio transmitting in I2S and PCM mode
- Support 2 channels audio receiving in I2S and PCM mode
- Support up to 192kHz sample rate
- Support I2S normal, left and right justified mode serial audio data transfer
- Support PCM early, late1, late2, late3 mode serial audio data transfer
- Support MSB or LSB first serial audio data transfer
- Support 16 to 31 bit audio data left or right justified in 32-bit wide FIFO
- Support two 16-bit audio data store together in one 32-bit wide location
- Support 3 independent LRCK signals, one for receiving and two for transmitting audio data
- Support configurable SCLK and LRCK polarity
- Support SCLK is equivalent to MCLK divided by an even number range from 2 to 64 in master mode

## 28.2 Block Diagram



Fig. 28-1 I2S/PCM0 controller (8 channel) Block Diagram

### **System Interface**

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

## **Clock Generator**

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

#### **Transmitters**

The Transmitters implement transmission operation. The transmitters can act as either master or slave, with I2S or PCM mode surround (up to 7.1 channel) serial audio interface.

### Receiver

The Receiver implements receive operation. The receiver can act as either master or slave, with I2S or PCM mode stereo serial audio interface.

#### Transmit FIFOs

The Transmit FIFOs are the buffer to store transmitted audio data. Each of the size of the four FIFOs 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.

# 28.3 Function description

In the I2S/PCM0 controller, there are four conditions: transmitter-master & receiver-master; transmitter-master & receiver-slave; transmitter-slave & receiver-master; transmitter-slave & receiver-slave.





Fig. 28-2I2S transmitter-master & receiver-slave condition

When transmitter acts as a master, it sends all signals to receiver (slave), and CPU control when to send clock and data to the receiver. When acting as a slave, SD signal still goes from transmitter to receiver, but SCLK and LRCK signals are from receiver (master) to transmitter. Based on three interface specifications, transmitting data should be ready before transmitter receives SCLK and LRCK signals. CPU should know when the receiver to initialize a transaction and when to send data.



Fig. 28-3I2S transmitter-slave& receiver-master condition

When the receiver acts as a master, it sends SCLK and LRCK signals to the transmitter (slave) and receives serial data. So CPU must tell the transmitter when to start a transaction for it to prepare transmitting data then start a transfer and send clock and channel-select signals. When the receiver acts as a slave, CPU should only do initial setting and wait for all signals and then start reading data.

Before transmitting or receiving data, CPU need do initial setting to the I2S register. These includes CPU settings, I2S interface registers settings, and maybe the embedded SoC platform settings. These registers must be set before starting data transfer.

#### 28.3.1 I2S normal mode

This is the waveform of I2S normal mode. For LRCK (i2s0\_lrck\_rx/i2s0\_lrck\_tx0) signal, it goes low to indicate left channel and high to right channel. For SD (i2s0\_sdo0, i2s0\_sdo1, i2s0\_sdo2, i2s0\_sdo3, i2s0\_sdi) signal, it transfers MSB or LSB first and sends the first bit one SCLK clock cycle after LRCK changes. The range of SD signal width is from 16 to 32bits.





Fig. 28-4I2S normal mode timing format

### 28.3.2 I2S left justified mode

This is the waveform of I2S left justified mode. For LRCK (i2s0\_lrck\_rx / i2s0 lrck tx0) signal, it goes high to indicate left channel and low to right channel. For SD (i2s0 sdo0, i2s0 sdo1, i2s0 sdo2, i2s0 sdo3, i2s0 sdi) signal, it transfers MSB or LSB first and sends the first bit at the same time when LRCK changes. The range of SD signal width is from 16 to 32bits.



Fig. 28-5I2S left justified mode timing format

### 28.3.3 I2S right justified mode

This is the waveform of I2S right justified mode. For LRCK (i2s0\_lrck\_rx / i2s0\_lrck\_tx0) signal, it goes high to indicate left channel and low to right channel. For SD (i2s0\_sdo0, i2s0\_sdo1, i2s0\_sdo2, i2s0\_sdo3, i2s0\_sdi) signal, it transfers MSB or LSB first; but different from I2S normal or left justified mode, its data is aligned to last bit at the edge of the LRCK signal. The range of SD signal width is from 16 to 32bits.



Fig. 28-6I2S right justified modetiming format

### 28.3.4 PCM early mode

This is the waveform of PCM early mode. For LRCK (i2s0\_lrck\_rx /

i2s0\_lrck\_tx0) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s0\_sdo0, i2s0\_sdi) signal, it transfers MSB or LSB first and sends the first bit at the same time when LRCK goes high. The range of SD signal width is from 16 to 32bits.



Fig. 28-7PCM early modetiming format

### 28.3.5 PCM late1 mode

This is the waveform of PCM early mode. For LRCK (i2s0\_lrck\_rx / i2s0\_lrck\_tx0) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s0\_sdo0, i2s0\_sdi) signal, it transfers MSB or LSB first and sends the first bit one SCLK clock cycle after LRCK goes high. The range of SD signal width is from 16 to 32bits.



Fig. 28-8PCM late1 modetiming format

### 28.3.6 PCM late2 mode

This is the waveform of PCM early mode. For LRCK (i2s0\_lrck\_rx / i2s0\_lrck\_tx0) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s0\_sdo0, i2s0\_sdi) signal, it transfers MSB or LSB first and sends the first bit two SCLK clock cycles after LRCK goes high. The range of SD signal width is from 16 to 32bits.

channel0 left

Fig. 28-9PCM late2 modetiming format

channel0 right

#### 28.3.7 PCM late3 mode

i2s0\_sdi

This is the waveform of PCM early mode. For LRCK (i2s0\_lrck\_rx / i2s0\_lrck\_tx0) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s0\_sdo0, i2s0\_sdi) signal, it transfers MSB or LSB first and sends the first bit three SCLK clock cycles after LRCK goes high. The range of SD signal width is from 16 to 32bits.



Fig. 28-10PCM late3 modetiming format

## 28.4 Register description

### 28.4.1 Register Summary

| Name        | Offset | Size | <b>Reset Value</b> | Description                         |
|-------------|--------|------|--------------------|-------------------------------------|
| I2S0_TXCR   | 0x0000 | W    | 0x000000f          | transmit operation control register |
| I2S0_RXCR   | 0x0004 | W    | 0x000000f          | receive operation control register  |
| I2S0_CKR    | 0x0008 | W    | 0x00071f1f         | clock generation register           |
| I2S0_FIFOLR | 0x000c | W    | 0x0000000          | FIFO level register                 |
| I2S0_DMACR  | 0x0010 | W    | 0x001f0000         | DMA control register                |
| I2S0_INTCR  | 0x0014 | W    | 0x01f00000         | interrupt control register          |
| I2S0_INTSR  | 0x0018 | W    | 0x00000000         | interrupt status register           |
| I2S0_XFER   | 0x001c | W    | 0x00000000         | Transfer Start Register             |
| I2S0_CLR    | 0x0020 | W    | 0x00000000         | SCLK domain logic clear Register    |
| I2S0_TXDR   | 0x0024 | W    | 0x00000000         | Transimt FIFO Data Register         |



| Name      | Offset | Size | Reset Value | Description                |
|-----------|--------|------|-------------|----------------------------|
| I2S0_RXDR | 0x0028 | W    | 0x00000000  | Receive FIFO Data Register |

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

## 28.4.2 Detail Register Description

### I2SO\_TXCR

Address: Operational Base + offset (0x0000)

transmit operation control register

| Bit   | Attr | Reset Value | Description                                    |
|-------|------|-------------|------------------------------------------------|
| 31:23 | RO   | 0x0         | reserved                                       |
|       |      |             | RCNT                                           |
|       |      |             | right jusitified counter                       |
|       |      |             | (Can be written only when XFER[0] bit is 0.)   |
| 22:17 | RW   | 0x00        | Only vailid in I2S Right justified format and  |
|       |      |             | slave tx mode is selected.                     |
|       |      |             | Start to tramsmit data RCNT sclk cycles after  |
|       |      |             | left channel valid.                            |
|       |      |             | CSR                                            |
|       |      | 0x0         | Channel select register                        |
|       | RW   |             | (Can be written only when XFER[0] bit is 0.)   |
| 16:15 |      |             | 0:channel 0 enable                             |
| 10.13 |      |             | 1:channel 0 & channel 1 enable                 |
|       |      |             | 2:channel 0 & channel 1 & channel 2 enable     |
|       |      |             | 3:channel 0 & channel 1 & channel 2 & channel  |
|       |      |             | 3 enable                                       |
|       |      | • 0         | HWT                                            |
|       |      | 0×0         | Halfword word transform                        |
|       |      |             | (Can be written only when XFER[0] bit is 0.)   |
| 14    | RW   |             | Only valid when VDW select 16bit data.         |
| 14    | KW   |             | 0:low 16bit data valid from AHB/APB bus.       |
|       |      |             | 1:32 bit data valid from AHB/APB bus. Low 16   |
|       |      |             | bit for left channel and high 16 bit for right |
| 0     |      |             | channel.                                       |
| 13    | RO   | 0x0         | reserved                                       |



| Bit  | Attr | Reset Value | Description                                         |
|------|------|-------------|-----------------------------------------------------|
|      |      |             | SJM                                                 |
|      |      |             | Store justified mode                                |
|      |      |             | (Can be written only when XFER[0] bit is 0.)        |
|      |      |             | 16bit~31bit DATA stored in 32 bits width fifo.      |
|      |      |             | If VDW select 16bit data, this bit is valid only    |
| 12   | RW   | 0x0         | when HWT select 0.Because if HWT is 1, every        |
|      |      |             | fifo unit contain two 16bit data and 32 bit         |
|      |      |             | space is full, it is impossible to choose justified |
|      |      |             | mode.                                               |
|      |      |             | 0:right justified                                   |
|      |      |             | 1:left justified                                    |
|      |      |             | FBM                                                 |
|      |      |             | First Bit Mode                                      |
| 11   | RW   | 0x0         | (Can be written only when XFER[0] bit is 0.)        |
|      |      |             | 0:MSB                                               |
|      |      |             | 1:LSB                                               |
|      |      |             | IBM                                                 |
|      |      |             | I2S bus mode                                        |
|      |      |             | (Can be written only when XFER[0] bit is 0.)        |
| 10:9 | RW   | 0x0         | 0:I2S normal                                        |
|      |      |             | 1:I2S Left justified                                |
|      |      |             | 2:I2S Right justified                               |
|      |      |             | 3:reserved                                          |
|      |      |             | PBM                                                 |
|      |      | . ()        | PCM bus mode                                        |
|      |      |             | (Can be written only when XFER[0] bit is 0.)        |
| 8:7  | RW   | 0x0         | 0:PCM no delay mode                                 |
|      |      | C           | 1:PCM delay 1 mode                                  |
|      | 11   |             | 2:PCM delay 2 mode                                  |
|      |      | 7           | 3:PCM delay 3 mode                                  |
| 6    | RO   | 0x0         | reserved                                            |
| 0    |      |             | TFS                                                 |
|      | ·    |             | Transfer format select                              |
| 5    | RW   | 0x0         | (Can be written only when XFER[0] bit is 0.)        |
|      |      |             | 0: I2S format                                       |
|      |      |             | 1: PCM format                                       |



| Bit | Attr | Reset Value | Description                                  |
|-----|------|-------------|----------------------------------------------|
|     |      |             | VDW                                          |
|     |      |             | Valid Data width                             |
|     |      |             | (Can be written only when XFER[0] bit is 0.) |
|     |      |             | 0~14:reserved                                |
|     |      |             | 15:16bit                                     |
|     |      |             | 16:17bit                                     |
| 4:0 | RW   | 0x0f        | 17:18bit                                     |
|     |      |             | 18:19bit                                     |
|     |      |             |                                              |
|     |      |             | 28:29bit                                     |
|     |      |             | 29:30bit                                     |
|     |      |             | 30:31bit                                     |
|     |      |             | 31:32bit                                     |

## I2SO\_RXCR

Address: Operational Base + offset (0x0004)

receive operation control register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                 |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                    |
| 14    | RW   | 0x0         | HWT Halfword word transform (Can be written only when XFER[1] bit is 0.) Only valid when VDW select 16bit data. 0:low 16bit data valid from AHB/APB bus. 1:32 bit data valid from AHB/APB bus. Low 16 bit for left channel and high 16 bit for right channel.                                                                                               |
| 13    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                    |
| 12    | RW   | 0×0         | SJM Store justified mode (Can be written only when XFER[1] bit is 0.) 16bit~31bit DATA stored in 32 bits width fifo. If VDW select 16bit data, this bit is valid only when HWT select 0.Because if HWT is 1, every fifo unit contain two 16bit data and 32 bit space is full, it is impossible to choose justified mode. 0:right justified 1:left justified |



| Bit  | Attr | Reset Value | Description                                  |
|------|------|-------------|----------------------------------------------|
|      |      |             | FBM                                          |
|      |      |             | First Bit Mode                               |
| 11   | RW   | 0x0         | (Can be written only when XFER[1] bit is 0.) |
|      |      |             | 0:MSB                                        |
|      |      |             | 1:LSB                                        |
|      |      |             | IBM                                          |
|      |      |             | I2S bus mode                                 |
|      |      |             | (Can be written only when XFER[1] bit is 0.) |
| 10:9 | RW   | 0x0         | 0:I2S normal                                 |
|      |      |             | 1:I2S Left justified                         |
|      |      |             | 2:I2S Right justified                        |
|      |      |             | 3:reserved                                   |
|      |      |             | РВМ                                          |
|      |      |             | PCM bus mode                                 |
|      |      |             | (Can be written only when XFER[1] bit is 0.) |
| 8:7  | RW   | 0x0         | 0:PCM no delay mode                          |
|      |      |             | 1:PCM delay 1 mode                           |
|      |      |             | 2:PCM delay 2 mode                           |
|      |      |             | 3:PCM delay 3 mode                           |
| 6    | RO   | 0x0         | reserved                                     |
|      |      |             | TFS                                          |
|      |      |             | Transfer format select                       |
| 5    | RW   | 0x0         | (Can be written only when XFER[1] bit is 0.) |
|      |      |             | 0:i2s                                        |
|      |      | . ()        | 1:pcm                                        |
|      |      |             | VDW                                          |
|      |      |             | Valid Data width                             |
|      |      |             | (Can be written only when XFER[1] bit is 0.) |
|      | 11   |             | 0~14:reserved                                |
|      | C    | · ·         | 15:16bit                                     |
|      |      |             | 16:17bit                                     |
| 4:0  | RW   | 0x0f        | 17:18bit                                     |
|      | ,    |             | 18:19bit                                     |
| 7    |      |             |                                              |
|      |      |             | 28:29bit                                     |
|      |      |             | 29:30bit                                     |
|      |      |             | 30:31bit                                     |
|      |      |             | 31:32bit                                     |

## I2SO\_CKR

Address: Operational Base + offset (0x0008)

clock generation register

| ciock generation register |      |                    |             |  |  |  |  |
|---------------------------|------|--------------------|-------------|--|--|--|--|
| Bit                       | Attr | <b>Reset Value</b> | Description |  |  |  |  |



| Bit   | Attr | Reset Value | Description                                         |
|-------|------|-------------|-----------------------------------------------------|
| 31:28 | RO   | 0x0         | reserved                                            |
|       |      |             | MSS                                                 |
|       |      |             | Master/slave mode select                            |
| 27    | RW   | 0.40        | (Can be written only when XFER[1] or XFER[0]        |
| 27    | KVV  | 0x0         | bit is 0.)                                          |
|       |      |             | 0:master mode(sclk output)                          |
|       |      |             | 1:slave mode(sclk input)                            |
|       |      |             | CKP                                                 |
|       |      |             | Sclk polarity                                       |
|       |      |             | (Can be written only when XFER[1] or XFER[0]        |
| 26    | RW   | 0×0         | bit is 0.)                                          |
| 20    | KVV  | UXU         | 0: sample data at posedge sclk and drive data       |
|       |      |             | at negedge sclk                                     |
|       |      |             | 1: sample data at negedge sclk and drive data       |
|       |      |             | at posedge sclk                                     |
|       |      |             | RLP                                                 |
|       |      |             | Receive Irck polarity                               |
|       |      |             | (Can be written only when XFER[1] or XFER[0]        |
|       |      |             | bit is 0.)                                          |
|       |      |             | 0:normal polartiy                                   |
|       |      |             | (I2S normal: low for left channel, high for right   |
|       |      |             | channel                                             |
| 25    | RW   | 0×0         | I2S left/right just: high for left channel, low for |
|       |      | o no        | right channel                                       |
|       |      | • 4         | PCM start signal:high valid)                        |
|       |      |             | 1:oppsite polarity                                  |
|       |      |             | (I2S normal: high for left channel, low for right   |
|       |      | ( )         | channel                                             |
|       | 1    |             | I2S left/right just: low for left channel, high for |
|       |      | · ·         | right channel                                       |
|       |      |             | PCM start signal:low valid)                         |



254,255:Fmclk=256\*Ftxsclk;



| Bit  | Attr | Reset Value | Description                                                                                                                                                                                             |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8 | RW   | 0x1f        | RSD Receive sclk divider (Can be written only when XFER[1] or XFER[0] bit is 0.) Receive sclk divider= Fsclk/Frxlrck 0~30:reserved 31: 32fs 32: 33fs 33: 34fs 34: 35fs                                  |
|      |      |             | 253: 254fs<br>254: 255fs<br>255: 256fs                                                                                                                                                                  |
| 7:0  | RW   | 0x1f        | Transmit sclk divider (Can be written only when XFER[1] or XFER[0] bit is 0.)  Transmit sclk divider=Ftxsclk/Ftxlrck 0~30:reserved 31: 32fs 32: 33fs 33: 34fs 34: 35fs 253: 254fs 254: 255fs 255: 256fs |

## I2SO\_FIFOLR

Address: Operational Base + offset (0x000c)

FIFO level register

| Bit      | Attr | Reset Value          | Description                                  |
|----------|------|----------------------|----------------------------------------------|
| 31:30    | RO   | 0x0                  | reserved                                     |
|          |      |                      | RFL                                          |
| 29:24    | RO   | 0×00                 | Receive FIFO Level                           |
| 29:24    | KU   | UXUU                 | Contains the number of valid data entries in |
|          |      |                      | the receive FIFO.                            |
|          |      |                      | TFL3                                         |
| 23:18 RO | 000  | Transmit FIFO3 Level |                                              |
|          | KU   | 0x00                 | Contains the number of valid data entries in |
|          |      |                      | the transmit FIFO3.                          |



| Bit   | Attr | Reset Value | Description                                  |
|-------|------|-------------|----------------------------------------------|
|       |      |             | TFL2                                         |
| 17:12 | RO   | 0×00        | Transmit FIFO2 Level                         |
| 17.12 | KO   | 0000        | Contains the number of valid data entries in |
|       |      |             | the transmit FIFO2.                          |
|       |      |             | TFL1                                         |
| 11:6  | RO   | 0×00        | Transmit FIFO1 Level                         |
| 11.0  | KO   | 0000        | Contains the number of valid data entries in |
|       |      |             | the transmit FIFO1.                          |
|       |      |             | TFL0                                         |
| 5:0   | RO   | 0x00        | Transmit FIFO0 Level                         |
| 3.0   | KO   |             | Contains the number of valid data entries in |
|       |      |             | the transmit FIFO0.                          |

### I2SO\_DMACR

Address: Operational Base + offset (0x0010)

DMA control register

| DIMA COI |       | l           | December 2                                       |  |
|----------|-------|-------------|--------------------------------------------------|--|
| Bit      | Attr  | Reset Value | Description                                      |  |
| 31:25    | RO    | 0x0         | reserved                                         |  |
|          |       |             | RDE                                              |  |
| 24       | RW    | 0×0         | Receive DMA Enable                               |  |
| 24       | INVV  | OXO         | 0 : Receive DMA disabled                         |  |
|          |       |             | 1 : Receive DMA enabled                          |  |
| 23:21    | RO    | 0x0         | reserved                                         |  |
|          |       |             | RDL                                              |  |
|          |       | • 0         | Receive Data Level                               |  |
|          |       |             | This bit field controls the level at which a DMA |  |
| 20:16    | RW    | 0x1f        | request is made by the receive logic. The        |  |
| 20.10    | INVV  |             | watermark level = $DMARDL+1$ ; that is,          |  |
|          |       |             | dma_rx_req is generated when the number of       |  |
|          |       | 7           | valid data entries in the receive FIFO is equal  |  |
|          |       |             | to or above this field value + 1.                |  |
| 15:9     | RO    | 0x0         | reserved                                         |  |
|          | V     |             | TDE                                              |  |
| 8        | RW    | 0×0         | Transmit DMA Enable                              |  |
| G        | IK VV |             | 0 : Transmit DMA disabled                        |  |
|          |       |             | 1 : Transmit DMA enabled                         |  |
| 7:5      | RO    | 0x0         | reserved                                         |  |



| Bit | Attr   | Reset Value                                                                  | Description                                      |
|-----|--------|------------------------------------------------------------------------------|--------------------------------------------------|
|     |        |                                                                              | TDL                                              |
|     |        |                                                                              | Transmit Data Level                              |
|     |        |                                                                              | This bit field controls the level at which a DMA |
|     |        | equal to the wadma_tx_req solution number of value TXFIFO(TXFIF CSR=01,TXFII | request is made by the transmit logic. It is     |
| 4:0 | RW     |                                                                              | equal to the watermark level; that is, the       |
| 4.0 | IK V V |                                                                              | dma_tx_req signal is generated when the          |
|     |        |                                                                              | number of valid data entries in the              |
|     |        |                                                                              | TXFIFO(TXFIFO0 if CSR=00;TXFIFO1 if              |
|     |        |                                                                              | CSR=01,TXFIFO2 if CSR=10,TXFIFO3 if              |
|     |        |                                                                              | CSR=11)is equal to or below this field value.    |

## I2SO\_INTCR

Address: Operational Base + offset (0x0014) interrupt control register

| interrup | control | register    |                                               |  |  |
|----------|---------|-------------|-----------------------------------------------|--|--|
| Bit      | Attr    | Reset Value | Description                                   |  |  |
| 31:25    | RO      | 0x0         | reserved                                      |  |  |
|          |         |             | RFT                                           |  |  |
|          |         |             | Receive FIFO Threshold                        |  |  |
| 24:20    | RW      | 0x1f        | When the number of receive FIFO entries is    |  |  |
|          |         |             | more than or equal to this threshold plus 1,  |  |  |
|          |         |             | the receive FIFO full interrupt is triggered. |  |  |
| 19       | RO      | 0x0         | reserved                                      |  |  |
|          |         |             | RXOIC                                         |  |  |
| 18       | WO      | 0x0         | RX overrun interrupt clear                    |  |  |
|          |         | . ()        | Write 1 to clear RX overrun interrupt.        |  |  |
|          |         |             | RXOIE                                         |  |  |
| 17       | RW      | 0x0         | RX overrun interrupt enable                   |  |  |
| 17       |         |             | 0:disable                                     |  |  |
|          |         |             | 1:enable                                      |  |  |
|          | 63      |             | RXFIE                                         |  |  |
| 16       | RW      | 0x0         | RX full interrupt enable                      |  |  |
|          |         |             | 0:disable                                     |  |  |
|          | V       |             | 1:enable                                      |  |  |
| 15:9     | RO      | 0x0         | reserved                                      |  |  |
|          |         |             | TFT                                           |  |  |
|          |         |             | Transmit FIFO Threshold                       |  |  |
|          |         |             | When the number of transmit FIFO (TXFIFO0     |  |  |
| 8:4      | RW      | 0x00        | if CSR=00; TXFIFO1 if CSR=01, TXFIFO2 if      |  |  |
|          |         |             | CSR=10, TXFIFO3 if CSR=11) entries is less    |  |  |
|          |         |             | than or equal to this threshold, the transmit |  |  |
|          |         |             | FIFO empty interrupt is triggered.            |  |  |
| 3        | RO      | 0x0         | reserved                                      |  |  |



| Bit | Attr  | Reset Value | Description                             |  |  |
|-----|-------|-------------|-----------------------------------------|--|--|
|     |       |             | TXUIC                                   |  |  |
| 2   | WO    | 0x0         | TX underrun interrupt clear             |  |  |
|     |       |             | Write 1 to clear TX underrun interrupt. |  |  |
|     |       |             | TXUIE                                   |  |  |
| 1   | RW    | 0x0         | TX underrun interrupt enable            |  |  |
| 1   | I KVV |             | 0:disable                               |  |  |
|     |       |             | 1:enable                                |  |  |
|     |       |             | TXEIE                                   |  |  |
| 0   | RW    | 0x0         | TX empty interrupt enable               |  |  |
| U   | KVV   |             | 0:disable                               |  |  |
|     |       |             | 1:enable                                |  |  |

## I2SO\_INTSR

Address: Operational Base + offset (0x0018)

interrupt status register

| Bit   | Attr | Reset Value | Description           |  |  |
|-------|------|-------------|-----------------------|--|--|
| 31:18 | RO   | 0x0         | reserved              |  |  |
|       |      |             | RXOI                  |  |  |
| 17    | RO   | 0×0         | RX overrun interrupt  |  |  |
| 17    | RU   | UXU         | 0:inactive            |  |  |
|       |      |             | 1:active              |  |  |
|       |      |             | RXFI                  |  |  |
| 16    | RO   | 0x0         | RX full interrupt     |  |  |
| 10    | KU   |             | 0:inactive            |  |  |
|       |      |             | 1:active              |  |  |
| 15:2  | RO   | 0x0         | reserved              |  |  |
|       |      | 0x0         | TXUI                  |  |  |
| 1     | RO   |             | TX underrun interrupt |  |  |
| 1     | KO   |             | 0:inactive            |  |  |
|       |      | 1           | 1:active              |  |  |
|       |      | 0×0         | TXEI                  |  |  |
| 0     | RO   |             | TX empty interrupt    |  |  |
| U     |      |             | 0:inactive            |  |  |
| ,     |      |             | 1:active              |  |  |

### I2SO\_XFER

Address: Operational Base + offset (0x001c)

Transfer Start Register

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



### I2SO\_CLR

Address: Operational Base + offset (0x0020)

SCLK domain logic clear Register

| Bit  | Attr | Reset Value | Description                                     |  |
|------|------|-------------|-------------------------------------------------|--|
| 31:2 | RO   | 0x0         | reserved                                        |  |
|      |      |             | RXC                                             |  |
| 14   | RW   | 0.40        | RX logic clear                                  |  |
| I KV | KVV  | 0x0         | This is a self cleard bit. Write 1 to clear all |  |
|      |      |             | receive logic.                                  |  |
| ·    |      |             | TXC                                             |  |
| 0    | DW   | UXU         | TX logic clear                                  |  |
|      | RW   |             | This is a self cleard bit. Write 1 to clear all |  |
|      |      |             | transmit logic.                                 |  |

### I2SO\_TXDR

Address: Operational Base + offset  $(0x0400 \sim 0x7FC)$ 

Transimt FIFO Data Register

| Bit  | Attr | Reset Value | Description                                    |
|------|------|-------------|------------------------------------------------|
|      |      | 0x00000000  | TXDR                                           |
| 31:0 | wo   |             | Transimt FIFO Data Register                    |
| 31.0 | WO   |             | When it is written to, data are moved into the |
| (    |      |             | transmit FIFO.                                 |

### I2SO\_RXDR

Address: Operational Base + offset (0x0800~0xBFC)

Receive FIFO Data Register

| Bit  | Attr | Reset Value | Description                                    |
|------|------|-------------|------------------------------------------------|
|      |      | 0×00000000  | RXDR                                           |
| 31:0 | RO   |             | Receive FIFO Data Register                     |
| 31.0 | RO   |             | When the register is read, data in the receive |
|      |      |             | FIFO is accessed.                              |

## 28.5 Timing Diagram

### 28.5.1 Master mode



Fig. 28-11Master mode timing diagram

Table 28-1Meaning of the parameterin Fig. 28-12

| Parameter          | Description                                                                                 | min  | typ  | max  | unit |
|--------------------|---------------------------------------------------------------------------------------------|------|------|------|------|
| t <sub>DLRCK</sub> | i2s0_lrck_rx/i2s0_lrck_tx propagation delay from i2s0_sclk falling edge                     | 1.65 | 2.42 | 3.38 | ns   |
| t <sub>DSDO</sub>  | i2s0_sdo0/i2s0_sdo1/i2s0_sdo2/i2s0_sdo3<br>propagation delay from i2s0_sclk falling<br>edge | 1.61 | 2.41 | 3.44 | ns   |
| t <sub>SUSDI</sub> | i2s0_sdi setup time to i2s0_sclk rising edge                                                | 4.53 | 6.52 | 9.04 | ns   |

### 28.5.2 Slave mode



Fig. 28-12Slave mode timing diagram



Table 28-2Meaning of the parameter in Fig. 28-13

| Parameter           | Description                                                                                  | min  | typ  | max   | unit |
|---------------------|----------------------------------------------------------------------------------------------|------|------|-------|------|
| t <sub>CSCLK</sub>  | i2s0_sclk cycle time (cannot be less than 40ns)                                              | -    | ı    | -     | ns   |
| t <sub>HSCLK</sub>  | i2s0_sclk pulse width high (cannot be less than 20ns)                                        | ı    | ı    | ı     | ns   |
| t <sub>LSCLK</sub>  | i2s0_sclk pulse width low (cannot be less than 20ns)                                         | 1    | 1    | -     | ns   |
| t <sub>sulrck</sub> | i2s0_lrck_rx/i2s0_lrck_tx setup time to i2s0_sclk falling edge                               | 0.94 | 1.36 | 1.42  | ns   |
| t <sub>DSDO</sub>   | i2s0_sdo0/i2s0_sdo1/i2s0_sdo2/i2s0_sdo<br>3 propagation delay from i2s0_sclk falling<br>edge | 5.37 | 7.89 | 10.96 | ns   |
| t <sub>SUSDI</sub>  | i2s0_sdi setup time to i2s0_sclk rising edge                                                 | 0.71 | 0.89 | 0.81  | ns   |

# 28.6 Interface description

|                   | D: .:     | <b>D</b> 1 11 | TOMBY C. III              |
|-------------------|-----------|---------------|---------------------------|
| <b>Module Pin</b> | Direction | Pad Name      | IOMUX Setting             |
| i2s0_sdi          | I         | GPIO0_A[7]    | GRF_GPIO0A_IOMUX[14]=1'b1 |
| i2s0_clk          | 0         | GPIO0_B[0]    | GRF_GPIO0B_IOMUX[ 0]=1'b1 |
| i2s0_sclk         | I/O       | GPIO0_B[1]    | GRF_GPIO0B_IOMUX[ 2]=1'b1 |
| i2s0_lrck_rx      | I/O       | GPIO0_B[2]    | GRF_GPIO0B_IOMUX[ 4]=1'b1 |
| i2s0_lrck_tx      | I/O       | GPIO0_B[3]    | GRF_GPIO0B_IOMUX[ 6]=1'b1 |
| i2s0_sdo0         | 0         | GPIO0_B[4]    | GRF_GPIO0B_IOMUX[ 8]=1'b1 |
| i2s0_sdo1         | 0         | GPIO0_B[5]    | GRF_GPIO0B_IOMUX[10]=1'b1 |
| i2s0_sdo2         | 0         | GPIO0_B[6]    | GRF_GPIO0B_IOMUX[12]=1'b1 |
| i2s0_sdo3         | 0         | GPIO0_B[7]    | GRF_GPIO0B_IOMUX[14]=1'b1 |

## 28.7 Application Notes



Fig. 28-13 I2S/PCM0 controller (8 channel) transmit operation flow chart





Fig. 28-14I2S/PCM0 controller (8 channel) receive operation flow chart

## Chapter 29 I2S/PCM1/2 Controller (2 channel)

### 29.1 Overview

The I2S/PCM1/2 controller is designed for interfacing between the AHB bus and the I2S bus.

The I2S bus (Inter-IC sound bus) is a serial link for digital audio data transfer between devices in the system and be invented by Philips Semiconductor. Now it is widely used by many semiconductor manufacturers.

Devices often use the I2S bus are ADC, DAC, DSP, CPU, etc. With the I2S interface, we can connect audio devices and the embedded SoC platform together and provide an audio interface solution for the system.

Not only I2S but also PCM mode stereo audio output and input are supported in I2S/PCM1/2 controller.

- Support two internal 32-bit wide and 32-location deep FIFOs, one for transmitting and the other for receiving audio data
- Support AHB bus interface
- Support 16 ~ 32 bits audio data transfer
- Support master and slave mode
- Support DMA handshake interface and configurable DMA water level
- Support transmit FIFO empty, underflow, receive FIFO full, overflow interrupt and all interrupts can be masked
- Support configurable water level of transmit FIFO empty and receive FIFO full interrupt
- Support combine interrupt output
- Support 2 channels audio transmitting in I2S mode but 2,4,6,8 channels in PCM mode
- Support 2 channels audio receiving in I2S and PCM mode
- Support up to 192kHz sample rate
- Support I2S normal, left and right justified mode serial audio data transfer
- Support PCM early, late1, late2, late3 mode serial audio data transfer
- Support MSB or LSB first serial audio data transfer
- Support 16 to 31 bit audio data left or right justified in 32-bit wide FIFO
- Support two 16-bit audio data store together in one 32-bit wide location
- Support 2 independent LRCK signals, one for receiving and the other for transmitting audio data
- Support configurable SCLK and LRCK polarity
- Support SCLK is equivalent to MCLK divided by an even number range from 2 to 64 in master mode

# 29.2 Block Diagram



Fig. 29-1 I2S/PCM1/2 controller (2 channel) Block Diagram

### **System Interface**

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

#### **Clock Generator**

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

#### **Transmitters**

The Transmitters implement transmission operation. The transmitters can act as either master or slave, with I2S or PCM mode surround (up to 7.1 channel) serial audio interface.

### Receiver

The Receiver implements receive operation. The receiver can act as either master or slave, with I2S or PCM mode stereo serial audio interface.

#### Transmit FIFO

The Transmit FIFO is the buffer to store transmitted audio data. The size of the FIFO is 32bits x 32.

#### **Receive FIFO**

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

## 29.3 Function description

In the I2S/PCM1/2 controller, there are four conditions: transmitter-master & receiver-master; transmitter-master & receiver-slave; transmitter-slave & receiver-master; transmitter-slave & receiver-slave.





Fig. 29-2I2S transmitter-master & receiver-slave condition

When transmitter acts as a master, it sends all signals to receiver (slave), and CPU control when to send clock and data to the receiver. When acting as a slave, SD signal still goes from transmitter to receiver, but SCLK and LRCK signals are from receiver (master) to transmitter. Based on three interface specifications, transmitting data should be ready before transmitter receives SCLK and LRCK signals. CPU should know when the receiver to initialize a transaction and when to send data.



Fig. 29-3I2S transmitter-slave & receiver-master condition

When the receiver acts as a master, it sends SCLK and LRCK signals to the transmitter (slave) and receives serial data. So CPU must tell the transmitter when to start a transaction for it to prepare transmitting data then start a transfer and send clock and channel-select signals. When the receiver acts as a slave, CPU should only do initial setting and wait for all signals and then start reading data.

Before transmitting or receiving data, CPU need do initial setting to the I2S register. These includes CPU settings, I2S interface registers settings, and maybe the embedded SoC platform settings. These registers must be set before starting data transfer.

#### 29.3.1 I2S normal mode

This is the waveform of I2S normal mode. For LRCK (i2s1\_lrck\_rx/i2s1\_lrck\_tx) signal, it goes low to indicate left channel and high to right channel. For SD (i2s1\_sdo, i2s1\_sdi) signal, it transfers MSB or LSB first and sends the first bit one SCLK clock cycle after LRCK changes. The range of SD signal width is from 16 to 32bits.



Fig. 29-4I2S normal mode timing format

#### 29.3.2 I2S left justified mode

This is the waveform of I2S left justified mode. For LRCK (i2s1\_lrck\_rx / i2s1\_lrck\_tx) signal, it goes high to indicate left channel and low to right channel.

For SD (i2s1 sdo, i2s1 sdi) signal, it transfers MSB or LSB first and sends the first bit at the same time when LRCK changes. The range of SD signal width is from 16 to 32bits.



Fig. 29-5I2S left justified mode timing format

### 29.3.3 I2S right justified mode

This is the waveform of I2S right justified mode. For LRCK (i2s1 lrck rx/ i2s1 lrck tx) signal, it goes high to indicate left channel and low to right channel. For SD (i2s1 sdo, i2s1 sdi) signal, it transfers MSB or LSB first; but different from I2S normal or left justified mode, its data is aligned to last bit at the edge of the LRCK signal. The range of SD signal width is from 16 to 32bits.



Fig. 29-6I2S right justified mode timing format

### 29.3.4 PCM early mode

This is the waveform of PCM early mode. For LRCK (i2s1 lrck rx/i2s1 lrck tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s1\_sdo, i2s1\_sdi) signal, it transfers MSB or LSB first and sends the first bit at the same time when LRCK goes high. The range of SD signal width is from 16 to 32bits.



Fig. 29-7PCM early mode timing format

### 29.3.5 PCM late1 mode

This is the waveform of PCM early mode. For LRCK (i2s1\_lrck\_rx/i2s1\_lrck\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s1 sdo, i2s1 sdi) signal, it transfers MSB or LSB first and sends the first bit one SCLK clock cycle after LRCK goes high. The range of SD signal width is from 16 to 32bits.

channel() left

Fig. 29-8PCM late1 mode timing format

#### 29.3.6 PCM late2 mode

This is the waveform of PCM early mode. For LRCK (i2s1\_lrck\_rx/i2s1\_lrck\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s1\_sdo, i2s1\_sdi) signal, it transfers MSB or LSB first and sends the first bit two SCLK clock cycles after LRCK goes high. The range of SD signal width is from 16 to 32bits.



Fig. 29-9PCM late2 mode timing format

### 29.3.7 PCM late3 mode

This is the waveform of PCM early mode. For LRCK (i2s1\_lrck\_rx/i2s1\_lrck\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s1\_sdo, i2s1\_sdi) signal, it transfers MSB or LSB first and sends the first bit three SCLK clock cycles after LRCK goes high. The range of SD signal width is from 16 to 32bits.



Fig. 29-10PCM late3 mode timing format

# 29.4 Register description

29.4.1 Register Summary

| Name        | Offset | Size       | Reset Value                | Description                         |
|-------------|--------|------------|----------------------------|-------------------------------------|
| I2Sx_TXCR   | 0x0000 | W          | 0x000000f                  | transmit operation control register |
| I2Sx_RXCR   | 0x0004 | W          | 0x000000f                  | receive operation control register  |
| I2Sx_CKR    | 0x0008 | W          | 0x00071f1f                 | clock generation register           |
| I2Sx_FIFOLR | 0x000c | W          | 0x0000000                  | FIFO level register                 |
| I2Sx_DMACR  | 0x0010 | W          | 0x001f0000                 | DMA control register                |
| I2Sx_INTCR  | 0x0014 | W          | 0x0000000                  | interrupt control register          |
| I2Sx_INTSR  | 0x0018 | W          | 0x0000000                  | interrupt status register           |
| I2Sx_XFER   | 0x001c | W          | 0x0000000                  | Transfer Start Register             |
| I2Sx_CLR    | 0x0020 | W          | 0x00000000                 | SCLK domain logic clear Register    |
| I2Sx_TXDR   | 0x0400 | W          | 0,0000000                  | Transimt FIFO Data Register         |
| IZ3X_IXDR   | ~0x7FC | VV         | 020000000                  | Transmit i ii O Data Register       |
| 0x0800 W    | W      | 0,00000000 | Passiva FIFO Data Pasiatan |                                     |
| I2Sx_RXDR   | ~0xBFC | VV         |                            | Receive FIFO Data Register          |

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

## 29.4.2 Detail Register Description

## I2Sx\_TXCR

Address: Operational Base + offset (0x0000)

transmit operation control register

| Bit   | Attr | Reset Value | Description                                    |
|-------|------|-------------|------------------------------------------------|
| 31:23 | RO   | 0x0         | reserved                                       |
|       |      |             | RCNT                                           |
|       |      | VO X        | right jusitified counter                       |
|       |      |             | (Can be written only when XFER[0] bit is 0.)   |
| 22:17 | RW   | 0x00        | Only vailid in I2S Right justified format and  |
|       |      | 7           | slave tx mode is selected.                     |
|       |      | 7           | Start to tramsmit data RCNT sclk cycles after  |
|       |      |             | left channel valid.                            |
|       |      |             | CSR                                            |
| 16:15 | RW   | 0x0         | Channel select register                        |
|       |      |             | Must be 2'b00.                                 |
|       |      |             | HWT                                            |
|       |      |             | Halfword word transform                        |
|       |      |             | (Can be written only when XFER[0] bit is 0.)   |
| 14    | RW   | 0×0         | Only valid when VDW select 16bit data.         |
| 14    | INV  | 0.00        | 0:low 16bit data valid from AHB/APB bus.       |
|       |      |             | 1:32 bit data valid from AHB/APB bus. Low 16   |
|       |      |             | bit for left channel and high 16 bit for right |
|       |      |             | channel.                                       |



| Bit  | Attr | Reset Value | Description                                                      |
|------|------|-------------|------------------------------------------------------------------|
| 13   | RO   | 0x0         | reserved                                                         |
|      |      |             | SJM                                                              |
|      |      |             | Store justified mode                                             |
|      |      |             | (Can be written only when XFER[0] bit is 0.)                     |
|      |      |             | 16bit~31bit DATA stored in 32 bits width fifo.                   |
|      |      |             | If VDW select 16bit data, this bit is valid only                 |
| 12   | RW   | 0x0         | when HWT select 0.Because if HWT is 1, every                     |
|      |      |             | fifo unit contain two 16bit data and 32 bit                      |
|      |      |             | space is full, it is impossible to choose justified              |
|      |      |             | mode.                                                            |
|      |      |             | 0:right justified                                                |
|      |      |             | 1:left justified                                                 |
|      |      |             | FBM                                                              |
|      |      |             | First Bit Mode                                                   |
| 11   | RW   | 0x0         | (Can be written only when XFER[0] bit is 0.)                     |
|      |      |             | 0:MSB                                                            |
|      |      |             | 1:LSB                                                            |
|      |      |             | IBM                                                              |
|      |      |             | I2S bus mode                                                     |
|      |      |             | (Can be written only when XFER[0] bit is 0.)                     |
| 10:9 | RW   | 0x0         | 0:I2S normal                                                     |
|      |      |             | 1:I2S Left justified                                             |
|      |      |             | 2:I2S Right justified                                            |
|      |      |             | 3:reserved                                                       |
|      |      | • ~ ~       | PBM<br>PCM bus mode                                              |
|      |      | A A Y       |                                                                  |
| 8:7  | RW   | 0×0         | (Can be written only when XFER[0] bit is 0.) 0:PCM no delay mode |
| 0.7  | KVV  | OXO         | 1:PCM delay 1 mode                                               |
|      |      | 7           | 2:PCM delay 2 mode                                               |
|      |      | Y           | 3:PCM delay 3 mode                                               |
| 6    | RO   | 0x0         | reserved                                                         |
|      |      |             | TFS                                                              |
|      |      |             | Transfer format select                                           |
| 5    | RW   | 0×0         | (Can be written only when XFER[0] bit is 0.)                     |
|      |      |             | 0: I2S format                                                    |
|      |      |             | 1: PCM format                                                    |



| Bit | Attr | Reset Value | Description                                  |
|-----|------|-------------|----------------------------------------------|
|     |      |             | VDW                                          |
|     |      |             | Valid Data width                             |
|     |      |             | (Can be written only when XFER[0] bit is 0.) |
|     |      |             | 0~14:reserved                                |
|     |      |             | 15:16bit                                     |
|     |      |             | 16:17bit                                     |
| 4:0 | RW   | 0x0f        | 17:18bit                                     |
|     |      |             | 18:19bit                                     |
|     |      |             |                                              |
|     |      |             | 28:29bit                                     |
|     |      |             | 29:30bit                                     |
|     |      |             | 30:31bit                                     |
|     |      |             | 31:32bit                                     |

## I2Sx\_RXCR

Address: Operational Base + offset (0x0004) receive operation control register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                 |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                    |
| 14    | RW   | 0x0         | HWT Halfword word transform (Can be written only when XFER[1] bit is 0.) Only valid when VDW select 16bit data. 0:low 16bit data valid from AHB/APB bus. 1:32 bit data valid from AHB/APB bus. Low 16 bit for left channel and high 16 bit for right channel.                                                                                               |
| 13    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                    |
| 12    | RW   | 0×0         | SJM Store justified mode (Can be written only when XFER[1] bit is 0.) 16bit~31bit DATA stored in 32 bits width fifo. If VDW select 16bit data, this bit is valid only when HWT select 0.Because if HWT is 1, every fifo unit contain two 16bit data and 32 bit space is full, it is impossible to choose justified mode. 0:right justified 1:left justified |



| Bit  | Attr | Reset Value | Description                                  |
|------|------|-------------|----------------------------------------------|
|      |      |             | FBM                                          |
|      |      |             | First Bit Mode                               |
| 11   | RW   | 0x0         | (Can be written only when XFER[1] bit is 0.) |
|      |      |             | 0:MSB                                        |
|      |      |             | 1:LSB                                        |
|      |      |             | IBM                                          |
|      |      |             | I2S bus mode                                 |
|      |      |             | (Can be written only when XFER[1] bit is 0.) |
| 10:9 | RW   | 0x0         | 0:I2S normal                                 |
|      |      |             | 1:I2S Left justified                         |
|      |      |             | 2:I2S Right justified                        |
|      |      |             | 3:reserved                                   |
|      |      |             | РВМ                                          |
|      |      |             | PCM bus mode                                 |
|      |      |             | (Can be written only when XFER[1] bit is 0.) |
| 8:7  | RW   | 0x0         | 0:PCM no delay mode                          |
|      |      |             | 1:PCM delay 1 mode                           |
|      |      |             | 2:PCM delay 2 mode                           |
|      |      |             | 3:PCM delay 3 mode                           |
| 6    | RO   | 0x0         | reserved                                     |
|      |      |             | TFS                                          |
|      |      |             | Transfer format select                       |
| 5    | RW   | 0x0         | (Can be written only when XFER[1] bit is 0.) |
|      |      |             | 0:i2s                                        |
|      |      |             | 1:pcm                                        |
|      |      | 1           | VDW                                          |
|      |      | 10 y        | Valid Data width                             |
|      |      |             | (Can be written only when XFER[1] bit is 0.) |
|      | 1    |             | 0~14:reserved                                |
|      |      | 7           | 15:16bit                                     |
|      |      |             | 16:17bit                                     |
| 4:0  | RW   | 0x0f        | 17:18bit                                     |
|      | ,    |             | 18:19bit                                     |
|      |      |             | <b></b>                                      |
|      |      |             | 28:29bit                                     |
|      |      |             | 29:30bit                                     |
|      |      |             | 30:31bit                                     |
|      |      |             | 31:32bit                                     |

## I2Sx\_CKR

Address: Operational Base + offset (0x0008)

clock generation register

| <br>arout garraration register |      |             |             |  |  |  |
|--------------------------------|------|-------------|-------------|--|--|--|
| Bit                            | Attr | Reset Value | Description |  |  |  |



| Bit   | Attr | Reset Value | Description                                         |
|-------|------|-------------|-----------------------------------------------------|
| 31:28 | RO   | 0x0         | reserved                                            |
|       |      |             | MSS                                                 |
|       |      |             | Master/slave mode select                            |
| 27    | RW   | 0×0         | (Can be written only when XFER[1] or XFER[0]        |
| 27    | KVV  | UXU         | bit is 0.)                                          |
|       |      |             | 0:master mode(sclk output)                          |
|       |      |             | 1:slave mode(sclk input)                            |
|       |      |             | CKP                                                 |
|       |      |             | Sclk polarity                                       |
|       |      |             | (Can be written only when XFER[1] or XFER[0]        |
| 26    | RW   | 0×0         | bit is 0.)                                          |
| 20    | INVV | 0.00        | 0: sample data at posedge sclk and drive data       |
|       |      |             | at negedge sclk                                     |
|       |      |             | 1: sample data at negedge sclk and drive data       |
|       |      |             | at posedge sclk                                     |
|       |      |             | RLP                                                 |
|       |      |             | Receive Irck polarity                               |
|       |      |             | (Can be written only when XFER[1] or XFER[0]        |
|       |      |             | bit is 0.)                                          |
|       |      |             | 0:normal polartiy                                   |
|       |      |             | (I2S normal: low for left channel, high for right   |
|       |      |             | channel                                             |
| 25    | RW   | 0×0         | I2S left/right just: high for left channel, low for |
|       |      |             | right channel                                       |
|       |      | • 1         | PCM start signal:high valid)                        |
|       |      |             | 1:oppsite polarity                                  |
|       |      |             | (I2S normal: high for left channel, low for right   |
|       |      |             | channel                                             |
|       |      |             | I2S left/right just: low for left channel, high for |
|       |      | 7           | right channel                                       |
|       |      |             | PCM start signal:low valid)                         |



| Bit   | Attr | Reset Value | Description                                         |
|-------|------|-------------|-----------------------------------------------------|
|       |      |             | TLP                                                 |
|       |      |             | Transmit Irck polarity                              |
|       |      |             | (Can be written only when XFER[1] or XFER[0]        |
|       |      |             | bit is 0.)                                          |
|       |      |             | 0:normal polartiy                                   |
|       |      |             | (I2S normal: low for left channel, high for right   |
|       |      |             | channel                                             |
| 2.4   | DW   | 00          | I2S left/right just: high for left channel, low for |
| 24    | RW   | 0x0         | right channel                                       |
|       |      |             | PCM start signal:high valid)                        |
|       |      |             | 1:oppsite polarity                                  |
|       |      |             | (I2S normal: high for left channel, low for right   |
|       |      |             | channel                                             |
|       |      |             | I2S left/right just: low for left channel, high for |
|       |      |             | right channel                                       |
|       |      |             | PCM start signal:low valid)                         |
|       |      |             | MDIV                                                |
|       |      |             | mclk divider                                        |
|       |      |             | (Can be written only when XFER[1] or XFER[0]        |
|       |      |             | bit is 0.)                                          |
|       |      |             | Serial Clock Divider = Fmclk / Ftxsclk-1.(mclk      |
|       |      |             | frequecy / txsclk frequecy-1)                       |
|       |      |             | 0 :Fmclk=Ftxsclk;                                   |
| 23:16 | RW   | 0x07        | 1 :Fmclk=2*Ftxsclk;                                 |
|       |      | 0,107       | 2,3 :Fmclk=4*Ftxsclk;                               |
|       |      |             | 4,5 :Fmclk=6*Ftxsclk;                               |
|       |      |             |                                                     |
|       |      |             | 60,61:Fmclk=62*Ftxsclk;                             |
|       | 1    |             | 62,63:Fmclk=64*Ftxsclk;                             |
|       |      | · ·         | <br>  252 252 5                                     |
|       |      |             | 252,253:Fmclk=254*Ftxsclk;                          |
|       |      |             | 254,255:Fmclk=256*Ftxsclk;                          |



| Bit  | Attr  | Reset Value | Description                                  |
|------|-------|-------------|----------------------------------------------|
|      |       |             | RSD                                          |
|      |       |             | Receive sclk divider                         |
|      |       |             | (Can be written only when XFER[1] or XFER[0] |
|      |       |             | bit is 0.)                                   |
|      |       |             | Receive sclk divider= Fsclk/Frxlrck          |
|      |       |             | 0~30:reserved                                |
| 15.0 | DW    | 016         | 31: 32fs                                     |
| 15:8 | RW    | 0x1f        | 32: 33fs                                     |
|      |       |             | 33: 34fs                                     |
|      |       |             | 34: 35fs                                     |
|      |       |             |                                              |
|      |       |             | 253: 254fs                                   |
|      |       |             | 254: 255fs                                   |
|      |       |             | 255: 256fs                                   |
|      |       |             | TSD                                          |
|      |       |             | Transmit sclk divider                        |
|      |       |             | (Can be written only when XFER[1] or XFER[0] |
|      |       |             | bit is 0.)                                   |
|      |       |             | Transmit sclk divider=Ftxsclk/Ftxlrck        |
|      |       |             | 0~30:reserved                                |
| 7:0  | RW    | 0x1f        | 31: 32fs                                     |
| 7.0  | IK VV | UXII        | 32: 33fs                                     |
|      |       |             | 33: 34fs                                     |
|      |       |             | 34: 35fs                                     |
|      |       |             | ·····                                        |
|      |       |             | 253: 254fs                                   |
|      |       | V Y         | 254: 255fs                                   |
|      |       | C > Y       | 255: 256fs                                   |

## I2Sx\_FIFOLR

Address: Operational Base + offset (0x000c)

FIFO level register

| Bit   | Attr | Reset Value | Description                                  |
|-------|------|-------------|----------------------------------------------|
| 31:30 | RO   | 0x0         | reserved                                     |
|       |      |             | RFL                                          |
| 29:24 | DO.  | 0.00        | Receive FIFO Level                           |
| 29:24 | RO   | 0x00        | Contains the number of valid data entries in |
|       |      |             | the receive FIFO.                            |
| 23:6  | RO   | 0x0         | reserved                                     |
|       |      | 0×00        | TFL                                          |
| 5:0   | RO   |             | Transmit FIFO Level                          |
|       |      |             | Contains the number of valid data entries in |
|       |      |             | the transmit FIFO0.                          |



Address: Operational Base + offset (0x0010)

DMA control register

| DMA control register |        |             |                                                  |  |
|----------------------|--------|-------------|--------------------------------------------------|--|
| Bit                  | Attr   | Reset Value | Description                                      |  |
| 31:25                | RO     | 0x0         | reserved                                         |  |
|                      |        |             | RDE                                              |  |
| 24                   | RW     | 0×0         | Receive DMA Enable                               |  |
| 24                   | IXVV   | 0.00        | 0 : Receive DMA disabled                         |  |
|                      |        |             | 1 : Receive DMA enabled                          |  |
| 23:21                | RO     | 0x0         | reserved                                         |  |
|                      |        |             | RDL                                              |  |
|                      |        |             | Receive Data Level                               |  |
|                      |        |             | This bit field controls the level at which a DMA |  |
| 20:16                | RW     | 0x1f        | request is made by the receive logic. The        |  |
| 20.10                | KVV    | UXII        | watermark level = $DMARDL+1$ ; that is,          |  |
|                      |        |             | dma_rx_req is generated when the number of       |  |
|                      |        |             | valid data entries in the receive FIFO is equal  |  |
|                      |        |             | to or above this field value + 1.                |  |
| 15:9                 | RO     | 0x0         | reserved                                         |  |
|                      |        |             | TDE                                              |  |
| 8                    | RW     | 0×0         | Transmit DMA Enable                              |  |
| 0                    | IK V V | UXU         | 0 : Transmit DMA disabled                        |  |
|                      |        |             | 1 : Transmit DMA enabled                         |  |
| 7:5                  | RO     | 0x0         | reserved                                         |  |
|                      |        | • 1         | TDL                                              |  |
|                      |        |             | Transmit Data Level                              |  |
|                      |        |             | This bit field controls the level at which a DMA |  |
|                      |        |             | request is made by the transmit logic. It is     |  |
| 4:0                  | RW     | 0x00        | equal to the watermark level; that is, the       |  |
| 4.0                  | KVV    | V V         | dma_tx_req signal is generated when the          |  |
|                      |        |             | number of valid data entries in the              |  |
|                      |        |             | TXFIFO(TXFIFO0 if CSR=00;TXFIFO1 if              |  |
|                      | V      |             | CSR=01,TXFIFO2 if CSR=10,TXFIFO3 if              |  |
| 7                    |        |             | CSR=11)is equal to or below this field value.    |  |

## I2Sx\_INTCR

Address: Operational Base + offset (0x0014)

interrupt control register

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:25 | RO   | 0x0         | reserved    |



| Bit   | Attr   | Reset Value | Description                                   |  |  |
|-------|--------|-------------|-----------------------------------------------|--|--|
|       |        |             | RFT                                           |  |  |
|       |        |             | Receive FIFO Threshold                        |  |  |
| 24:20 | RW     | 0x00        | When the number of receive FIFO entries is    |  |  |
|       |        |             | more than or equal to this threshold plus 1,  |  |  |
|       |        |             | the receive FIFO full interrupt is triggered. |  |  |
| 19    | RO     | 0x0         | reserved                                      |  |  |
|       |        |             | RXOIC                                         |  |  |
| 18    | WO     | 0x0         | RX overrun interrupt clear                    |  |  |
|       |        |             | Write 1 to clear RX overrun interrupt.        |  |  |
|       |        |             | RXOIE                                         |  |  |
| 17    | RW     | 0×0         | RX overrun interrupt enable                   |  |  |
| 17    | IX V V | 0.00        | 0:disable                                     |  |  |
|       |        |             | 1:enable                                      |  |  |
|       |        |             | RXFIE                                         |  |  |
| 16    | RW     | 0x0         | RX full interrupt enable                      |  |  |
| 10    | IX V V |             | 0:disable                                     |  |  |
|       |        |             | 1:enable                                      |  |  |
| 15:9  | RO     | 0x0         | reserved                                      |  |  |
|       |        |             | TFT                                           |  |  |
|       |        |             | Transmit FIFO Threshold                       |  |  |
|       |        |             | When the number of transmit FIFO (TXFIFO0     |  |  |
| 8:4   | RW     | 0×00        | if CSR=00; TXFIFO1 if CSR=01, TXFIFO2 if      |  |  |
|       |        |             | CSR=10, TXFIFO3 if CSR=11) entries is less    |  |  |
|       |        |             | than or equal to this threshold, the transmit |  |  |
|       |        | . 1         | FIFO empty interrupt is triggered.            |  |  |
| 3     | RO     | 0x0         | reserved                                      |  |  |
|       |        |             | TXUIC                                         |  |  |
| 2     | WO     | 0x0         | TX underrun interrupt clear                   |  |  |
|       | 1      |             | Write 1 to clear TX underrun interrupt.       |  |  |
|       |        | 7           | TXUIE                                         |  |  |
| 1 RW  |        | 0×0         | TX underrun interrupt enable                  |  |  |
|       |        | OXO         | 0:disable                                     |  |  |
|       | Y      |             | 1:enable                                      |  |  |
| 7     |        |             | TXEIE                                         |  |  |
| 0     | RW     | 0×0         | TX empty interrupt enable                     |  |  |
|       |        |             | 0:disable                                     |  |  |
|       |        |             | 1:enable                                      |  |  |

## I2Sx\_INTSR

Address: Operational Base + offset (0x0018)

interrupt status register

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
|-----|------|-------------|-------------|



| Bit   | Attr   | Reset Value | Description           |
|-------|--------|-------------|-----------------------|
| 31:18 | RO     | 0x0         | reserved              |
|       |        |             | RXOI                  |
| 17    | RO     | 0×0         | RX overrun interrupt  |
| 17    | KO     | UXU         | 0:inactive            |
|       |        |             | 1:active              |
|       |        |             | RXFI                  |
| 16    | RO     | 0×0         | RX full interrupt     |
| 10    | KU     |             | 0:inactive            |
|       |        |             | 1:active              |
| 15:2  | RO     | 0x0         | reserved              |
|       |        |             | TXUI                  |
| 1     | RO 0x0 |             | TX underrun interrupt |
| 1     | KO     | UXU         | 0:inactive            |
|       |        |             | 1:active              |
|       |        | 0x0         | TXEI                  |
| 0     | RO     |             | TX empty interrupt    |
| U     |        |             | 0:inactive            |
|       |        |             | 1:active              |

## I2Sx\_XFER

Address: Operational Base + offset (0x001c)

Transfer Start Register

| Bit  | Attr   | Reset Value | Description           |
|------|--------|-------------|-----------------------|
| 31:2 | RO     | 0x0         | reserved              |
|      |        | •. 0        | RXS                   |
| 1    | RW     | 10x0        | RX Transfer start bit |
| 1    | IK VV  |             | 0:stop RX transfer.   |
|      |        |             | 1:start RX transfer   |
|      |        |             | TXS                   |
| 0    | RW     | (()x()      | TX Transfer start bit |
| U    | KVV    |             | 0:stop TX transfer.   |
|      | $\cup$ |             | 1:start TX transfer   |

## I2Sx\_CLR

Address: Operational Base + offset (0x0020)

SCLK domain logic clear Register

| Bit  | Attr | Reset Value | Description                                     |  |  |
|------|------|-------------|-------------------------------------------------|--|--|
| 31:2 | RO   | 0x0         | reserved                                        |  |  |
| 1 RW |      | 0x0         | RXC                                             |  |  |
|      | RW   |             | RX logic clear                                  |  |  |
|      |      |             | This is a self cleard bit. Write 1 to clear all |  |  |
|      |      |             | receive logic.                                  |  |  |



| Bit | Attr   | Reset Value | Description                                     |  |  |
|-----|--------|-------------|-------------------------------------------------|--|--|
|     |        |             | TXC                                             |  |  |
|     | 0   DW | 00          | TX logic clear                                  |  |  |
| U   | RW 0x0 |             | This is a self cleard bit. Write 1 to clear all |  |  |
|     |        |             | transmit logic.                                 |  |  |

### I2Sx\_TXDR

Address: Operational Base + offset  $(0x0400 \sim 0x7FC)$ 

Transimt FIFO Data Register

| Bit  | Attr | Reset Value | Description                                    |
|------|------|-------------|------------------------------------------------|
|      |      |             | TXDR                                           |
| 21.0 | wo   | 00000000    | Transimt FIFO Data Register                    |
| 31:0 | WO   | 0x00000000  | When it is written to, data are moved into the |
|      |      |             | transmit FIFO.                                 |

### I2Sx\_RXDR

Address: Operational Base + offset (0x0800~0xBFC)

Receive FIFO Data Register

| Bit  | Attr | Reset Value | Description                                    |
|------|------|-------------|------------------------------------------------|
|      |      |             | RXDR                                           |
| 31:0 | RO   |             | Receive FIFO Data Register                     |
| 31:0 | RU   | 0x00000000  | When the register is read, data in the receive |
|      |      |             | FIFO is accessed.                              |

# 29.5 Timing Diagram

### 29.5.1 Master mode



Fig. 29-11Master mode timing diagram



Table 29-1Meaning of the parameter in Fig. 29-11

| Parameter          | Description                                                             | min  | typ  | max   | unit |
|--------------------|-------------------------------------------------------------------------|------|------|-------|------|
| t <sub>DLRCK</sub> | i2s1_lrck_rx/i2s1_lrck_tx propagation delay from i2s1_sclk falling edge | 1.1/ | 1.63 | 2.18  | ns   |
| t <sub>DSDO</sub>  | i2s1_sdo propagation delay from i2s1_sclk falling edge                  | 1.23 | 1.73 | 2.37  | ns   |
| t <sub>SUSDI</sub> | i2s1_sdi setup time to i2s1_sclk rising edge                            | 5.51 | 7.81 | 11.03 | ns   |

| 4 | x= | : 1 |
|---|----|-----|
|   |    |     |
|   | _  |     |

| Parameter          | Description                                                             |      | typ  | max   | unit |
|--------------------|-------------------------------------------------------------------------|------|------|-------|------|
| t <sub>DLRCK</sub> | i2s2_lrck_rx/i2s2_lrck_tx propagation delay from i2s1_sclk falling edge | 1.02 | 1.35 | 1.68  | ns   |
| t <sub>DSDO</sub>  | i2s2_sdo propagation delay from i2s2_sclk falling edge                  | 0.97 | 1.26 | 1.57  | ns   |
| t <sub>SUSDI</sub> | i2s2_sdi setup time to i2s2_sclk rising edge                            | 5.01 | 7.37 | 10.48 | ns   |

x=2

### 29.5.2 Slave mode



Fig. 29-12Slave mode timing diagram Table 29-2Meaning of the parameter in Fig. 29-12

| Parameter           | Description                                                    | min  | typ  | max  | unit |
|---------------------|----------------------------------------------------------------|------|------|------|------|
| t <sub>CSCLK</sub>  | i2s1_sclk cycle time (cannot be less than 40ns)                | -    | -    | -    | ns   |
| t <sub>HSCLK</sub>  | i2s1_sclk pulse width high (cannot be less than 20ns)          | -    | -    | -    | ns   |
| t <sub>LSCLK</sub>  | i2s1_sclk pulse width low (cannot be less than 20ns)           | -    | -    | -    | ns   |
| t <sub>SULRCK</sub> | i2s1_lrck_rx/i2s1_lrck_tx setup time to i2s1_sclk falling edge | 0.86 | 1.18 | 1.15 | ns   |
| t <sub>DSDO</sub>   | i2s1_sdo propagation delay from i2s1_sclk falling edge         | 4.97 | 7.24 | 9.91 | ns   |
| t <sub>SUSDI</sub>  | i2s1_sdi setup time to i2s1_sclk rising edge                   | 0.69 | 0.73 | 0.67 | ns   |

unit Parameter Description min max typ



| t <sub>CSCLK</sub>  | i2s2_sclk cycle time (cannot be less than 40ns)                | -    | -    | -    | ns |
|---------------------|----------------------------------------------------------------|------|------|------|----|
| t <sub>HSCLK</sub>  | i2s2_sclk pulse width high (cannot be less than 20ns)          | 1    | 1    | 1    | ns |
| t <sub>LSCLK</sub>  | i2s2_sclk pulse width low (cannot be less than 20ns)           | -    | -    | -    | ns |
| t <sub>SULRCK</sub> | i2s2_lrck_rx/i2s2_lrck_tx setup time to i2s2_sclk falling edge | 0.84 | 1.14 | 1.11 | ns |
| t <sub>DSDO</sub>   | i2s2_sdo propagation delay from i2s2_sclk falling edge         | 4.55 | 6.57 | 9.00 | ns |
| t <sub>SUSDI</sub>  | i2s2_sdi setup time to i2s2_sclk rising edge                   | 0.72 | 0.98 | 0.84 | ns |

x=2

## 29.6 Interface description

| <b>Module Pin</b> | Direction | Pad Name   | IOMUX Setting             |  |  |
|-------------------|-----------|------------|---------------------------|--|--|
| I2S1              |           |            |                           |  |  |
| i2s1_clk          | 0         | GPIO0_C[0] | GRF_GPIO0C_IOMUX[ 0]=1'b1 |  |  |
| i2s1_sclk         | I/O       | GPIO0_C[1] | GRF_GPIO0C_IOMUX[ 2]=1'b1 |  |  |
| i2s1_lrck_rx      | I/O       | GPIO0_C[2] | GRF_GPIO0C_IOMUX[ 4]=1'b1 |  |  |
| i2s1_lrck_tx      | I/O       | GPIO0_C[3] | GRF_GPIO0C_IOMUX[ 6]=1'b1 |  |  |
| i2s1_sdi          | I         | GPIO0_C[4] | GRF_GPIO0C_IOMUX[ 8]=1'b1 |  |  |
| i2s1_sdo          | 0         | GPIO0_C[5] | GRF_GPIO0C_IOMUX[10]=1'b1 |  |  |
| I2S2              |           |            |                           |  |  |
| i2s2_clk          | 0         | GPIO0_D[0] | GRF_GPIO0D_IOMUX[ 0]=1'b1 |  |  |
| i2s2_sclk         | I/O       | GPIO0_D[1] | GRF_GPIO0D_IOMUX[ 2]=1'b1 |  |  |
| i2s2_lrck_rx      | I/O       | GPIO0_D[2] | GRF_GPIO0D_IOMUX[ 4]=1'b1 |  |  |
| i2s2_lrck_tx      | I/O       | GPIO0_D[3] | GRF_GPIO0D_IOMUX[ 6]=1'b1 |  |  |
| i2s2_sdi          | I         | GPIO0_D[4] | GRF_GPIO0D_IOMUX[ 8]=1'b1 |  |  |
| i2s2_sdo          | 0         | GPIO0_D[5] | GRF_GPIO0D_IOMUX[10]=1'b1 |  |  |

# 29.7 Application Notes



Fig. 29-13I2S/PCM1/2 controller transmit operation flow chart





Fig. 29-14I2S/PCM1/2 controller receive operation flow chart

# **Chapter 30 SPDIF transmitter**

### 30.1 Overview

The SPDIF transmitter is a self-clocking, serial, un-directional 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.

- Support one internal 32-bit wide and 32-location deep sample data buffer
- Support two 16-bit audio data store together in one 32-bit wide location
- Support AHB bus interface
- Support biphase format stereo audio data output
- Support DMA handshake interface and configurable DMA water level
- Support sample data buffer empty and block terminate interrupt
- Support combine interrupt output
- Support 16 to 31 bit audio data left or right justified in 32-bit wide sample data buffer
- Support 48, 44.1, 32kHz sample rate
- Support 16, 20, 24 bits audio data transfer

# 30.2 Block Diagram



Fig. 30-1SPDIF transmitter Block Diagram



#### **System Interface**

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

#### **Clock Divider**

The Clock Divider implements clock generation function. The input source clock to the module is MCLK, and by the divider of the module, the clock divider generates work clock for digital audio data transformation.

#### **Parallel Audio Buffer**

The Parallel Audio Buffer is the buffer to store transmitted audio data. The size of the FIFO is 32bits x 32.

#### **Serial Audio Converter**

The Serial Audio Converter reads parallel audio data from the Parallel Audio Buffer and converts it to serial audio data.

## **Biphase Audio Generator**

The Biphase Audio Generatorreads serial audio data from the Serial Audio Converter and generates biphase audio data based on IEC-60958 standard.

# 30.3 Function description

#### 30.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. 30-2SPDIF 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).



#### 30.3.2 Sub-frame Format



Fig. 30-3SPDIF Sub-frame Format

Each sub-frame is divided into 32 time slot, numbered from 0 to 31. Time slot 0 to 3 carries one of the three permitted preambles. Time slots 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. 30.3.3 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'

30.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. 30-5SPDIF 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.

# 30.4 Register description

## 30.4.1 Register Summary

| Name        | Offset | Size | Reset<br>value | Description                     |
|-------------|--------|------|----------------|---------------------------------|
| SPDIF_CFGR  | 0x00   | W    | 0x0            | Transfer Configuration Register |
| SPDIF_SDBLR | 0x04   | W    | 0x0            | Sample Date Buffer Level        |
|             | ,      |      |                | Register                        |
| SPDIF_DMACR | 0x08   | W    | 0x0            | DMA Control Register            |
| SPDIF_INTCR | 0x0C   | W    | 0x0            | Interrupt Control Register      |
| SPDIF_INTSR | 0x10   | W    | 0x0            | Interrupt Status Register       |
| SPDIF_XFER  | 0x18   | W    | 0x0            | Transfer Start Register         |
| SPDIF_SMPDR | 0x20   | W    | 0x0            | Sample Data Register            |
| SPDIF_VLDFR | 0x60~  | W    | 0x0            | Validity Flag Register          |
|             | 0x8C   |      |                |                                 |
| SPDIF_USRDR | 0x90~  | W    | 0x0            | User Data Register              |
|             | 0xBC   |      |                |                                 |
| SPDIF_CHNSR | 0xC0~  | W    | 0x0            | Channel Status Register         |
|             | 0xEC   |      |                |                                 |

Notes:

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



## 30.4.2 Detail Register Description

## SPDIF\_CFGR

Address: operational base+offset(0x00)

Transfer Configuration Register

| Bit   | Attr | <b>Reset Value</b> | Description                                     |  |
|-------|------|--------------------|-------------------------------------------------|--|
| 31:24 | -    | ı                  | Reserved.                                       |  |
| 23:16 | RW   | 0x0                | Fmclk/Fsdo                                      |  |
|       |      |                    | This parameter can be caculated by              |  |
|       |      |                    | Fmclk/(Fs*128).                                 |  |
|       |      |                    | Fs=the sample frequency be wanted               |  |
| 15:8  | -    | -                  | Reserved.                                       |  |
| 7     | W    | 0x0                | Write 1 to clear mclk domain logic. Read return |  |
|       |      |                    | zero.                                           |  |
| 6     | RW   | 0x0                | Channel status enable                           |  |
| 5     | RW   | 0x0                | User data enable                                |  |
| 4     | RW   | 0x0                | Validity flag enable                            |  |
| 3     | RW   | 0x0                | Apb valid audio data justified                  |  |
|       |      |                    | 0:Right justified                               |  |
|       |      |                    | 1:Left justified                                |  |
| 2     | RW   | 0x0                | Halfword word transform enable                  |  |
|       |      |                    | 0:disable                                       |  |
|       |      |                    | 1:enable                                        |  |
| 1:0   | RW   | 0x0                | Valid data width                                |  |
|       |      |                    | 00: 16bit                                       |  |
|       |      |                    | 01: 20bit                                       |  |
|       |      |                    | 10: 24bit                                       |  |
|       |      |                    | 11: reserved                                    |  |

## SPDIF\_SDBLR

Address:operational base+offset(0x04)

Sample Date Buffer Level Register

| Bit  | Attr | Reset Value | Description                                                                                             |
|------|------|-------------|---------------------------------------------------------------------------------------------------------|
| 31:6 | -    | -           | Reserved.                                                                                               |
| 5:0  | R    | 0x0         | Sample Date Buffer Level Register. Contains the number of valid data entries in the sample data buffer. |

## SPDIF\_DMACR

Address:operational base+offset(0x08)

DMA Control Register

| Bit  | Attr | Reset Value | Description                                         |  |
|------|------|-------------|-----------------------------------------------------|--|
| 31:6 | -    | -           | Reserved.                                           |  |
| 5    | RW   | 0x0         | Transmit DMA Enable.                                |  |
|      |      |             | 0 = Transmit DMA disabled                           |  |
|      |      |             | 1 = Transmit DMA enabled                            |  |
| 4:0  | RW   | 0x0         | Transmit Data Level. 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 Sample      |  |
|      |      |             | Date Buffer is equal to or below this field value   |  |

# SPDIF\_INTCR



Address:operational base+offset(0x0C)

Interrupt Control Register

| Bit    | Attr | Reset Value | Description                                |  |
|--------|------|-------------|--------------------------------------------|--|
| 31: 17 | -    | -           | Reserved.                                  |  |
| 16     | W    | 0x0         | Block transfer terminate interrupt clear   |  |
| 15: 10 | -    | -           | Reserved.                                  |  |
| 9:5    | RW   | 0x0         | Sample Date Buffer Threshold for empty     |  |
|        |      |             | interrupt                                  |  |
| 4      | RW   | 0x0         | Sample Date Buffer empty interrupt enable. |  |
|        |      |             | 0:disable; 1: enable;                      |  |
| 3      | RW   | 0x0         | Block transfer terminate interrupt enable. |  |
|        |      |             | 0:disable; 1: enable;                      |  |
| 2:0    | _    | -           | Reserved.                                  |  |

### SPDIF\_INTSR

Address:operational base+offset(0x10)

Interrupt Status Register

| Bit   | Attr | Reset Value | Description                                |  |
|-------|------|-------------|--------------------------------------------|--|
| 31: 5 | -    | -           | Reserved.                                  |  |
| 4     | R    | 0x0         | Sample Date Buffer empty interrupt status. |  |
|       |      |             | 0:inactive; 1: active;                     |  |
| 3     | R    | 0x0         | Block transfer terminate interrupt status. |  |
|       |      |             | 0:inactive; 1: active;                     |  |
| 2:0   | -    | -           | Reserved.                                  |  |

### SPDIF\_XFER

Address:operational base+offset(0x18)

Transfer Start Register

| Bit   | Attr | Reset Value | Description              |
|-------|------|-------------|--------------------------|
| 31: 1 | -    | -           | Reserved.                |
| 0     | RW   | 0x0         | Transfer Start Register. |

#### SPDIF\_SMPDR

Address:operational base+offset(0x20)

Sample Data Register

| Bit  | Attr | Reset Value | Description           |
|------|------|-------------|-----------------------|
| 31:0 | W    | 0x0         | Sample Data Register. |

## SPDIF\_VLDFR

Address:operational base+offset(0x60~0x8C)

Validity Flag Register

| Bit  | Attr | Reset Value | Description             |  |
|------|------|-------------|-------------------------|--|
| 31:0 | RW   | 0x0         | Validity Flag Register. |  |

## SPDIF\_USRDR

Address:operational base+offset(0x90~0xBC)

User Data Register

| Bit  | Attr | Reset Value | Description         |  |
|------|------|-------------|---------------------|--|
| 31:0 | RW   | 0x0         | User Data Register. |  |

### SPDIF\_CHNSR

Address:operational base+offset(0xC0~0xEC)

Channel Status Register.



# 30.5 Interface description

| <b>Module Pin</b> | Direction | Pad Name   | IOMUX Setting         |  |
|-------------------|-----------|------------|-----------------------|--|
| spdif_tx          | 0         | GPIO1_B[2] | GRF_GPIO1B_IOMUX[4]=1 |  |

# **30.6 Application Notes**



Fig. 30-6 SPDIF transmitter operation flow chart

# **Chapter 31 SDIO Host Controller**

## 31.1 Overview

The SDMMC Host Controller is designed to support Secure Digital memory (SD mem - version 3.00), Secure Digital I/O(SDIO-version 3.00), Multimedia Cards(MMC-version 4.41). The SDMMC support SD Card(1/4bit), SDIO, MMC(1/4bit).

#### **Feature**

- Supports AMBA AHB interface
- Supports DMA controller for data transfers
- Supports interrupt output
- Supports SD version3.0 except SPI mode
- Supports MMC version4.41 except SPI mode
- Supports SDIO version3.0
- Supports programmable baud rate.
- Provides individual clock control to selectively turn ON or OFF clock to a card
- Supports power management and power switch. Provides individual power control to selectively turn ON or OFF power to a card
- Support DDR in 4-bit mode

# 31.2 Block Diagram

The SD/MMC controller consists of the following main functional blocks, which are illustrated in Fig. 17-1.



Fig. 31-1SD/MMC Controller Block Diagram

- Bus Interface Unit (BIU) Provides AMBA AHB and DMA interfaces for register and dataread/writes.
- Card Interface Unit (CIU) Takes care of the SD\_MMC protocols and provides clockmanagement.

# 31.3 Function description

Ref 17.3

# 31.4 Register description

Ref 17.4

# 31.5 Timing Diagram

# 31.6 Interface description

#### 31.6.1 Card-Detect and Write-Protect Mechanism

Figure 17-6 illustrates how the SD/MMC Host Controller card detection and write-protect signals are connected. Most of the SD\_MMC sockets have card-detect pins. When no card is present, card\_detect\_n is 1 due to the pull-up. When the SD\_MMC card is inserted, the card-detect pin is shorted to ground, which makes card\_detect\_n go to 0. Similarly in SD cards, when the write-protect switch is toward the left, it shorts the write\_protect port to ground.



Fig. 31-2 Card-Detect and Write-Protect

### 31.6.2 SD/MMC Controller Termination Requirement

Fig.17-7 illustrates the SD/MMC Host Controller termination requirements, which is required to pull up ccmd and cdata lines on the SD\_MMC bus. The recommended specification for pull-up on the ccmd line (Rcmd) is 4.7 K - 100 K for MMC, and 10 K - 100 K for an SD. The recommended pull-up on the cdata line (Rdat) is 50 K - 100 K.





Fig. 31-3 SD/MMC Termination

#### **Rcmd and Rod Calculation**

The SD and MMC card enumeration happens at a very low frequency – 100-400KHz. Since the MMC bus is a shared bus between multiple cards, during enumeration open-drive mode is used to avoid bus conflict. Cards that drive 0 win over cards that drive "z." The pull-up in the command line pulls the bus to 1 when all cards drive "z." MMC interrupt mode also uses the pull-up. During normal data transfer, the hose chooses only one card and the card driver switches to push-pull mode.

For example, if enumeration is done at 400KHz and the total bus capacitance is 200 pf, the pull-up needed during enumeration is:

```
2.2 \text{ RC} = \text{rise-time} = 1/400 \text{KHz}
R = 1/(2.2 * C * 100KHz)
  = 1/(2.2 \times 200 \times 10^{**}-12 \times 400 \times 10^{**}3)
  = 1/(17.6 \times 10**-5)
  = 5.68K
```

The Rod and Rcmd should be adjusted in such a way that the effective pull-up is at the maximum 5.68K during enumeration. If there are only a few cards in the bus, a fixed Rcmd resister is sufficient and there is no need for an additional Rod pull-up during enumeration. You should also ensure the effective pull-up will not violate the Iol rating of the drivers.

In SD mode, since each card has a separate bus, the capacitance is less, typically in the order of 20-30pf (host capacitance + card capacitance + trace + socket capacitance). For example, if enumeration is done at 400KHz and the total bus capacitance is 20pf, the pull-up needed during enumeration is:

```
2.2 \text{ RC} = \text{rise-time} = 1/400 \text{KHz}
R = 1/(2.2 * C * 100KHz)
  = 1/(2.2 \times 20 \times 10^{**}-12 \times 400 \times 10^{**}3)
  = 1/(1.76 \times 10^{**}-5)
  = 56.8K
```

Therefore, a fixed 56.8K permanent Rcmd is sufficient in SD mode to enumerate the cards.

The driver of the SD/MMC Host Controller on the "command" port needs to be only a push-pull driver. During enumeration, the SD/MMC Host Controller emulates an open-drain driver by driving only a 0 or a "z" by controlling the ccmd out and ccmd out en signals.



### 31.6.3 SD/MMC Controller IOMUX

The SDMMC Host Controller share the pin with GPIO. In default, the pins are used for GPIO, if user want to work in sdmmc function, the user must configure the GRF registers as following table:

Table 31-1 SDMMC IOMUX Settings

| Module Pin     | Direction                             | Pad Name        | IOMUX Setting         |
|----------------|---------------------------------------|-----------------|-----------------------|
| sdio_clkout    | 0                                     | GPIO3_C[5]      | GPIO3C_IOMUX[10]=0x1& |
|                |                                       |                 | GPIO3C_IOMUX[26]=0x1  |
| sdio_cmd       | I/O                                   | GPIO3_C[0]      | GPIO3C_IOMUX[0]=0x1&  |
|                |                                       |                 | GPIO3C_IOMUX[16]=0x1  |
| sdio_data0     | I/O                                   | GPIO3_C[1]      | GPIO3C_IOMUX[2]=0x1&  |
|                |                                       |                 | GPIO3C_IOMUX[18]=0x1  |
| sdio_data1     | I/O                                   | GPIO3_C[2]      | GPIO3C_IOMUX[4]=0x1&  |
|                |                                       |                 | GPIO3C_IOMUX[20]=0x1  |
| sdio_data2     | I/O                                   | GPIO3_C[3]      | GPIO3C_IOMUX[6]=0x1&  |
|                |                                       |                 | GPIO3C_IOMUX[22]=0x1  |
| sdio_data3     | I/O                                   | GPIO3_C[4]      | GPIO3C_IOMUX[8]=0x1&  |
|                |                                       |                 | GPIO3C_IOMUX[24]=0x1  |
| sdio_int_n     | I                                     | GPIO3_D[2]      | GPIO3D_IOMUX[4]=0x1&  |
|                |                                       | $C \rightarrow$ | GPIO3D_IOMUX[20]=0x1  |
| sdio_detect_n  | I                                     | GPIO3_C[6]      | GPIO3C_IOMUX[12]=0x1& |
|                |                                       |                 | GPIO3C_IOMUX[28]=0x1  |
| sdio_write_prt | I                                     | GPIO3_C[7]      | GPIO3C_IOMUX[14]=0x1& |
|                |                                       |                 | GPIO3C_IOMUX[30]=0x1  |
| sdio_backend   | 0                                     | GPIO3_D[1]      | GPIO3D_IOMUX[2]=0x1&  |
|                |                                       |                 | GPIO3D_IOMUX[18]=0x1  |
| sdio_pwr_en    | 0                                     | GPIO3_D[0]      | GPIO3D_IOMUX[0]=0x1&  |
| <b>A</b>       | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ |                 | GPIO3D_IOMUX[16]=0x1  |

Notes: Direction: I- Input, O- Output, I/O- Input/Output

# **31.7 Application Notes**

Ref to 17.7

# **Chapter 32 MAC Ethernet Interface**

## 32.1 Overview

The VMAC Ethernet Controller providers a complete Ethernet interface from processor to a Reduced Media Independent Interface(RMII) compliant Ethernet PHY.

The VMAC includes a DMAC controller. The DMAC controller efficiently moves packet data from microprocessor's RAM, format the data for an IEEE 802.3 compliant packet and transmit the data to an Ethernet Physical Interface (PHY). It also efficiently moves packet data from RXFIFO to microprocessor's RAM.

#### 32.1.1 Features

- IEEE 802.3u compliant Ethernet Media Access Controller
- 10Mbps and 100Mbps compatible
- Automatic retry and automatic collision frame deletion
- Reduced Media Independent Interface (RMII) for PHY connection
- Mangement Interface (MDIO) state machine for easy real-time communication with the PHY.
- Full Duplex Support
- Pause full-duplex flow-control support
- Address filtering –Broadcast/Multicast/Logic/Physical
- Complete DMA buffer management controller for minimal processor overhead
- Wake-On-LAN low-power mode support
- AHB interface to any CPU or memory

# 32.2 Block Diagram

#### 32.2.1 Architecture



Fig. 32-1 VMAC architecture

The VMAC is broken up into nine separate functional units. These nine blocks are interconnected in the VMAC module. The block diagram shows the general flow of data and control signals between these blocks.

The DMA\_CTLR controller moves data between system memory and the respective TX or RX pipelines and manges the buffer descriptors. A single state machine handles the Buffer Descriptors as well as both the RX and TX DMAs. Transmit and Receive DMAs may be interleaved as well as polling of the buffer descriptor rings. The DMA controller also includes all of the configuration, control and status registers of the VMAC as well as the MDIO state machine for communicating to the PHY.



The transmit FIFO and its controller are integrated in the TX FIFO block. The FIFO is typically built of a 512x8bit dual-port RAM.

The TX MAC provides all of the logic necessary to build and transmit a frame that meets the IEEE 802.3 Ethernet LAN standard. When a start of frame is detected on the data/status bus, then the TX MAC block starts to transmit preamble data. TX MAC delays the transmission if the receive path is active in Half-Duplex mode and ensures that the interframe period is met. In Full-Duplex mode only the interframe period is observed and no deferring process takes place.

The TX RATE block transfers the raw packet data from the HCLK to the CLK TX clock domains. In addition to its main function, the TX RATE block monitors the collision signal COL from the PHY and the preamble field from TX\_RATE.In case of a collision, the TX\_RATE jams the data on TXD bus and notifies TX\_MAC about the collision.

The RX\_FIFO block is composed with a 1024x9 bit dual-port ram. (

The RX\_ADDRFLT block determines if the destination address matches under any of the currently-active addressing modes. While the Destination Address fileld is being verified, the incoming bytes are stored in a small FIFO. If the Destination address does not match, then the RX\_ADDRFLT resets its FIFO and disregards incoming data.

The RX\_MAC block provides all of the logic necessary to meet the IEEE 802.3 Ethernet LAN standard for frame reception. The RX MAC detects the SFD pattern, verifies FCS field, senses framing errors (odd number of nibbles) and monitors the RX\_ER signal, which indicates any other errors received from an external PHY.

The RX RATE block synchronizes signals from MII CLK RX domain to hclk domain.

The MII2RMII block transfers MII signals to RMII signals.

#### 32.2.2 Frame Structure

Data frames transmitted shall have the frame format shown in Fig 32-2.

# <inter-frame>preamble><sfd><data><efd>

Fig. 32-2 VMAC Frame structure

preamble field consist of 7 octets with the folling 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 octets data.

#### 32.2.3 RMII Interface timing diagram

#### 1.Transmission diagram

Fig. 32-3 shows the 100Mb/s Transmission diagram. The REF CLK frequency is 50MHz in RMII interface.



Fig. 32-3RMII transmission in 100Mb/s mode

In 10Mb/s mode, as the REF\_CLK frequency is 10 times as the data rate, the value on 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 gRup and yield the correct frame data.

#### 2. Receiption diagram

Fig.32-4shows the 100Mb/s reception diagram. The REF\_CLK frequency is 50MHz in RMII interface.



Fig. 32-4 RMII reception with no errors in 100Mb/s mode

In 10Mb/s mode, as the REF\_CLK frequency is 10 times the data rate, the value on RXD[1:0] shall be valid such that RXD[1:0] may be sampled every 10th cycle, regardless of the starting cycle within the gRup and yield the correct frame data.

#### 32.2.4 Mangement Interface

The MII management interface provides a simple,tW-wire, serial interface to connect the VMAC and a manged PHY, for the purposes of controlling the PHY and gathering status from the PHY. The management interface consists of a pair of signals that transport the management information acRss the MII bus: MDIO and MDC.

# 32.3 Register description

### 32.3.1 Register Summary

| Name         | Offset | Size | Reset<br>Value | Description               |
|--------------|--------|------|----------------|---------------------------|
| EMAC_ID      | 0x0000 | W    | 0x00053d02     | hardware version          |
| EMAC_STAT    | 0x0004 | W    | 0x0000000      | Interrupt status register |
| EMAC_ENABLE  | 0x0008 | W    | 0x00000000     | Interrupt enable register |
| EMAC_CONTROL | 0x000c | W    | 0x0000000      | CONTROL Register          |



| Name                | Offset | Size | Reset<br>Value | Description                              |
|---------------------|--------|------|----------------|------------------------------------------|
| EMAC_POLLRATE       | 0x0010 | W    | 0x0000000      | Poll Rate register                       |
| EMAC_RXERR          | 0x0014 | W    | 0x0000000      | Receive Error Counters                   |
| EMAC_MISS           | 0x0018 | W    | 0x0000000      | Missed Packet Counter                    |
| EMAC_TXRINGPTR      | 0x001c | W    | 0x00000000     | Transmit Ring Pointer address register   |
| EMAC_RXRINGPTR      | 0x0020 | W    | 0x00000000     | Receive Ring Pointer address register    |
| EMAC_ADDRL          | 0x0024 | W    | 0x00000000     | Ethernet MAC Address ,<br>low 32 bits    |
| EMAC_ADDRH          | 0x0028 | W    | 0x00000000     | Ethernet MAC Address,<br>high 16 bits    |
| EMAC_LAFL           | 0x002c | W    | 0x00000000     | Logical Address filter<br>Register Low   |
| EMAC_LAFH           | 0x0030 | W    | 0x00000000     | Logical Address filter<br>Register High  |
| EMAC_MDIO_DATA      | 0x0034 | W    | 0x00000000     | MDIO access register                     |
| EMAC_TXRINGPTR_READ | 0x0038 | W    | 0x00000000     | Transmit Ring Pointer read-back register |
| EMAC_RXRINGPTR_READ | 0x003c | W    | 0×00000000     | Receive Ring Pointer read-back register  |

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

## 32.3.2 Detail Register Description

## EMAC\_ID

Address: Operational Base + offset (0x0000)

hardware version

| Bit   | Attr | Reset Value | Description                              |
|-------|------|-------------|------------------------------------------|
| 31:24 | RO   | 0x0         | reserved                                 |
|       |      | Y           | Revision                                 |
| 23:16 | RO   | 0x05        | Revision number                          |
|       |      |             | Revision number (currently Rev 5)        |
| 15:14 | RO   | 0x0         | reserved                                 |
|       |      |             | NOTID                                    |
| 13:8  | RO   | 0x3d        | Ones-Complement of the ID                |
|       |      |             | Ones-Complement of the ID, (111101b)     |
| 7:6   | RO   | 0x0         | reserved                                 |
|       |      |             | ID                                       |
| 5:0   | RO   | 0x02        | Identification number                    |
|       |      |             | Identification number, always 2 for VMAC |

# **EMAC\_STAT**



Address: Operational Base + offset (0x0004)

Interrupt status register

| Bit         | t status<br>Attr | Reset Value | Description                                         |
|-------------|------------------|-------------|-----------------------------------------------------|
|             |                  |             | TXPL                                                |
|             |                  |             | TXPOLL                                              |
|             |                  |             | Writing a one forces a poll of the transmit         |
| 31          | RW               | 0x0         | descriptors. Always write this bit with a one       |
|             |                  |             | after adding a packet to the transmit BDT.          |
|             |                  |             | Always read as zero.                                |
| 30:13       | RO               | 0x0         | reserved                                            |
|             |                  |             | MDIO                                                |
| 12          | RW               | 0x0         | MDIO Complete                                       |
|             |                  |             | The register access to the PHY has completed        |
| 11          | RO               | 0x0         | reserved                                            |
|             |                  |             | RXFL                                                |
| 10          | RW               | 0x0         | RX OVER FLOW                                        |
|             |                  |             | The RXOFLOWERR counter has rolled over              |
|             |                  |             | RXFR                                                |
| 9           | RW               | 0x0         | RXFRAME                                             |
|             |                  |             | The RXFRAMEERR counter has rolled over              |
|             |                  |             | RXCR                                                |
| 8           | RW               | 0x0         | RXCRC                                               |
|             |                  |             | The RXCRCERR counter has rolled over                |
| 7:5         | RO               | 0x0         | reserved                                            |
|             |                  |             | MSER                                                |
| 4           | RW               | 0x0         | MISSERR                                             |
|             |                  |             | Missed packet counter has rolled over               |
|             |                  | V X         | TXCH                                                |
|             |                  |             | TX Chaining Error                                   |
| 3           | RW               | 0×0         | A bad conbination of FIRST and LAST bits has        |
| 3           | KVV              | UXU         | been encountedred. The VMAC asserts this            |
|             |                  |             | error bit and disables the TXRN bit in the          |
|             |                  |             | CONTROL register.                                   |
|             | ,                |             | ERR                                                 |
| <b>&gt;</b> |                  |             | Error interrupt pending                             |
| 2           | RO               | 0×0         | Error interrupt pending . is the logical OR of all  |
| _           |                  |             | of the other error bits in the status register (all |
|             |                  |             | interrupts except TXINT , RXINT and MDIO ).         |
|             |                  |             | This is a read-only bit                             |



| Bit | Attr | Reset Value | Description                                        |
|-----|------|-------------|----------------------------------------------------|
|     |      |             | RXINT                                              |
|     |      |             | Receive Interrupt Pending                          |
|     |      |             | RXINT is set when the VMAC clears the OWN          |
|     |      |             | bit of an RX BDT and LAST=1. Note that             |
|     |      |             | multiple RX BDTs could be cleared before the       |
| 1   | RW   | 0x0         | RXINT interrupt is serviced. Thus ALL RX BDTs      |
|     |      |             | must be processed within the interrupt. This       |
|     |      |             | also results in the possibility that there will be |
|     |      |             | a RXINT without any corresponding BDTs with        |
|     |      |             | their OWN bits cleared. This is normal and the     |
|     |      |             | software driver must handle this case.             |
|     |      |             | TXINT                                              |
|     |      |             | Transmit Interrupt Pending                         |
|     |      |             | TXINT is set when the OWN bit of a TX BDT is       |
|     |      |             | cleared to 0 by the VMAC and LAST=1. Note          |
|     |      | 0×0         | that multiple TX BDTs could be cleared before      |
| 0   | RW   |             | the TXINT interrupt is erviced. Tus ALL TX         |
|     |      |             | BDTs must be processed within the interrupt.       |
|     |      |             | This also results in the possibility that there    |
|     |      |             | will be a TXINT without any corresponding          |
|     |      |             | BDTs with their OWN bits cleared. This is          |
|     |      |             | normal and the software driver must handle         |
|     |      |             | this case.                                         |

# **EMAC\_ENABLE**

Address: Operational Base + offset (0x0008)

Interrupt enable register

| Bit   | Attr      | Reset Value | Description                                 |
|-------|-----------|-------------|---------------------------------------------|
|       | <b>\1</b> |             | TXPL                                        |
| 31    | RW        | 0x0         | TXPOLL                                      |
| 4     |           |             | TXPOLL                                      |
| 30:13 | RO        | 0x0         | reserved                                    |
|       | ~         |             | MDIO                                        |
| 12    | RW        | 0x0         | MDIO Complete enable                        |
|       |           |             | MDIO Complete enable                        |
| 11    | RO        | 0x0         | reserved                                    |
|       |           |             | RXFL                                        |
| 10    | RW        | 0x0         | RXOFLOWERR counter rolled over error enable |
|       |           |             | Field0000 Description                       |
|       |           |             | RXFR                                        |
| 9     | RW        | 0x0         | RXFRAMEERR counter rolled over error enable |
|       |           |             | RXFRAMEERR counter rolled over error enable |



| Bit | Attr | Reset Value | Description                                 |
|-----|------|-------------|---------------------------------------------|
|     |      |             | RXCR                                        |
| 8   | RW   | 0x0         | RXFRAMEERR counter rolled over error enable |
|     |      |             | RXFRAMEERR counter rolled over error enable |
| 7:5 | RO   | 0x0         | reserved                                    |
|     |      |             | MSER                                        |
| 4   | RW   | 0x0         | Missed packet counter error enable          |
|     |      |             | Missed packet counter error enable          |
|     |      |             | TXCH                                        |
| 3   | RW   | 0x0         | TX Chaining Error enable                    |
|     |      |             | TX Chaining Error enable                    |
|     |      |             | ERR                                         |
| 2   | RW   | 0x0         | Error Interrupt Pending Enable              |
|     |      |             | Error Interrupt Pending Enable              |
|     |      |             | RXINT                                       |
| 1   | RW   | 0x0         | Receive interrupt pending enable            |
|     |      |             | Receive interrupt pending enable            |
|     |      |             | TXINT                                       |
| 0   | RW   | 0x0         | Transmit interrupt pending enable           |
|     |      |             | Transmit interrupt pending enable           |

# EMAC\_CONTROL

Address: Operational Base + offset (0x000c)

**CONTROL** Register

| Bit   | Attr     | Reset Value | Description                                  |
|-------|----------|-------------|----------------------------------------------|
|       |          | •. 0        | RXBDTLEN                                     |
| 31:24 | RW       | 0×00        | RXBDTLEN                                     |
| 31.24 | KVV      | UXUU        | Number of BDTs in the RX Ring. 1-255         |
|       |          |             | allowed.                                     |
|       |          |             | TXBDTLEN                                     |
| 23:16 | RW       | 0×00        | TXBDTLEN                                     |
| 23.10 | KW       | .vv UXUU    | Number of BDTs in the TX Ring. 1-255         |
|       |          |             | allowed.                                     |
|       | <b>Y</b> |             | DISAD                                        |
| ,     |          |             | DISADDCRC                                    |
|       |          |             | 1: disable adding the 4byte CRC(FCS) on      |
|       |          | 0x0         | every packet. Instead, use the ADDCRC bit in |
| 15    | RW       |             | the INFO word of the Transmit Buffer         |
|       |          |             | descriptor to add the FCS on a packet by     |
|       |          |             | packet basis.                                |
|       |          |             | 0: always add CRC and ignore the ADDCRC bit  |
|       |          |             | in the info field                            |



| Bit | Attr   | Reset Value | Description                                    |
|-----|--------|-------------|------------------------------------------------|
|     |        |             | DISRT                                          |
| 14  | RW     | 0×0         | DISRETRY                                       |
| 14  | KVV    | UXU         | 1: disable retries, tx will be attempted only  |
|     |        |             | once.                                          |
|     |        |             | TEST                                           |
| 13  | RW     | 0x0         | TEST                                           |
|     |        |             | used for silicon testing -always set to zero   |
|     |        |             | DIS2P                                          |
|     |        |             | DISABLE2PART                                   |
| 12  | RW     | 0×0         | 1: Disable two part deferral. Disabling 2-part |
| 12  | IXVV   | 0.00        | deferral disables a fast Inter-packet Gap time |
|     |        |             | as described in the 802.3 specification. See   |
|     |        |             | ANSI/IEEE Std802.3-1993 Edition , 4.2.3.2.1    |
|     |        |             | PROM                                           |
| 11  | RW     | 0×0         | PROM                                           |
|     |        | OXO         | 0: normal mode                                 |
|     |        |             | 1: promiscuous mode = accepts all packets.     |
|     |        |             | ENFL                                           |
|     |        |             | ENBFULL                                        |
|     |        |             | 1: enable full duplex mode. This bit needs to  |
| 10  | RW     | 0x0         | be set to the corresponding duplex mode of     |
|     |        |             | the PHY chip the VMAC is connected to. The     |
|     |        |             | duplex mode of the PHY needs to be polled      |
|     |        |             | periodically to keep the VMAC duplex setting   |
| _   |        |             | in line with the PHY.                          |
| 9   | RO     | 0x0         | reserved                                       |
|     |        |             | DISBC                                          |
| 8   | RW     | 0x0         | DISBDCST                                       |
|     |        |             | 1: disable receive broadcast packets.          |
| 7:5 | RO     | 0x0         | reserved                                       |
|     |        |             | RXRN                                           |
| 101 | $\cup$ |             | RXRUN                                          |
|     |        |             | 0: disable receive operation. If a packet is   |
| 4   | RW     | 0x0         | currently being received, it will complete     |
|     |        |             | before the receive operation is disabled. Like |
|     |        |             | TXRN, RXRN can be used to safely disable       |
|     |        |             | packet reception.                              |



| Bit | Attr | Reset Value | Description                                      |
|-----|------|-------------|--------------------------------------------------|
|     |      |             | TXRN                                             |
|     |      |             | TXRUN                                            |
|     |      |             | 0: disable transmit operation. This bit is only  |
|     |      |             | tested when the TXBDT state machine              |
|     |      |             | completes the current transmit operation and     |
| 3   | RW   | 0x0         | just before it checks the next BDT for new       |
|     |      |             | packet. This bit can be used to safely stop      |
|     |      |             | transmitting packets without affecting packet    |
|     |      |             | reception. A TX packet that is already in        |
|     |      |             | process will complete before TXRN is             |
|     |      |             | recongnized.                                     |
| 2:1 | RO   | 0x0         | reserved                                         |
|     |      |             | EN                                               |
|     |      |             | ENABLE                                           |
|     |      |             | 0: stop all activity.                            |
| 0   | RW   | 0x0         | 1: enable ethernet traffic. All registers should |
|     |      |             | be initialized before setting this bit. Clearing |
|     |      |             | this bit to zero resets BDT rings to their first |
|     |      |             | BD in the table.                                 |

## EMAC\_POLLRATE

Address: Operational Base + offset (0x0010)

Poll Rate register

| Bit      | Attr | Reset Value | Description                                     |
|----------|------|-------------|-------------------------------------------------|
| 31:15    | RO   | 0x0         | reserved                                        |
|          |      |             | POLLRATE                                        |
|          |      |             | POLLRATE                                        |
|          |      | ()          | The value programmed into this register is the  |
|          | 11   |             | number of clocks between polls times 1024. A    |
|          |      | ,           | value of 1 will cause a poll every 1024 clocks. |
| 14:0     | RW   | 0x0000      | 2=2048 clocks. 0 is not valid. A CPU clock      |
|          |      |             | frequency of 100MHz would typically want to     |
|          | ·    |             | program the POLLRATE register with a value      |
| <b>Y</b> |      |             | of 100 which will cause a poll to occur about   |
|          |      |             | once every millisecond (10ns * 1024 * 100 =     |
|          |      |             | 1ms)                                            |

# EMAC\_RXERR

Address: Operational Base + offset (0x0014)

**Receive Error Counters** 

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:24 | RO   | 0x0         | reserved    |



| Bit   | Attr | Reset Value | Description                              |
|-------|------|-------------|------------------------------------------|
|       |      |             | RXOFLOW                                  |
| 23:16 | RW   | 0×00        | Overflow Errors                          |
| 23.10 | KVV  | 0000        | Number of receive packets dropped due to |
|       |      |             | FIFO overflows                           |
|       | RW   | 0x00        | RXFRAM                                   |
| 15:8  |      |             | RXFRAME Errors                           |
| 15:6  |      |             | Number of receive packets dropped due to |
|       |      |             | framing errors.                          |
|       |      |             | RXCRC                                    |
| 7:0   | RW   | 0×00        | CRC Errors                               |
|       |      |             | Number of receive packets dropped due to |
|       |      |             | CRC errors.                              |

## **EMAC\_MISS**

Address: Operational Base + offset (0x0018)

Missed Packet Counter

| Bit  | Attr  | Reset Value | Description                                 |
|------|-------|-------------|---------------------------------------------|
| 31:8 | RO    | 0x0         | reserved                                    |
|      |       |             | MISSCNTR                                    |
|      |       | 0x00        | Missed packet counter                       |
| 7:0  | RW    |             | When the counter counts up to the maximum   |
|      |       |             | value, it sets the MISSERR bit in the INTER |
|      | IK VV |             | register. This counter counts the number of |
|      |       |             | packets that were dropped because a BD was  |
|      |       |             | not available. This counter is auto-zeroed  |
|      |       |             | when read.                                  |

## EMAC\_TXRINGPTR

Address: Operational Base + offset (0x001c)

Transmit Ring Pointer address register

| Bit  | Attr | Reset Value | Description                                  |
|------|------|-------------|----------------------------------------------|
|      |      |             | TXRINGPTR                                    |
|      | ~    |             | Address of the start of the Transmit RING of |
| ,    |      |             | Buffer Descriptors                           |
| 31:0 | RW   | 0x00000000  | Address of the start of the Transmit RING of |
|      |      |             | Buffer Descriptors.                          |
|      |      |             | Must be on 8-byte boundaries. (ID: Bits 2-0  |
|      |      |             | must be zero)                                |

## **EMAC\_RXRINGPTR**

Address: Operational Base + offset (0x0020)

Receive Ring Pointer address register



| Bit  | Attr | Reset Value | Description                                 |
|------|------|-------------|---------------------------------------------|
|      |      |             | RXRINGPTR                                   |
|      |      |             | Address of the start of the Receive RING of |
|      |      |             | BDs.                                        |
| 31:0 | RW   | 0x00000000  | Address of the start of the Receive RING of |
|      |      |             | BDs.                                        |
|      |      |             | Must be on 8-byte boundaries (IE: Bits 2-0  |
|      |      |             | must be zero)                               |

## **EMAC\_ADDRL**

Address: Operational Base + offset (0x0024)

Ethernet MAC Address, low 32 bits

| Bit  | Attr | Reset Value | Description                                                |
|------|------|-------------|------------------------------------------------------------|
|      |      |             | ADDRL                                                      |
|      |      |             | Lower 32 bits of the ethernet MAC address                  |
|      |      |             | Lower 32 bits of the ethernet MAC address.                 |
|      |      |             | The address is little-endian. Thus the first               |
|      |      |             | byte transferred on the Ethernet wire must match bits 7:0. |
|      |      |             | The second byte transferred is in bits 15:8                |
|      |      |             | and so on.                                                 |
|      |      |             | Thus for a Physical address transmitted in                 |
|      |      |             | byte order of:                                             |
| 31:0 | RW   | 0x00000000  | 0x00 - 1st byte transmitted                                |
|      |      |             | 0x11 - 2nd byte transmitted                                |
|      |      | • ()        | 0x22 - 3rd byte transmitted                                |
|      |      |             | 0x33 - 4th byte transmitted                                |
|      |      |             | 0x44 - 5th byte transmitted                                |
|      |      |             | 0x55 - 6th byte transmitted                                |
|      | 1    |             | The ADDRL register should be programmed                    |
|      |      |             | with 0x33221100.                                           |
|      |      |             | Bit 0 is the multi-cast / Broadcast bit of the             |
|      |      |             | address.                                                   |
|      |      |             | Bit 0 MUST be programmed with a zero.                      |

## **EMAC\_ADDRH**

Address: Operational Base + offset (0x0028)

Ethernet MAC Address, high 16 bits

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



| Bit  | Attr | Reset Value | Description                                |
|------|------|-------------|--------------------------------------------|
|      | RW   | 0x0000      | ADDRH                                      |
|      |      |             | Upper 16 bits of the ethernet MAC address  |
| 15.0 |      |             | Upper 16 bits of the ethernet MAC address. |
| 15:0 |      |             | See ADDRL for more details. In the example |
|      |      |             | given in ADDRL, this register would be     |
|      |      |             | programmed with 0x5544.                    |

## **EMAC\_LAFL**

Address: Operational Base + offset (0x002c)

Logical Address filter Register Low

| Bit  | Attr | Reset Value | Description                                     |
|------|------|-------------|-------------------------------------------------|
|      |      |             | LAFL                                            |
|      |      |             | Low 32 bits for the Logical Address Filter      |
|      |      |             | Low 32 bits for the Logical Address Filter.     |
| 31:0 | RW   | 0x00000000  | Each bit corresponds to a hash function of the  |
|      |      |             | destination address of a packet. IFf the bit is |
|      |      |             | set to a 1, then the packet is accepted,        |
|      |      |             | otherwise it is filtered out.                   |

## EMAC\_LAFH

Address: Operational Base + offset (0x0030)

Logical Address filter Register High

| Bit  | Attr | Reset Value | Description                                    |
|------|------|-------------|------------------------------------------------|
|      |      |             | LAFH                                           |
|      |      | • 0         | High 32 bits for the Logical Address Filter    |
|      |      |             | High 32 bits for the Logical Address Filter.   |
| 31:0 | RW   | 0x0000000   | Each bit corresponds to a hash function of the |
|      |      |             | destination address of a packet. If the bit is |
|      | 1    |             | set to a 1, then the packet is accepted ,      |
|      |      | 7           | otherwise it is filtered out.                  |

## EMAC\_MDIO\_DATA

Address: Operational Base + offset (0x0034)

MDIO access register

| <u> </u> | 1210 decess register |             |                                               |  |  |
|----------|----------------------|-------------|-----------------------------------------------|--|--|
| Bit      | Attr                 | Reset Value | Description                                   |  |  |
|          |                      |             | SFD                                           |  |  |
| 31:30    | RW                   | 0x0         | Start of Frame Delimiter                      |  |  |
|          |                      |             | Start of Frame Delimiter, must be set to "01" |  |  |
| 29:28    |                      | 0x0         | OP                                            |  |  |
|          | RW                   |             | Operation Code                                |  |  |
|          |                      |             | Operation Code, set to "10" for a read and    |  |  |
|          |                      |             | "01" for a write.                             |  |  |



| Bit   | Attr | Reset Value | Description                                |
|-------|------|-------------|--------------------------------------------|
|       |      |             | PHY                                        |
| 27:23 | RW   | 0x00        | PHY address(0-31)                          |
|       |      |             | PHY address(0-31)                          |
|       |      |             | REG                                        |
| 22:18 | RW   | 0x00        | Register to access (0-31)                  |
|       |      |             | Register to access (0-31)                  |
|       |      |             | TA                                         |
| 17:16 | RW   | 0x0         | Bus Turn-Around, must be set to "10"       |
|       |      |             | Bus Turn-Around, must be set to "10"       |
|       |      |             | DATA                                       |
|       |      |             | DATA to be written to or read from the PHY |
| 15:0  | RW   | 0x0000      | register                                   |
|       |      |             | DATA to be written to or read from the PHY |
|       |      |             | register                                   |

## **EMAC\_TXRINGPTR\_READ**

Address: Operational Base + offset (0x0038)Transmit Ring Pointer read-back register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0×00000000  | TXRINGPTR Transmit Ring Pointer read-back register This read-only register gives the address of the current Transmit Buffer Descriptor being polled or processed by the VMAC. This allows the software to determine where in the BDT ring the VMAC is currently processing. Note that this is a hardware register and undergoes rapid changes. The value in this register should ONLY be read when TXRN is cleared to zero so that the VMAC will stop processing buffers. |

# EMAC\_RXRINGPTR\_READ

Address: Operational Base + offset (0x003c)Receive Ring Pointer read-back register

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
|-----|------|-------------|-------------|

| Bit  | Attr | Reset Value | Description                                    |
|------|------|-------------|------------------------------------------------|
|      |      |             | RXRINGPTR                                      |
|      |      |             | Receive Ring Pointer read-back register        |
|      |      |             | This read-only register gives the address of   |
| 31:0 | RO   | 0x00000000  | the current Receive Buffer Descriptor being    |
|      |      |             | polled or processed by the VMAC. This allows   |
|      |      |             | the software to determine where in the BDT     |
|      |      |             | ring the VMAC is currently processing buffers. |

# 32.4 Timing Diagram

# • Management Timing Diagram



Fig. 32-5Management timing diagram

Table 32-1 Management timing parameters

| Parameter          | Description                                         | min   | typ | max | unit |
|--------------------|-----------------------------------------------------|-------|-----|-----|------|
| $T_{MDC}$          | MDC clock period                                    | 400   | -   | -   | ns   |
| t <sub>MODLY</sub> | Mii_md output delay time from mii_mdclk rising edge | 261.2 |     |     | ns   |
| t <sub>MISU</sub>  | Mii_md input setup time from mii_mdclk risiong edge | 133.3 | -   | ı   | ns   |
| t <sub>MIH</sub>   | Mii_md input hold time from mii_mdclk risiong edge  | 0     | -   | -   | ns   |

## • RMII Timing Diagram



Fig. 32-6 RMII timing diagram

Table 32-2 RMii timing parameters

| Parameter            | Description                                                                   | min   | typ   | max    | unit |
|----------------------|-------------------------------------------------------------------------------|-------|-------|--------|------|
|                      | Rmii_clkout clock frequency                                                   | -     | 50    | -      | MHz  |
| t <sub>ODLYDAT</sub> | Rmii txd output delay                                                         | 6.061 | 9.403 | 14.044 | ns   |
| t <sub>ODLYCTL</sub> | Rmii control signals output delay                                             | 6.131 | 9.48  | 14.134 | ns   |
| t <sub>ISUDAT</sub>  | rmii_rxd setup to<br>rmii_clkout/rmii_clkin<br>rising edge                    | 3.083 | 4.035 | 5.489  | ns   |
| t <sub>IHDAT</sub>   | rmii_rxd hold to<br>rmii_clkout/rmii_clkin<br>rising edge                     | 1.423 | 1.858 | 2.746  | ns   |
| t <sub>ISUCTL</sub>  | rmii_crs_dv, rmii_rx_err<br>setup to<br>rmii_clkout/rmii_clkin<br>rising edge | 3.088 | 4.217 | 5.253  | ns   |
| t <sub>IHCTL</sub>   | rmii_crs_dv, rmii_rx_err<br>hold to<br>rmii_clkout/rmii_clkin<br>rising edge  | 1.425 | 1.873 | 2.6    | ns   |

# **32.5 Interface Description**

Table 32-3 RMII/MII Interface Description

| Module pin Direction Pad name | IOMUX |
|-------------------------------|-------|
|-------------------------------|-------|



|                     |                | ı              |                            |  |  |  |  |  |  |  |  |  |  |
|---------------------|----------------|----------------|----------------------------|--|--|--|--|--|--|--|--|--|--|
| name                |                |                |                            |  |  |  |  |  |  |  |  |  |  |
|                     | RMII interface |                |                            |  |  |  |  |  |  |  |  |  |  |
| rmii_clkout         | 0              | GPIO1_C[0]     | GRF_GPIO1C_IOMUX[1:0]=10   |  |  |  |  |  |  |  |  |  |  |
| rmii_clkin          | I              | GPIO1_C[0]     | GRF_GPIO1C_IOMUX[1:0]=11   |  |  |  |  |  |  |  |  |  |  |
| rmii_tx_en          | 0              | GPIO1_C[1]     | GRF_GPIO1C_IOMUX[3:2]=10   |  |  |  |  |  |  |  |  |  |  |
| rmii_txd1           | 0              | GPIO1_C[2]     | GRF_GPIO1C_IOMUX[5:4]=10   |  |  |  |  |  |  |  |  |  |  |
| rmii_txd0           | 0              | GPIO1_C[3]     | GRF_GPIO1C_IOMUX[7:6]=10   |  |  |  |  |  |  |  |  |  |  |
| rmii_rx_err         | I              | GPIO1_C[4]     | GRF_GPIO1C_IOMUX[9:8]=10   |  |  |  |  |  |  |  |  |  |  |
| rmii_crs_dv<br>alid | I              | GPIO1_C[5]     | GRF_GPIO1C_IOMUX[11:10]=10 |  |  |  |  |  |  |  |  |  |  |
| rmii_rxd1           | I              | GPIO1_C[6]     | GRF_GPIO1C_IOMUX[13:12]=01 |  |  |  |  |  |  |  |  |  |  |
| rmii_rxd0           | I              | GPIO1_C[7]     | GRF_GPIO1C_IOMUX[15:14]=01 |  |  |  |  |  |  |  |  |  |  |
|                     | Manage         | ement interfac | ce                         |  |  |  |  |  |  |  |  |  |  |
| mii_md              | I/O            | GPIO1_D[0]     | GRF_GPIO1D_IOMUX[1:0]=10   |  |  |  |  |  |  |  |  |  |  |
| mii_mdclk           | 0              | GPIO1_D[1]     | GRF_GPIO1D_IOMUX[3:2]=10   |  |  |  |  |  |  |  |  |  |  |

# 32.6 Application Notes

#### 32.6.1 Buffer Descriptors

Data is sent and received via buffers that are built in system memory. These buffers are pointed to by the Buffer Descriptor Rings that are also located in memory. These are two Buffer Descriptor Rings: the transmit (TX) and receive (RX) rings. The Transmit Ring Pointer (TXRINGPTR) is a pointer to the start of the Transmit Descriptor Ring. The RXRINGPTR register similarly is a pointer to the start of the Receive Descriptor Ring. The VMAC processes each descriptor in each ring sequentially until it reaches the last descriptor. Then the VMAC will automatically cycle back to the first descriptor in the ring.

Each Buffer Descriptor Ring in turn consist of a number of Buffer Descriptors. The Buffer Descriptor Rings must occupy a contiguous area of memory and must be aligned on 8-byte boundaries. The number of Buffer Descriptors in the Ring are programmed by fields in the CONTROL register.

Each Buffer Descriptor (BD) within the Ring in turn points to a buffer in memory that contains the packet data. Each Buffer Descriptor consists of eight bytes of data formatted as two 32-bit Wrds. The first Wrd (INFO) contains various status information on the buffer itself. The most important field is the OWN bit which indicates whether the VMAC "owns" the buffer, or the processor "owns" the buffer. The OWN bit is a semaphore that indicates who is allowed access to the buffer and the buffer descriptor. If the VMAC owns the buffer, the processor must not make any changes to either the buffer descriptor or the contents of the buffer. If the processor owns the buffer then the VMAC will ignore the buffer and wait for the processor to release it. Once a buffer and the Buffer Descriptor have been prepared, the processor toggles the OWN bit and releases the buffer to the VMAC. The second Wrd of the BD is the PTR field which is a 32-bit byte addressable pointer to the packet data. The data can start on any bute boundary and need not be aligned. Any number of bytes of data can be contained in the buffer, every zero bytes. The length of the buffer is defined in the LENGTH field of the INFO Wrd. A buffer typically contains all of the bytes of a single packet.





Fig. 32-7 VMAC buffer chain

Fig. 32-9 shows the relationship of the VMAC registers and the Buffer Descriptors. The RINGPTR register is shown on the left which points to the starting address of the Buffer Descriptor Ring (either TX or RX) in system memory. The Buffer Descriptor Ring takes up a very small amount of the system memory and is expanded on the right of the diagram. The Buffer Descriptor Ring has a number of Buffer Descriptors in it each containing the two 32-bit Wrds, INFO and PTR. The PTR in turn points to the start of buffer data which can be in any location in system memory. The VMAC processes one Buffer Descriptor after the next in the ring. When the last BD has been processed, it circles back to the beginning of the ring and continues processing from there.

#### 32.6.2 Transmit Buffer Descriptor

The Transmit Buffer descriptor consists of two 32-bit Wrds, the INFO and PTR Wrds. The INFO Wrd is broken up into a number of a smaller fields described on the following page. Note that the processor fills the INFO field with one set of data, and then release the buffer to the VMAC by setting the OWN bit. Once the VMAC has completed processing this buffer, it will fill the INFO Wrd with different data and clear the OWN bit.

The processor must completely set up the Buffer Descriptor and completely fill the buffer with data before setting the OWN bit. Once the OWN bit is set, the processor must not alter the BD or buffer data. Once the OWN bit is set the VMAC will clear the OWN bit once the buffer has been sent or error condition has occurred.

### 1. Transmit Buffer Descriptor written by CPU



Address: 0x00

| 31      | 30 | 29 | 28 | 27 | 26 | 25  | 24   | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13  | 12  | 11 | 10 | 9 | 8 | 7 | 6 | 5   | 4 | 3 | 2 | 1 | 0 |
|---------|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|---|---|---|---|-----|---|---|---|---|---|
| OW<br>N |    |    |    |    | F  | Res | erve | ed |    |    |    |    | AD |    |    |    | Re | ser | ved |    |    |   |   |   | T | ΧLI | N |   |   |   |   |
| IN      |    |    |    |    |    |     |      |    |    |    |    |    | CR | 51 | ST |    |    |     |     |    |    |   |   |   |   |     |   |   |   |   |   |

Address: 0x04



Fig. 32-8 VMAC transmit buffer descriptor written by CPU

The field descriptions for these registers are shown in the following table:

| Bit   | Attr | Reset<br>Value | Description                                                                                                                                                                                                        |
|-------|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:32 | RW   | 0x0            | POINTER: 32 bit physical address to the start of the buffer data. Does not have to be Wrd aligned. The DMA controller will DMA bytes until it becomes Wrd aligned, then it will transfer Words. Unchanged by VMAC. |
| 31    | RW   | 0x0            | OWN 0: buffer owned by the CPU 1: buffer owned by the VMAC                                                                                                                                                         |
| 30:19 | N/A  | 0x0            | Reserved                                                                                                                                                                                                           |
| 18    | RW   | 0x0            | ADCR – ADDCRC  1: VMAC will compute and add the 4 byte CRC to the end of the packet.  0: don't add the CRC (FCS) to the end of the packet                                                                          |
| 17    | RW   | 0x0            | LAST – This bit must be set to one when it is the last buffer in a packet. Note that both FIRST and LAST are set at the same time if the buffer is large enough to hold the entire packet                          |
| 16    | RW   | 0x0            | FIRST – This bit must be set to one when it is the first buffer in a packet                                                                                                                                        |
| 15:11 | N/A  | 0x0            | Reserved                                                                                                                                                                                                           |
| 10:0  | RW   | 0x0            | TXLEN – length of data in this buffer to be transmitted. Can be zero length in the case of packet-chaining, but the minimum length for a packet is 64 bytes.                                                       |

## 2. Transmit Buffer Descriptor Written by VMAC

Address: 0x00



Address: 0x04



Fig. 32-9 VMAC transmit buffer descriptor written by VMAC



The field descriptions for these registers are shown in the following table:

Table 32-4 VMAC tx buffer descriptor

|          |               | le 32-4 VMAC tx buffer descriptor                                                                                                                                                              |
|----------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Attr     |               | Description                                                                                                                                                                                    |
|          |               |                                                                                                                                                                                                |
| R        | 0x0           | POINTER: 32 bit physical address to the start of the                                                                                                                                           |
|          |               | buffer data. Does not have to be Wrd aligned. The                                                                                                                                              |
|          |               | DMA controller will DMA bytes until it becomes Wrd                                                                                                                                             |
|          |               | aligned, then it will transfer Wrds. Unchanged by                                                                                                                                              |
| 5111     |               | VMAC.                                                                                                                                                                                          |
| RW       | 0x0           | OWN – Cleared by VMAC. When this bit is cleared,                                                                                                                                               |
|          |               | the TXINT bit is set if END is also set and the                                                                                                                                                |
| D1 / D   | 0.0           | transmission has complete.                                                                                                                                                                     |
| -        |               | Reserved                                                                                                                                                                                       |
| RW       | 0x0           | UFLO – Underflow erRr, packet data corrupted and                                                                                                                                               |
|          |               | dropped because data was not available in time.                                                                                                                                                |
|          |               | Larger FIFOs, more AHB bus bandwidth or lower                                                                                                                                                  |
|          |               | system latency required.                                                                                                                                                                       |
| RW       | 0x0           | LATECOL - Late collision error - Packet dropped                                                                                                                                                |
|          |               | due to late collision                                                                                                                                                                          |
| RW       | 0x0           | RTRY – Retry count, Number of times the packet                                                                                                                                                 |
|          |               | was retried. Packet transmission is attempted up to                                                                                                                                            |
|          |               | 16 times. If the packet is transmitted successfully                                                                                                                                            |
|          |               | on the first try, the value is zero.                                                                                                                                                           |
| RW       | 0x0           | DRP – More than 16 retransmissions were                                                                                                                                                        |
| D        |               | attempted and the packet was dropped                                                                                                                                                           |
| RW       | 0x0           | DEFR – Transmission was deferred due to traffic on                                                                                                                                             |
| DV       | 0.0           | the wire                                                                                                                                                                                       |
|          |               | CRLS- Carrier sense was lost during transmission                                                                                                                                               |
| N/A      | 0x0           | Rreserved                                                                                                                                                                                      |
| R        | 0x0           | ADCR - ADDCRC                                                                                                                                                                                  |
|          |               | 1: VMAC will compute and add the 4 byte CRC to                                                                                                                                                 |
|          | 40            | the end of the packet.                                                                                                                                                                         |
|          | ( )           | 0: don't add the CRC (FCS) to the end of the packet                                                                                                                                            |
| R        | 0x0           | LAST – This bit is one when it is the last buffer in a                                                                                                                                         |
| <b>A</b> | 1             | packet.                                                                                                                                                                                        |
| R        | 0x0           | FIRST – This bit is one when it is the first buffer in                                                                                                                                         |
|          | ) "           | a packet                                                                                                                                                                                       |
| N/A      | 0x0           | Reserved                                                                                                                                                                                       |
| R        | 0x0           | TXLEN – length of data in this buffer to be                                                                                                                                                    |
|          |               | transmitted.                                                                                                                                                                                   |
|          | R<br>R<br>N/A | Attr Reset Value R 0x0 RW 0x0 |

## 32.6.3 Receive Buffer Descriptor

The receive buffer descriptor is very similar to the Transmit Buffer Descriptor and again consists of two 32-bit Words, the INFO and PTR Words. The INFO Wrd is broken up into a number of smaller fields described on the following page.

Note that the processor fills the INFO field with one set of data, and then releases the buffer to the VMAC by setting the OWN bit. Once the VMAC has completed processing this buffer, it will fill the INFO Wrd with different data and clear the OWN bit.

The processor must completely set up the Buffer Descriptor before setting the OWN bit. The data buffer can be left uninitialized as VMAC will fill it with data



once a packet has been received. Once the OWN bit is set, the processor must NOT alter the Buffer Descriptor. Once the OWN bit is set the VMAC may begin operating on the buffer immediately. The VMAC will clear the OWN bit once the buffer has been filled with data or an error condition has occurred.

### 1. Receive Buffer Descriptor Written by VMAC

Address: 0x00 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 Reserved Reserved

Address: 0x04

32 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 **POINTER** 

Fig. 32-10 VMAC receive buffer descriptor written by VMAC

The field descriptions for this register are shown below.

Table 32-5 VMAC- rx buffer descriptor for VMAC

| Bit   | Attr | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:32 | R    | 0x0            | POINTER: 32 bit physical address to the start of the buffer data. Does not have to be Word aligned. The DMA controller will DMA bytes until it becomes Wrd aligned, then it will transfer Wrds.                                                                                                                                                                                                      |
| 31    | RW   | 0x0            | OWN 0: buffer owned by the CPU 1: buffer owned by the VMAC This bit is cleared by VMAC. When this bit is cleared and LAST is set to 1, the RXINT bit is set.                                                                                                                                                                                                                                         |
| 30    | RW   | 0x0            | BUFF – Buffer error, an error occurred during packet chaining, with data in one or more of the buffers in the chain corrupted.Software shold discard the entire packet and return the buffers back to the VMAC.                                                                                                                                                                                      |
| 29:18 | N/A  | 0x0            | Reserved                                                                                                                                                                                                                                                                                                                                                                                             |
| 17    | RW   | 0x0            | LAST – This bit must be set to one when it is the last buffer in a packet.                                                                                                                                                                                                                                                                                                                           |
| 16    | RW   | 0x0            | FIRST – This bit must be set to one when it is the first buffer in a packet. Note that in certain error conditions, you may come acRss a FIRST bit being set without a corresponding END.In this case the previous packet must be dropped.                                                                                                                                                           |
| 15:11 | N/A  | 0x0            | Reserved                                                                                                                                                                                                                                                                                                                                                                                             |
| 10:0  | RW   | 0x0            | RXLEN – Length of the data in this buffer in bytes. Might be zero length. Note that if a packet of exactly the same length as the RXLEN is received, there is a chance that the VMAC will release the buffer without the LAST bit set in anticipation of using buffer chaining. The next buffer will be released with the LAST bit set but will be zero length. This is especially true when the CPU |



| is clocking much faster than the VMAC.To prevent chaining, the CPU shold set RXLEN to a slightly larger value than ghe largest expected packet |
|------------------------------------------------------------------------------------------------------------------------------------------------|
| length.                                                                                                                                        |

### 2. Receive Buffer Descriptor Written by CPU

Address: 0x00

| 31      | <br>29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17       | 16 | 15 | 14 | 13  | 12  | 11 | 10 | 9 | 8 | 7 | 6 | 5  | 4 | 3 | 2 | 1 | 0 |
|---------|--------|----|----|----|----|-----|----|----|----|----|----|----|----------|----|----|----|-----|-----|----|----|---|---|---|---|----|---|---|---|---|---|
| OW<br>N |        |    |    |    | Re | ser | ve | d  |    |    |    |    | LA<br>ST |    |    | Re | ser | ved |    |    |   |   |   | R | XL | N |   |   |   |   |
|         |        |    |    |    |    |     |    |    |    |    |    |    |          |    |    |    |     |     |    |    |   |   |   |   |    |   |   |   |   |   |

Address: 0x04



Fig. 32-11 VMAC receive buffer descriptor written by CPU

The field descriptions for this register are shown below.

Table 32-6 VMAC-rx buffer descriptor for CPU

| Bit   | Attr | Reset<br>Value | Description                                                                                                                                                                                     |  |
|-------|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 63:32 | R    | 0x0            | POINTER: 32 bit physical address to the start of the buffer data. Does not have to be word aligned. The DMA controller will DMA bytes until it becomes Wrd aligned, then it will transfer Wrds. |  |
| 31    | RW   | 0x0            | OWN 0: Buffer owned by the CPU 1: Buffer owned by the VMAC                                                                                                                                      |  |
| 30:18 | N/A  | 0x0            | Rreserved                                                                                                                                                                                       |  |
| 17    | RW   | 0x0            | LAST – This bit is one when it is the last buffer in a packet. CPU clears it to zero.                                                                                                           |  |
| 16    | RW   | 0x0            | FIRST – This bit is one when it is the first buffer in a packet, CPU clears it to zeR                                                                                                           |  |
| 15:11 | N/A  | 0x0            | Reserved                                                                                                                                                                                        |  |
| 10:0  | RW   | 0x0            | RXLEN – Maximum length of data in this buffer in bytes. Can be zero but strongly discouraged. Minimum of 64 bytes recommended. 1536 recommended unless using chaining.                          |  |

#### 32.6.4 Buffer Chaining

The length of each buffer is defined in the RXLEN or TXLEN fields within the INFO Wrd of each Buffer Descriptor. The length of a buffer can be between zero and 2047 bytes though buffer of less than 64 bytes and strongly discouraged. Larger FIFOs are highly recommended when using buffer chaining.

Buffer chaining is also useful for receive packets by using more buffers of smaller sizes. Chaining allows the use of smaller buffers which in turn creates more buffers in the same amount of memory. More receive buffers means there a lower chance of dropping important short packets and relying on upper level software to transmit the dropped packets. Note that by chaining buffers you can still assemble the packet data to be contiguous for large packets.



### 32.6.5 Automatic Descriptor Polling

The TX and RX BDT rings will be polled at the frequency programmed into the POLLRATE register. The DMA controller polls the BDT rings to see if the next descriptors in the chain are owned by the VMAC. There are also several instances where automatic polling of the descriptor chains will occur.

# Chapter 33 High-Speed ADC /TS stream Interface

## 33.1 Overview

HS-ADC Interface Unit is interface unit for connecting the High Speed AD Converter to AMBA AHB bus. That implement bus speed convert at low speed AD Converter bus to high speed AHB bus. HS-ADC Interface Unit fetches the bus data by the AD converter and stores that to asynchronous FIFO after the AD clock is active when OS configure completion by DMA and HS-ADC Interface Unit. The HS-ADC Interface Unit generates the DMA request signal when data length of the asynchronous FIFO over the almost full level or almost empty level.

#### 33.1.1 Features

- Support HS-ADC interface with 8bits/10bits data bus
- Support Transport-Stream Interface with 8bits data bus
- Support GPS interface with 2bits/4bits data bus
- Support combined interrupt output, the source includes:full interrupt, empty interrupt
- Support DMA transfers mode and that generate DMA request from the event of almost full or almost empty, etc.
- Support two channel mode:single channel and dual channel
- Support the most significant bit negation or not
- Support sign bitextention
- Support two store mode: store to high 8bits/10bits and store to low 8bits/10bits
- Support an asynchronous build-in FIFO with 128x64 size
- Support AHB burst transfer, including SINGLE, INCR4, INCR8, INCR16

# 33.2 Block Diagram



Fig. 33-1 HS-ADC/TS Interface block diagram



# 33.3 Function Description

This module can be configured for 3 interfaces:

- 1. HS-ADC interface
- 2. GPS interface
- 3. TS interface

### 1. HS-ADC interface

When this module is used as HS-ADC interface, user should configureGRF GPIO2B IOMUX and GRF GPIO2C IOMUX to select HS-ADC data input, and select hsadc\_clock input(pgs\_clkin) from pad or output hsadc clock(hsadc clkout) to pad. The direction of hsadc clock is determined by software through configuring CRU CLKSEL CON[5:4].



Fig. 33-2 HS-ADC application diagram

#### 2. GPS interface

When this module is used as GPS interface, user should configureGRF\_GPIO2C\_IOMUX to select 2bits or 4bitsGPS data input and gps\_clk as GPS clock input from pad.

Also, user should configure CRU\_CLKSEL\_CON[5:4] to select gps\_clk as HS-ADC controller working clock source.



Fig. 33-3 GPS application diagram

#### 3. TS interface

When this module is used as TS interface, user should configure GRF\_GPIO2B\_IOMUX and GRF\_GPIO2C\_IOMUX to select 8bit TS data, ts sync, ts\_valid and ts\_fail input and gps\_clk input as TS clock input from pad.

Also, user should configure CRU\_CLKSEL\_CON[5:4] to select qps\_clk from pad as TS clock input.





Fig. 33-4 TS application diagram

# 33.4 Register Description

## 33.4.1 Registers Summary

| Name          | Offset | Size | Reset Value | Description                       |
|---------------|--------|------|-------------|-----------------------------------|
| HSADC_CTRL    | 0x00   | RW   | 0x00000000  | control register                  |
| HSADC_IER     | 0x04   | RW   | 0x00000000  | interrupt enable/mask<br>register |
| HSADC_ISR     | 0x08   | RW   | 0x00000000  | interrupt status register         |
| HSADC_TS_FAIL | 0x0c   | R    | -           | ts fail register                  |
| HSADC_DATA    | 0x10   | R    | -           | data register                     |

## 33.4.2 Detail Register Description

## **HSADC\_CTRL**

Address: Operational Base + offset (0x0000)

|       | Control register |             |                                                  |  |  |  |
|-------|------------------|-------------|--------------------------------------------------|--|--|--|
| Bit   | Attr             | Reset Value | Description                                      |  |  |  |
| 31:28 | RO               | 0x0         | reserved                                         |  |  |  |
|       |                  |             | almost_full_level                                |  |  |  |
|       |                  |             | Define almost full trigger level                 |  |  |  |
| 27:24 | RW               | 0x0         | 0x0~"0xf" - configure valid range (Notes: 1      |  |  |  |
| 27.27 | IXVV             | 0,0         | level indicate 4 entries data in the async FIFO. |  |  |  |
|       |                  |             | and this configure range mapping to 64 - 124     |  |  |  |
|       | A 1              |             | entries data in the async FIFO.)                 |  |  |  |
| 23:20 | RO               | 0x0         | reserved                                         |  |  |  |
|       |                  |             | almost_empty_level                               |  |  |  |
|       |                  |             | Define almost empty trigger level                |  |  |  |
| 10.16 | RW               | 0×0         | 0x0~"0xf" - configure valid range (Notes: 1      |  |  |  |
| 19:16 | KVV              | UXU         | level indicate 4 entries data in the async FIFO. |  |  |  |
|       |                  |             | and this configure range mapping to 0 - 60       |  |  |  |
|       |                  |             | entries data in the async FIFO.)                 |  |  |  |
| 15:13 | RO               | 0x0         | reserved                                         |  |  |  |
|       |                  |             | sbex                                             |  |  |  |
| 12    |                  |             | Sign Bit extent select                           |  |  |  |
|       | RW               | 0x0         | Sign bit extent select when store width wider    |  |  |  |
|       | IV.VV            | UXU         | than interface width                             |  |  |  |
|       |                  |             | 0: fill 0                                        |  |  |  |
|       |                  |             | 1: fill sign extend bit                          |  |  |  |



| Bit | Attr   | Reset Value | Description                                   |
|-----|--------|-------------|-----------------------------------------------|
|     |        |             | gpsw                                          |
| 11  | RW     | 0×0         | GPS interface data width select               |
| 111 | IX V V | OXO         | 0:2bit data mode                              |
|     |        |             | 1:4bit data mode                              |
|     |        |             | ts_sync_en                                    |
| 10  | RW     | 0x0         | TS sync interface enable                      |
|     |        |             | Field0000 Description                         |
|     |        |             | ts_valid_en                                   |
|     |        |             | TS valid interface enable                     |
|     | RW     | 0.40        | Enable ts interface "ts_valid" signal as data |
| 9   | KVV    | 0x0         | valid indicator                               |
|     |        |             | 0:disable                                     |
|     |        |             | 1:enable                                      |
|     |        |             | ts_sel                                        |
|     |        |             | MPEG-TS input select                          |
| 0   | DW     | 00          | 0 : MPEG-TS is Not selected                   |
| 8   | RW     | 0x0         | 1: MPEG-TS is selected                        |
|     |        |             | *When gps_sel & ts_sel both equal to 0,then   |
|     |        |             | ADC IF is selected                            |
|     |        |             | chan                                          |
|     |        |             | data input channel select                     |
| 7   | RW     | 0x0         | 0 : single channel, ADC input from adc_data_l |
|     |        |             | 1 : double channel data input from            |
|     |        |             | adc_data_l/adc_data_h                         |
|     |        | . (         | stmd                                          |
| _   | DW     | 0.40        | Store mode select                             |
| 6   | RW     | 0x0         | 0:8bit store mode                             |
|     |        |             | 1:16bit store mode                            |
|     | 11     |             | dma_req_mode                                  |
|     |        |             | DMA request mode select                       |
|     |        |             | 1 - almost full generate DMA request signal   |
|     |        |             | (Notes: this mode generate DMA request        |
|     | ·      |             | signal from almost full condition and cancel  |
| E   | DW     | 0.40        | DMA request signal from almost empty          |
| 5   | RW     | 0x0         | condition. so you need configure two level by |
|     |        |             | almost full level and almost empty level)     |
|     |        |             | 0 - almost empty generate DMA request signal  |
|     |        |             | (Notes: this mode generate DMA request        |
|     |        |             | signal from almost empty condition and that   |
|     |        |             | only once DMA request.)                       |



| Bit | Attr | Reset Value | Description                                       |
|-----|------|-------------|---------------------------------------------------|
|     |      | 0×0         | smsb                                              |
| 4   | RW   |             | MSB negation select                               |
| 4   | KVV  | UXU         | 1:negation                                        |
|     |      |             | 0:not negation                                    |
|     |      |             | sctl                                              |
|     |      |             | store mode select                                 |
|     |      |             | fetch the bus data by AD converter and that       |
|     |      |             | store to high 8-bit/10-bit or low 8-bit/10-bit at |
| 3   | RW   | 0x0         | a haft word width before push to Async FIFO:      |
|     |      |             | "1" - store to high 8-bit/10-bit                  |
|     |      |             | "0" - store to low 8-bit/10-bit (Notes: have      |
|     |      |             | sign extend if that configure of store to low     |
|     |      |             | 8-bit/10-bit)                                     |
|     |      | 0×0         | bwth                                              |
| 2   | RW   |             | The data bus width of AD converter                |
| 2   | IXVV |             | "1" - 10-bit                                      |
|     |      |             | "0" - 8-bit                                       |
|     | RW   | 0x0         | gps_sel                                           |
|     |      |             | GPS input select                                  |
| 1   |      |             | 0 : GPS is Not selected                           |
|     | IXVV |             | 1 : GPS is selected                               |
|     |      |             | *When gps_sel & ts_sel both equal to 0,then       |
|     |      |             | ADC IF is selected                                |
|     |      |             | adc_en                                            |
|     |      | 0×0         | HS-ADC Interface Unit Enable Bit                  |
| 0   | RW   |             | "1" - enable (Notes: will return 1 when the       |
|     | KVV  |             | hardware started transfer)                        |
|     |      |             | "0" - disable (Notes: other bit can be modify     |
|     | 1    |             | only the hardware return 0)                       |

# HSADC\_IER

Address: Operational Base + offset (0x0004)

Interrupt control register

| Bit  | Attr   | Reset Value | Description                            |  |
|------|--------|-------------|----------------------------------------|--|
| 31:2 | RO     | 0x0         | reserved                               |  |
|      |        |             | int_empty_en                           |  |
|      |        |             | Interrupt en/disable bit for the empty |  |
| 1    | RW 0x0 |             | interrupt flag of async FIFO           |  |
|      |        |             | "1" - enable                           |  |
|      |        |             | "0" - disable                          |  |



| Bit | Attr | <b>Reset Value</b> | Description                                     |  |
|-----|------|--------------------|-------------------------------------------------|--|
|     |      |                    | int_full_en                                     |  |
|     |      |                    | Interrupt en/disable bit for the full interrupt |  |
| 0   | RW   | 0x0                | flag of async FIFO                              |  |
|     |      |                    | "1" - enable                                    |  |
|     |      |                    | "0" - disable                                   |  |

### **HSADC\_ISR**

Address: Operational Base + offset (0x0008)

Interrupt status register

| Bit  | Attr | Reset Value | Description                                       |
|------|------|-------------|---------------------------------------------------|
| 31:2 | RO   | 0x0         | reserved                                          |
|      |      |             | int_empty_stat_ind                                |
|      |      |             | Async FIFO empty interrupt flag                   |
|      |      |             | "1(R)" - This bit will be set to "1" when Async   |
| 1    | RW   | 0x0         | FIFO empty status and that only to read           |
|      |      |             | operation.                                        |
|      |      |             | "0(W)" - Write "0" to bit for clear the interrupt |
|      |      |             | flag and that only to wrtie operation.            |
|      |      |             | int_full_stat_ind                                 |
|      |      | / 0×0       | Async FIFO full interrupt flag                    |
|      | RW   |             |                                                   |
| 0    |      |             | "1(R)" - This bit will be set to "1" when Async   |
| U    | KVV  |             | FIFO full status and that only to read            |
|      |      |             | operation.                                        |
|      |      | . ()        | "0(W)" - Write "0" to bit for clear the interrupt |
|      |      |             | flag and that only to wrtie operation.            |

**HSADC\_TS\_FAIL**Address: Operational Base + offset (0x000c)

ts fail register

| Bit      | Attr | Reset Value | Description                                  |  |
|----------|------|-------------|----------------------------------------------|--|
| 31:1     | RO   | 0x0         | reserved                                     |  |
|          | 7    |             | ts_fail_ahb                                  |  |
| <b>Y</b> |      | 0×0         | TS stream fail indicator                     |  |
| 0        | RW   |             | this signal only valid when select TS stream |  |
| U        | KVV  |             | input( mpts=1)                               |  |
|          |      |             | 0:TS stream decode successfully              |  |
|          |      |             | 1:TS stream decode fail                      |  |

# **HSADC\_CGCTL**

Address: Operational Base + offset (0x0010)

**HSADC Clock Gating control** 



| Bit  | Attr | Reset Value | Description                                  |  |  |
|------|------|-------------|----------------------------------------------|--|--|
|      |      |             | cycle_cfg                                    |  |  |
|      |      |             | clock gated cycles configuration             |  |  |
| 31:1 | RW   | 0x00000000  | when configure cg_enable to 1 and cycle_cfg  |  |  |
|      |      |             | to non-zero value, HSADC clock will be gated |  |  |
|      |      |             | for cycle_cfg cycles ,then clock recover.    |  |  |
|      |      | W 0×0       | cg_enable                                    |  |  |
| 0    | RW   |             | clock gating enable control                  |  |  |
| U    | KVV  |             | 0:clock gating disable                       |  |  |
|      |      |             | 1:clock gating enable                        |  |  |

#### **HSADC\_DATA**

Address: Operational Base + offset (0x0020)

Data register

| Bit  | Attr | Reset Value | Description |  |  |
|------|------|-------------|-------------|--|--|
|      |      |             | DATA        |  |  |
| 31:0 | RO   | 0x00000000  | DATA        |  |  |
|      |      |             | DATA        |  |  |

# 33.5 Timing Diagram



Fig. 33-5 HS-AD Interface timing diagram

Table 33-1 HS-ADC interface timing parameter

| Parameter                | Symbol             | Min   | Тур   | Max   | Unit |
|--------------------------|--------------------|-------|-------|-------|------|
| Clock Cycle              | t <sub>cycle</sub> | 50    | 50    | 50    | ns   |
| Data to clock setup time | t <sub>setup</sub> | 3.123 | 4.211 | 6.366 | ns   |
| Data to clock hold time  | t <sub>hold</sub>  | 0     | 0     | 0     | ns   |

Note: When interface configured as TS or GPS interface, CLK is input from pad, when configured as ADC interface, CLK is output to pad.

# 33.6 Interface Description

The following are typical iomux configurations.

For more information, please reference detailed register description in GRF chapter.

In ADC mode:

Table 33-2 IOMUX configuration in ADC mode

| Module Pin    | Direction | Pad Name   | IOMUX Setting                              |
|---------------|-----------|------------|--------------------------------------------|
| hsadc_clkout/ | O/        | GPIO2_C[0] | GRF_GPIO2C_IOMUX[1:0]=2'b11/GRF_GPIO2C_IOM |
| gps_clkin     | I         |            |                                            |
| adc_data_i[0] | I         | GPIO2_C[3] | GRF_GPIO2C_IOMUX[7:6]=2'b11                |
| adc_data_i[1] | I         | GPIO2_C[4] | GRF_GPIO2C_IOMUX[9:8]=2'b11                |
| adc_data_i[2] | I         | GPIO2_C[5] | GRF_GPIO2C_IOMUX[11:10]=2'b11              |
| adc_data_i[3] | I         | GPIO2_C[6] | GRF_GPIO2C_IOMUX[13:12]=2'b11              |
| adc_data_i[4] | I         | GPIO2_C[7] | GRF_GPIO2C_IOMUX[15:14]=2'b11              |
| adc_data_i[5] | I         | GPIO2_C[2] | GRF_GPIO2C_IOMUX[5:4]=2'b11                |
| adc_data_i[6] | I         | GPIO2_C[1] | GRF_GPIO2C_IOMUX[3:2]=2'b11                |
| adc_data_i[7] | I         | GPIO2_B[7] | GRF_GPIO2B_IOMUX[15:14]=2'b11              |
| adc_data_i[8] | I         | GPIO2_B[5] | GRF_GPIO2B_IOMUX[11:10]=2'b11              |
| adc_data_i[9] | I         | GPIO2_B[4] | GRF_GPIO2B_IOMUX[9:8]=2'b11                |

### In GPS mode:

Table 33-3 IOMUX configuration in GPS mode

| Module Pin    | Direction | Pad Name   | IOMUX Setting                 |
|---------------|-----------|------------|-------------------------------|
| gps_clkin     | I         | GPIO2_C[0] | GRF_GPIO2C_IOMUX[1:0]=2'b10   |
| adc_data_i[0] | I         | GPIO2_C[3] | GRF_GPIO2C_IOMUX[7:6]=2'b11   |
| adc_data_i[1] | I         | GPIO2_C[4] | GRF_GPIO2C_IOMUX[9:8]=2'b11   |
| adc_data_i[2] | I         | GPIO2_C[5] | GRF_GPIO2C_IOMUX[11:10]=2'b11 |
| adc_data_i[3] | I         | GPIO2_C[6] | GRF_GPIO2C_IOMUX[13:12]=2'b11 |

### In TS mode:

Table 33-4 IOMUX configuration in TS mode

|               | Table 66  | 4 TOMON Configura | tion in 15 mode               |
|---------------|-----------|-------------------|-------------------------------|
| Module Pin    | Direction | Pad Name          | IOMUX Setting                 |
| gps_clkin     | I         | GPIO2_C[0]        | GRF_GPIO2C_IOMUX[1:0]=2'b10   |
| adc_data_i[0] | I         | GPIO2_C[3]        | GRF_GPIO2C_IOMUX[7:6]=2'b11   |
| adc_data_i[1] | ľ         | GPIO2_C[4]        | GRF_GPIO2C_IOMUX[9:8]=2'b11   |
| adc_data_i[2] | I         | GPIO2_C[5]        | GRF_GPIO2C_IOMUX[11:10]=2'b11 |
| adc_data_i[3] | Ι         | GPIO2_C[6]        | GRF_GPIO2C_IOMUX[13:12]=2'b11 |
| adc_data_i[4] | I         | GPIO2_C[7]        | GRF_GPIO2C_IOMUX[15:14]=2'b11 |
| adc_data_i[5] | I         | GPIO2_C[2]        | GRF_GPIO2C_IOMUX[5:4]=2'b11   |
| adc_data_i[6] | I         | GPIO2_C[1]        | GRF_GPIO2C_IOMUX[3:2]=2'b11   |
| adc_data_i[7] | I         | GPIO2_B[7]        | GRF_GPIO2B_IOMUX[15:14]=2'b11 |
| ts_valid      | I         | GPIO2_B[5]        | GRF_GPIO2B_IOMUX[11:10]=2'b11 |
| ts_fail       | I         | GPIO2_B[4]        | GRF_GPIO2B_IOMUX[9:8]=2'b11   |
| ts_sync       | I         | GPIO2_B[6]        | GRF_GPIO2B_IOMUX[13:12]=2'b11 |

# **33.7 Application Notes**

The following sections will describe the operation of DMA requests and DMA transfers:





Fig. 33-6Almost empty triggers a DMA request by DMA request mode

The DMA request signal will be generated from a watermark level trigger when data stored to FIFO over the watermark level of almost empty, where the watermark level can be configured through HSADC\_CTRL[19:16] by software . This DMA request mode doesn't care the watermark level of almost full. The sample for watermark level configuration is shown in figure above.



Fig. 33-7Almost full triggers a DMA request by DMA request mode

The DMA request signal will be generated from a watermark level trigger when data stored to FIFO over the watermark level of almost full. It continues to generate request signal when the number of data in FIFO greater than watermark level of almost empty. This DMA request mode needs configuretwo watermark levels: watermark level of almost empty at the HSADC\_CTRL[19:16] and watermark level of almost full at the HSADC\_CTRL[27:24]. The sample for watermark level configuration is shown in figure above.

When controller works in TS mode, the interface signal ts\_sync should always be used.



# **Chapter 34 PID-FILTER**

### 34.1 Overview

THE PID Filter controller is used to process the original TS(Transport Stream) from HS-ADC. It receives the original TS from HS-ADC, and transport the filtered TS to memory.

### 34.1.1 Key Feature

- Support 32-bit AHB slave configuration port & buffer write
- Support PID filter up to 64 channels'PID simultaneously
- Support sync-byte detection in transport packet head
- Support 188work x 2 PingPong buffer
- Support combined interrupt and interrupt polarity/type configurable
- Support transfer handshake mechanismwith external DMA
- Support packet lost mechanismwhen bandwidth is limited

# 34.2 Block Diagram



Fig. 34-1 PID-Filter block diagram

# 34.3 Function Description

This module is used to co-work with external DMA. The DMA receives raw TS data from HS-ADC controller and transfers them to PID-Filter, then PID-Filter controller filters specific TS packet out and triggers DMA to transfer remaining useful TS packet to memory for future usage.

Besides, when PID-Filter controller receives the unexpected head of TS packet or loses packet in TS receiving procedure, the controller is capable of outputting interrupt to processor.



# 34.4 Register Description

# 34.4.1 Register summary

| Name                      | Offset                 | Size | Reset<br>Value | Description                                |
|---------------------------|------------------------|------|----------------|--------------------------------------------|
| PIDF_GCTL                 | 0x0000                 | W    | 0x00000000     | Global Control register                    |
| PIDF_GSTA                 | 0x0004                 | W    | 0x0000000a     | Global Status register                     |
| PIDF_ICTL                 | 0x0010                 | W    | 0x00000000     | Interrupt control register                 |
| PIDF_IMR                  | 0x0014                 | W    | 0x00000000     | Interrupt mask register                    |
| PIDF_ICLR                 | 0x0018                 | W    | 0x00000000     | Interrupt clear register                   |
| PIDF_IRSR                 | 0x001C                 | W    | 0x00000000     | Raw interrupt status(pre-masking) register |
| PIDF_ISR                  | 0x0020                 | W    | 0x00000000     | Interrupt status register                  |
| PIDF_CHID0                | 0x0080                 | W    | 0x00000000     | Filter out ID & enable for channel 0       |
| PIDF_CHID1                | 0x0084                 | W    | 0x00000000     | Filter out ID & enable for channel 1       |
| PIDF_CHID2  ~PIDF_CHID6 3 | 0x0088<br>~0x001<br>7C | W    | 0×00000000     | Filter out ID & enable for channel 2~31    |
| PIDF_DR                   | 0x0200                 | W    | 0×00000000     | Data buffer write/read entrance            |

# 34.4.2 Register description

# PIDF\_GCTL

Address: Base + offset(0x0000)

The global control register of PID Filter controller

| Bit  | Attr | Reset Value | Description                                                                                                                       |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | R    | 0x0         | Reserved                                                                                                                          |
| 2    | RW   | 0×0         | Filter function bypass Filter function bypass enable. When set,data write transfer to buffer will not bypass PID filter function. |
| 1    | RW   | 0x0         | Hardware handshake mechanisim enable 0: Hardware handshake disable 1: Hardware handshake enable                                   |
| 0    | RW   | 0×0         | PID filter function enable 0:PID filter disable 1:PID filter enable                                                               |

### PIDF\_GSTA

Address: Base + offset(0x0004)

The global status register of PID Filter controller

| Bit  | Attr | Reset Value | Description                                              |
|------|------|-------------|----------------------------------------------------------|
| 31:4 | R    | 0x0         | Reserved                                                 |
| 3    | R    | 0x1         | Buffer 1 empty indicator Buffer 1 empty status indicator |
| 2    | R    | 0x0         | Buffer 1 full indicator Buffer 1 full status indicator   |



| 1 | R | 0x1 | Buffer 0 empty indicator<br>Buffer 0 empty status indicator |
|---|---|-----|-------------------------------------------------------------|
| 0 | R | 0x0 | Buffer 0 full indicator Buffer 0 full status indicator      |

# PIDF\_ICTL

Address: Base + offset(0x0010)

The interrupt control register of PID filter controller

| Bit  | Attr | Reset Value | Description                                      |
|------|------|-------------|--------------------------------------------------|
| 31:3 | R    | 0x0         | Reserved                                         |
|      |      |             | Interrupt type select                            |
| 2    | RW   | 0x0         | 0:Edge-type interrupt select                     |
|      |      |             | 1:Level-type interrupt select                    |
|      |      |             | Interrupt polarity select                        |
|      |      |             | 0: High-active interrupt select for combined int |
| 1    | RW   | 0x0         | output                                           |
|      |      |             | 1: Low-active interrupt select for combined int  |
|      |      |             | output                                           |
|      |      |             | Interrupt enable                                 |
| 0    | RW   | 0x0         | 0:Interrupt disable                              |
|      |      |             | 1:Interrupt enable                               |

# PIDF\_IMR

Address: Base + offset(0x0014)

The interrupt mask register of PID filter controller

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                          |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | R    | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                             |
| 3:0  | RW   | 0x0         | Interrupt mask for each interrupt source Interrupt mask for each interrupt source 0:Interrupt source mask disable for corresponding interrupt source 1:Interrupt source mask enable for corresponding interrupt source bit0: Sync byte error interrupt bit1: Packet lost detected interrupt bit2: buffer empty interrupt bit3: buffer full interrupt |

# PIDF\_ICLR

Address: Base + offset(0x0018)

The interrupt clear register of PID filter controller

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                   |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | R    | 0x0         | Reserved                                                                                                                                                                                                                      |
| 3:0  | RW   | 0x0         | Interrupt clear for each interrupt source Interrupt clear for each interrupt source 0: bit value will be set to "0" after write 1 to it 1: interrupt clear for corresponding interrupt source bit0: Sync byte error interrupt |



|  | bit1 : Packet lost detected interrupt |
|--|---------------------------------------|
|  | bit2 : buffer empty interrupt         |
|  | bit3 : buffer full interrupt          |

#### PIDF\_IRSR

Address: Base + offset(0x001C)

The interrupt raw status register of PID filter controller

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                           |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | R    | 0x0         | Reserved                                                                                                                                                                                              |
| 3:0  | R    | 0x0         | Interrupt raw status Interrupt raw status for each interrupt source bit0 : Sync byte error interrupt bit1 : Packet lost detected interrupt bit2 : buffer empty interrupt bit3 : buffer full interrupt |

### PIDF\_ISR

Address: Base + offset(0x0020)

The interrupt status register of PID filter controller

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                   |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | R    | 0x0         | Reserved                                                                                                                                                                                      |
| 3:0  | R    | 0x0         | Interrupt status Interrupt status for each interrupt source bit0 : Sync byte error interrupt bit1 : Packet lost detected interrupt bit2 : buffer empty interrupt bit3 : buffer full interrupt |

### PIDF\_CHID0

Address: Base + offset(0x0080)

The pid index and enable for channel 0 of PID filter controller

| Bit   | Attr        | Reset Value | Description                         |
|-------|-------------|-------------|-------------------------------------|
| 31:17 | R           | 0x0         | Reserved                            |
|       | (           | ) 7         | Channel 0 enable                    |
| 16    | RW          | 0x0         | 0:Diable to filter out channel ID 0 |
|       |             |             | 1:Enable to filter out channel ID 0 |
| 15:13 | R           | 0x0         | Reserved                            |
| 12.0  | DW          | 0.40        | Channel 0 PID value                 |
| 12:0  | 12:0 RW 0x0 | UXU         | Channel 0 PID value to filter out   |

The PID\_CHIDx register's address offset is (x\*0x4)+0x80, and the definition of register field is the same as PID\_CHID0.

### PIDF\_DR

Address: Base + offset(0x0200)

The data register of PID filter controller

| Bit  | Attr | Reset Value | Description              |
|------|------|-------------|--------------------------|
| 31:0 | RW   | 0x0         | PID Filter data register |

# 34.5 Application Notes

#### 34.5.1 Working Flow

Below is the typical data flow:



Fig. 34-2 PID-Filter data flow

Typically, PID-Filter and HS-ADC use hardware-handshake mechanism to transact with DMA.

When start to receiver TS from demodulator, user should follow the below sequence:

- a. Start DMA to wait for hardware request
- b. Start PID-Filter to wait for data from HS-ADC
- c. Start HS-ADC to receiving

When stop to receiver TS from demodulator, user should follow the below sequence:

- a. StopHS-ADC
- b. Stop DMA
- c. Stop PID-Filter

#### 34.5.2 About internal buffer access

The internal ping-pong buffer in PID-Filter cannot be random accessed. User can only accessed the buffer through the register entrance (PIDF\_BASE +PIDF\_DR) in a particular sequence.

#### 34.5.3 Recommendation

It's recommended to soft reset the PID-Filter controller before restart PID-Filter working.



### 35.1 Overview

The serial peripheral interface is an APB slave device. A four-wire, full-duplex serial protocol from Motorola. There are four possible combinations for the serial clock phase and polarity. The clock phase (SCPH) determines whether the serial transfer begins with the falling edge of slave select signals or the first edge of the serial clock. The slave select line is held high when the SPI is idle or disabled. This SPI controller can work as either master or slave mode.

- Support Motorola SPI,TI Synchronous Serial Protocol and National Semiconductor Microwire interface
- Support 32-bit APB bus
- Support two internal 16-bit wide and 32-location deep FIFOs, one for transmitting and the other for receiving serial data
- Support two chip select signals in master mode
- Support 4,8,16 bit serial data transfer
- Support configurable interrupt polarity
- Support asynchronous APB bus and SPI clock
- Support master and slave mode
- Support DMA handshake interface and configurable DMA water level
- Support transmit FIFO empty, underflow, receive FIFO full, overflow, underflow interrupt and all interrupts can be masked
- Support configurable water level of transmit FIFO empty and receive FIFO full interrupt
- Support combine interrupt output
- Support up to half of SPI clock frequency transfer in master mode and one sixth of SPI clock frequency transfer in slave mode
- Support full and half duplex mode transfer
- Stop transmitting SCLK if transmit FIFO is empty or receive FIFO is full in master mode
- Support configurable delay from chip select active to SCLK active in master mode
- Support configurable period of chip select inactive between two parallel data in master mode
- Support big and little endian, MSB and LSB first transfer
- Support two 8-bit audio data store together in one 16-bit wide location
- Support sample RXD 0~3 SPI clock cycles later
- Support configurable SCLK polarity and phase
- Support fix and incremental address access to transmit and receive FIFO

# 35.2 Block Diagram

The SPI 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. 35-1SPI 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 8, 16, and 32 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 serialdevice into the SPI is pushed into the receive FIFO. Both fifos are 32x16bits.

#### **FSM CONTROL**

Control the state's transformation of the design.

#### REGISTER BLOCK

All registers in the SPI are addressed at 32-bit boundaries to remain consistent with the AHB 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 bemasked. The combined interrupt request is the ORed result of all other SPI interrupts after masking.



# 35.3 Function description



Fig. 35-2SPI Master & Slave Interconnection

The SPI controller support dynamic switching between master and slave in a system. The diagram show how the SPI controller connects with other SPI devices.

#### Operation Modes

The SPI can be configured in the following two fundamental modes of operation: Master Mode when SPI\_CTRLR0 [20] is 1'b0, Slave Mode when SPI\_CTRLR0 [20] is 1'b1.

#### **Transfer Modes**

The SPI operates in the following three modes when transferring data on the serial bus:

#### 1.Transmit and Receive:

When SPI\_CTRLR0 [19:18] = 2'b00, both transmit and receive logic are valid.

### 2.Transmit Only:

When SPI CTRLR0 [19:18] = 2'b01, the receive data are invalid and should not be stored in the receive FIFO.

#### 3. Receive Only:

When SPI\_CTRLR0 [19:18]= 2'b10, the transmit data are invalid.

#### **Clock Ratios**

A summary of the frequency ratio restrictions between the bit-rate clock (sclk\_out/sclk\_in) and the SPI peripheral clock (spi\_clk) are described as:

Master:  $F_{spi\_clk} >= 2 \times (maximum F_{sclk\_out})$ Slave:  $F_{spi\_clk} >= 6 \times (maximum F_{sclk\_in})$ 

With the SPI, the clock polarity (SCPOL) configuration parameter determines whether the inactive state of the serial clock is high or low. To transmit data, both SPI peripherals must have identical serial clock phase (SCPH) and clock polarity (SCPOL) values. The data frame can be 4/8/16 bits in length.

When the configuration parameter SCPH = 0, data transmission begins on the falling edge of the slave select signal. The first data bit is captured by the master and slave peripherals on the first edge of the serial clock; therefore, valid data must be present on the txd and rxd lines prior to the first serial clock edge. Fig.35-3 and Fig.35-4 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. 35-3 SPI Format (SCPH=0 SCPOL=0)



Fig. 35-4SPI Format (SCPH=0 SCPOL=1)

When the configuration parameter SCPH = 1, both master and slave peripherals begin transmitting data on the first serial clock edge after the slave select line is activated. The first data bit is captured on the second (trailing) serial clock edge. Data are propagated by the master and slave peripherals on the leading edge of the serial clock. During continuous data frame transfers, the slave select line may be held active-low until the last bit of the last frame has been captured. Fig.35-5 and Fig.35-6 show the timing diagram for the SPI format when the configuration parameter SCPH = 1.



Fig. 35-6SPI Format (SCPH=1 SCPOL=1)

# 35.4 Register description

This section describes the control/status registers of the design. Pay attention that there are two SPI controllers in the chip: spi0 & spi1, so the base address in the following register descriptions can be either spi0 or spi1 base address.



### 35.4.1 Registers Summary

| Name        | Offset        | Size | Reset value | Description                      |
|-------------|---------------|------|-------------|----------------------------------|
| SPI_CTRLR0  | 0x0000        | W    | 0x2         | Control Register 0               |
| SPI_CTRLR1  | 0x0004        | W    | 0x0         | Control Register 1               |
| SPI_ENR     | 0x0008        | W    | 0x0         | SPI Enable Register              |
| SPI_SER     | 0x000C        | W    | 0x0         | Slave Enable Register            |
| SPI_BAUDR   | 0x0010        | W    | 0x0         | Baud Rate Select                 |
| SPI_TXFTLR  | 0x0014        | W    | 0x0         | Transmit FIFO Threshold Level    |
| SPI_RXFTLR  | 0x0018        | W    | 0x0         | Receive FIFO Threshold Level     |
| SPI_TXFLR   | 0x001C        | W    | 0x0         | Transmit FIFO Level<br>Register  |
| SPI_RXFLR   | 0x0020        | W    | 0x0         | Receive FIFO Level Register      |
| SPI_SR      | 0x0024        | W    | 0xC         | Status Register                  |
| SPI_IPR     | 0x0028        | W    | 0x0         | Interrupt Polarity Register      |
| SPI_IMR     | 0x002C        | W    | 0x0         | Interrupt Mask Register          |
| SPI_ISR     | 0x0030        | W    | 0x0         | Interrupt Status Register        |
| SPI_RISR    | 0x0034        | W    | 0x1         | Raw Interrupt Status<br>Register |
| SPI_ICR     | 0x0038        | W    | 0x0         | Interrupt Clear Register         |
| SPI_DMACR   | 0x003C        | W    | 0x0         | DMA Control Register             |
| SPI_DMATDLR | 0x0040        | W    | 0x0         | DMA Transmit Data Level          |
| SPI_DMARDLR | 0x0044        | W    | 0x0         | DMA Receive Data Level           |
| SPI_TXDR    | 0x0400~0x07FC | W    | 0x0         | Transmit FIFO Data<br>Register   |
| SPI_RXDR    | 0x0800~0x0BFC | W    | 0x0         | Receive FIFO Data Register       |

Notes:

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

# 35.4.2 Detail Register Description

# SPI\_CTRLR0

Address: Operational Base + offset(0x00)

Control register 0

| Bit   | Attr  | Reset Value | Description                                                                                                                                        |
|-------|-------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | - ( ) | -           | Reserved.                                                                                                                                          |
| 21    | RW    | 0x0         | Microwire Transfer Mode.  Valid when frame format is set to National Semiconductors Microwire.  0: non-sequential transfer  1: sequential transfer |
| 20    | RW    | 0X0         | Operation Mode. 0 Master Mode 1 Slave Mode                                                                                                         |
| 19:18 | RW    | 0X0         | Transfer Mode. 00 :Transmit & Receive 01 : Transmit Only 10 : Receive Only 11 :reserved                                                            |
| 17:16 | RW    | 0X0         | Frame Format. 00: Motorola SPI                                                                                                                     |



| 10: Texas Instruments SSP 10: National Semiconductors Microwire 11: Reserved Rxd Sample Delay, When SPI is configured as a master, if the rxd data cannot be sampled by the scik, 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. 00:do not delay 01:1 cycle delay 11:3 cycles delay 11:4 cycles delay 11:4 cycles delay 11:4 cycles delay 11:5 cycles delay 1 |       |      |      |                                                          |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|------|----------------------------------------------------------|
| 11: Reserved Rxd Sample Delay. 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. 00:do not delay 01:1 cycle delay 10:2 cycles delay 11:3 cycles delay 11:3 cycles delay 11:3 cycles delay 11:3 cycles delay 11:4 cycles delay 11:5 cycles delay 11:6 cycles delay 11:7 cycles delay 11:8 cycles delay 11:9 cycles delay 12:9 cycles delay 13:9 cycles delay 14:9 cycles delay 15:1 cycles delay 16:9 cycles delay 17:9 cycles delay 18:9 delay 19:8 cycles delay 19:9 cycles delay 19:10:2 cycles delay 19:2 cycles dela |       |      |      | 01: Texas Instruments SSP                                |
| Rxd Sample Delay. 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.  00:do not delay 01:1 cycle delay 10:2 cycles delay 11:3 cycles delay 11:4 cycle delay 12:4 cycle delay 13:4 cycle delay 14:4 cycle delay 15:4 cycle delay 15:4 cycle delay 16:4 cycle d |       |      |      | 10: National Semiconductors Microwire                    |
| Rxd Sample Delay. 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.  00:do not delay 01:1 cycle delay 10:2 cycles delay 11:3 cycles delay 11:4 cycle delay 12:4 cycle delay 13:4 cycle delay 14:4 cycle delay 15:4 cycle delay 15:4 cycle delay 16:4 cycle d |       |      |      | 11: Reserved                                             |
| 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.  00:do not delay 01:1 cycle delay 10:2 cycles delay 11:3 cycles delay 12:4 cycles delay 13:4 cycles delay 14:4 cycles delay 15:5 cycles delay 15:5 cycles delay 16:5 cycles delay 17:5 cycles delay 18:5 cycles delay 19:6 cycles delay 19:6 cycles delay 10:6 cycles delay 10:7 cycles delay 10:7 cycles delay 10:8 cycles delay 10:2 cycles delay 11:3 cycles delay 12:3 cycles delay 12:3 cycles delay 13:2 cycles delay 13:2 cycles delay 13:2 cycles delay 11:3 cycles delay 12:2 cycles delay 13:2 cycles delay 13:2 cycles delay 15:2 cycles delay 15:2 cycles delay 16:2 cycles delay 16:2 cycles delay 16:2 cycles delay 16:2 c |       |      |      |                                                          |
| 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, 00:do not delay 01:1 cycle delay 10:2 cycles delay 11:3 cycles 11:3 cycles delay 11:3 cycles delay 11:3 cycles delay 11:3 cycles |       |      |      |                                                          |
| 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.  00:do not delay 10:2 cycles delay 11:3 cycles delay 12:4 cycles delay 13:4 cycles delay 14:4 cycles delay 15:4 cycles delay 15:4 cycles delay 16:4 cycles delay 17:4 cycles delay 18:4 cycles delay 19:5 cycles delay 19:6 cycles delay 19:6 cycles delay 19:6 cycles delay 19:7 cycles delay 19:8 cycles delay 1 |       |      |      |                                                          |
| 15:14 RW 0X0 edge to sample rxd data later when SPI works at high frequency. 00:do not delay 01:1 cycle delay 10:2 cycles delay 11:3 cycle |       |      |      | , , ,                                                    |
| 15:14 RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |      |      |                                                          |
| frequency.  00:do not delay  01:1 cycle delay  10:2 cycles delay  10:2 cycles delay  11:3 cycles delay  Byte and Halfword Transform.  Valid when data frame size is 8bit.  0:apb 16bit write/read, spi 8bit write/read  1: apb 8bit write/read, spi 8bit write/read  First Bit Mode.  0:first bit is MSB  1:first bit is LSB  Endian Mode  Serial endian mode can be configured by this bit. Apb endian mode is always little endian.  0:little endian  1:big endian  SS_I to Sclk_out delay  Valid when the frame format is set to Motorola SPI and SPI used as a master.  0: the period between ss_n active and sclk_out active is half sclk_out cycles.  1: the period between ss_n active and sclk_out active is one sclk_out cycle.  Chip Select Mode.  Valid when the frame format is set to Motorola SPI and SPI used as a master.  00: ss_n keep low after every frame data is transferred.  01:ss_n be high for half sclk_out cycles after every frame data is transferred.  10: ss_n be high for one sclk_out cycle after every frame data is transferred.  10: ss_n be high for one sclk_out cycle after every frame data is transferred.  11:reserved  Serial Clock Polarity.  Valid when the frame format is set to Motorola SPI.  0 - Inactive state of serial clock is low  1 - Inactive state of serial clock is high  Serial Clock Phase.  Valid when the frame format is set to Motorola SPI.  0 - Serial clock toggles in middle of first data bit  1 - Serial clock toggles at start of first data bit  1 - Serial clock toggles at start of first data bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       | D.M. | 0)/0 |                                                          |
| 13   RW   0X0   Byte and Halfword Transform   Valid when data frame size is 8bit.   0:apb 16bit write/read, spi 8bit write/read   1: apb 8bit 8bit write/read   1: first bit is MSB   1: first bit is LSB   1: first bit is Apb   2: apb 40   2: ap   | 15:14 | RW   | UXU  |                                                          |
| 13 RW 0X0 Byte and Halfword Transform Valid when data frame size is 8bit. 0:apb 16bit write/read, spi 8bit write/read 1: apb 8bit write/read, spi 8bit write/read 1: first bit is LSB 1: big endian 1: |       |      |      |                                                          |
| 10:2 cycles delay 11:3 cycles delay 12 Byte and Halfword Transform Valid when data frame size is 8bit. 0:apb 16bit write/read, spi 8bit write/read 1: apb 8bit 8bit write/read 1: first bit is MSB 1: first bit is MSB 1: first bit is MSB 1: first bit is LSB 1 |       |      |      | ,                                                        |
| 11:3 cycles delay Byte and Halfword Transform Valid when data frame size is 8bit. 0:apb 16bit write/read, spi 8bit write/read 1: apb 8bit write/read, spi 8bit write/read First Bit Mode. 0:first bit is MSB 1:first bit is LSB Endian Mode Serial endian mode can be configured by this bit. Apb endian mode is always little endian. 0:little endian 1:big endian  SS_n to sclk_out delay Valid when the frame format is set to Motorola SPI and SPI used as a master. 0: the period between ss_n active and sclk_out active is half sclk_out cycles. 1: the period between ss_n active and sclk_out active is one sclk_out cycle.  Chip Select Mode. Valid when the frame format is set to Motorola SPI and SPI used as a master. 00: ss_n keep low after every frame data is transferred. 10: ss_n be high for half sclk_out cycles after every frame data is transferred. 10: ss_n be high for one sclk_out cycle after every frame data is transferred. 11:reserved  Serial Clock Polarity. Valid when the frame format is set to Motorola SPI. 0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high Serial Clock pogles in middle of first data bit 1 - Serial clock toggles in middle of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |      |      |                                                          |
| Byte and Halfword Transform                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |      |      | · · · · · · · · · · · · · · · · · · ·                    |
| RW 0x0 Valid when data frame size is 8bit. 0:apb 16bit write/read, spi 8bit write/read 1: apb 8bit write/read, spi 8bit write/read First Bit Mode. 0:first bit is MSB 1:first bit is LSB Endian Mode Serial endian mode can be configured by this bit. Apb endian mode is always little endian. 0:little endian 1:big endian ss_n to sclk_out delay Valid when the frame format is set to Motorola SPI and SPI used as a master. 0: the period between ss_n active and sclk_out active is half sclk, out cycles. 1: the period between ss_n active and sclk_out active is one sclk_out cycle. Chip Select Mode. Valid when the frame format is set to Motorola SPI and SPI used as a master. 00: ss_n keep low after every frame data is transferred. 10: ss_n be high for half sclk_out cycles after every frame data is transferred. 10: ss_n be high for one sclk_out cycle after every frame data is transferred. 11:reserved  7 RW 0x0 Serial Clock Polarity. Valid when the frame format is set to Motorola SPI. 0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high Serial Clock Phase. Valid when the frame format is set to Motorola SPI. 0 - Serial clock toggles in middle of first data bit 1 - Serial clock toggles in middle of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |      |      | 11:3 cycles delay                                        |
| 12 RW 0X0 0:apb 16bit write/read, spi 8bit write/read 1: apb 8bit write/read, spi 8bit write/read 11: spi 8bit write/read, spi 8bit write/read 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |      |      | Byte and Halfword Transform                              |
| 1: apb 16bit write/read, spi 8bit write/read 1: apb 8bit write/read, spi 8bit write/read First Bit Mode. 0:first bit is MSB 1:first bit is LSB Endian Mode Serial endian mode can be configured by this bit. Apb endian mode is always little endian. 0:little endian 1:big endian ss_n to sclk_out delay Valid when the frame format is set to Motorola SPI and SPI used as a master. 0: the period between ss_n active and sclk_out active is half sclk_out cycles. 1: the period between ss_n active and sclk_out active is one sclk_out cycles. Chip Select Mode. Valid when the frame format is set to Motorola SPI and SPI used as a master. 00: ss_n keep low after every frame data is transferred. 10: ss_n be high for half sclk_out cycles after every frame data is transferred. 10: ss_n be high for one sclk_out cycle after every frame data is transferred. 11:reserved Serial Clock Polarity. Valid when the frame format is set to Motorola SPI. 0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high Serial Clock Phase. Valid when the frame format is set to Motorola SPI. 0 - Serial clock toggles in middle of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock togg | 1,2   | DW   | 0)/0 | Valid when data frame size is 8bit.                      |
| 1: apb 8bit write/read, spi 8bit write/read First Bit Mode. 0: first bit is MSB 1: first bit is LSB Endian Mode Serial endian mode can be configured by this bit. Apb endian mode is always little endian. 0: little endian 1: big endian 1: big endian  ss_n to sclk_out delay Valid when the frame format is set to Motorola SPI and SPI used as a master. 0: the period between ss_n active and sclk_out active is half sclk_out cycles. 1: the period between ss_n active and sclk_out active is one sclk_out cycle. Chip Select Mode. Valid when the frame format is set to Motorola SPI and SPI used as a master. 00: ss_n keep low after every frame data is transferred. 01: ss_n be high for half sclk_out cycles after every frame data is transferred. 10: ss_n be high for one sclk_out cycle after every frame data is transferred. 11: reserved  Serial Clock Polarity. Valid when the frame format is set to Motorola SPI. 0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high  Serial Clock Phase. Valid when the frame format is set to Motorola SPI. 0 - Serial clock toggles in middle of first data bit 1- Serial clock toggles at start of first data bit 1- Serial clock toggles at start of first data bit 1- Serial clock toggles at start of first data bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 13    | RW   | UXU  | 0:apb 16bit write/read, spi 8bit write/read              |
| First Bit Mode.  0:first bit is MSB 1:first bit is MSB Endian Mode Serial endian mode can be configured by this bit. Apb endian mode is always little endian. 0:little endian 1:big endian ss_n to sclk_out delay Valid when the frame format is set to Motorola SPI and SPI used as a master. 0: the period between ss_n active and sclk_out active is half sclk_out cycles. 1: the period between ss_n active and sclk_out active is one sclk_out cycles. 1: the period between ss_n active and sclk_out active is one sclk_out cycle. Chip Select Mode. Valid when the frame format is set to Motorola SPI and SPI used as a master. 00: ss_n keep low after every frame data is transferred. 01: ss_n be high for half sclk_out cycles after every frame data is transferred. 10: ss_n be high for one sclk_out cycle after every frame data is transferred. 11:reserved  Serial Clock Polarity. Valid when the frame format is set to Motorola SPI. 0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high Serial Clock Phase. Valid when the frame format is set to Motorola SPI. 0 - Serial clock toggles in middle of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at sta |       |      |      |                                                          |
| 12 RW 0X0 1:first bit is LSB Endian Mode Serial endian mode can be configured by this bit. Apb endian mode is always little endian. 0:little endian 1:big endian 1:big endian Ss_n to sclk_out delay Valid when the frame format is set to Motorola SPI and SPI used as a master. 0: the period between ss_n active and sclk_out active is half sclk_out cycles. 1: the period between ss_n active and sclk_out active is one sclk_out cycle.  Chip Select Mode. Valid when the frame format is set to Motorola SPI and SPI used as a master. 00: ss_n keep low after every frame data is transferred. 01:ss_n be high for half sclk_out cycles after every frame data is transferred. 10: ss_n be high for one sclk_out cycle after every frame data is transferred. 10: ss_n be high for one sclk_out cycle after every frame data is transferred. 11:reserved  Serial Clock Polarity. Valid when the frame format is set to Motorola SPI. 0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high  Serial Clock Phase. Valid when the frame format is set to Motorola SPI. 0 - Serial clock toggles in middle of first data bit 1- Serial clock toggles at start of first data bit 1- Serial clock toggles at start of first data bit Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |      |      |                                                          |
| 1:first bit is LSB Endian Mode Serial endian mode can be configured by this bit. Apb endian mode is always little endian. 0:little endian 1:big endian 1:big endian 1:big endian 1:big endian 1:big endian  SS_n to sclk_out delay Valid when the frame format is set to Motorola SPI and SPI used as a master.  10 RW 0X0 0: the period between ss_n active and sclk_out active is half sclk_out cycles. 1: the period between ss_n active and sclk_out active is one sclk_out cycle.  Chip Select Mode. Valid when the frame format is set to Motorola SPI and SPI used as a master. 00: ss_n keep low after every frame data is transferred. 01:ss_n be high for half sclk_out cycles after every frame data is transferred. 10: ss_n be high for one sclk_out cycle after every frame data is transferred. 11:reserved  Serial Clock Polarity.  Valid when the frame format is set to Motorola SPI. 0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high  Serial Clock Phase. Valid when the frame format is set to Motorola SPI. 0 - Serial clock toggles in middle of first data bit 1- Serial clock toggles at start of first data bit 1- Serial clock toggles at start of first data bit 1- Serial clock toggles at start of first data bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 12    | RW   | oxo  |                                                          |
| Endian Mode Serial endian mode can be configured by this bit. Apb endian mode is always little endian. 0:little endian 1:big endian 1:b |       |      |      |                                                          |
| Serial endian mode can be configured by this bit. Apb endian mode is always little endian.  0:little endian 1:big endian 1:big endian  ss_n to sclk_out delay Valid when the frame format is set to Motorola SPI and SPI used as a master. 0: the period between ss_n active and sclk_out active is half sclk_out cycles. 1: the period between ss_n active and sclk_out active is one sclk_out cycle.  Chip Select Mode. Valid when the frame format is set to Motorola SPI and SPI used as a master. 00: ss_n keep low after every frame data is transferred. 01:ss_n be high for half sclk_out cycles after every frame data is transferred. 10: ss_n be high for one sclk_out cycle after every frame data is transferred. 11:reserved  Serial Clock Polarity. Valid when the frame format is set to Motorola SPI. 0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high  Serial Clock Phase. Valid when the frame format is set to Motorola SPI. 0 - Serial clock toggles in middle of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |      |      |                                                          |
| 11 RW 0X0 endian mode is always little endian. 0:little endian 1:big endian 1:big endian  ss_n to sclk_out delay Valid when the frame format is set to Motorola SPI and SPI used as a master. 0: the period between ss_n active and sclk_out active is half sclk_out cycles. 1: the period between ss_n active and sclk_out active is one sclk_out cycle.  Chip Select Mode. Valid when the frame format is set to Motorola SPI and SPI used as a master. 00: ss_n keep low after every frame data is transferred. 01:ss_n be high for half sclk_out cycles after every frame data is transferred. 10: ss_n be high for one sclk_out cycle after every frame data is transferred. 11:reserved  Serial Clock Polarity. Valid when the frame format is set to Motorola SPI. 0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high  Serial Clock Phase. Valid when the frame format is set to Motorola SPI. 0 - Serial clock toggles in middle of first data bit 1 - Serial clock toggles at start of first data bit Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |      |      |                                                          |
| 0:little endian 1:big endian 1:big endian  ss_n to sclk_out delay Valid when the frame format is set to Motorola SPI and SPI used as a master. 0: the period between ss_n active and sclk_out active is half sclk_out cycles. 1: the period between ss_n active and sclk_out active is one sclk_out cycle. Chip Select Mode. Valid when the frame format is set to Motorola SPI and SPI used as a master. 00: ss_n keep low after every frame data is transferred. 01:ss_n be high for half sclk_out cycles after every frame data is transferred. 10: ss_n be high for one sclk_out cycle after every frame data is transferred. 11:reserved  Serial Clock Polarity. Valid when the frame format is set to Motorola SPI. 0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high  Serial Clock Phase. Valid when the frame format is set to Motorola SPI. 0 - Serial clock toggles in middle of first data bit 1 - Serial clock toggles at start of first data bit Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 11    | DW   | 0.00 |                                                          |
| 1:big endian  ss_n to sclk_out delay Valid when the frame format is set to Motorola SPI and SPI used as a master.  0: the period between ss_n active and sclk_out active is half sclk_out cycles. 1: the period between ss_n active and sclk_out active is one sclk_out cycle.  Chip Select Mode. Valid when the frame format is set to Motorola SPI and SPI used as a master.  00: ss_n keep low after every frame data is transferred. 01:ss_n be high for half sclk_out cycles after every frame data is transferred. 10: ss_n be high for one sclk_out cycle after every frame data is transferred.  11:reserved  Serial Clock Polarity. Valid when the frame format is set to Motorola SPI. 0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high  Serial Clock Phase. Valid when the frame format is set to Motorola SPI. 0 -Serial clock toggles in middle of first data bit 1- Serial clock toggles at start of first data bit 1- Serial clock toggles at start of first data bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 11    | KVV  | UXU  |                                                          |
| ss_n to sclk_out delay Valid when the frame format is set to Motorola SPI and SPI used as a master. 0: the period between ss_n active and sclk_out active is half sclk_out cycles. 1: the period between ss_n active and sclk_out active is one sclk_out cycle. Chip Select Mode. Valid when the frame format is set to Motorola SPI and SPI used as a master. 00: ss_n keep low after every frame data is transferred. 01:ss_n be high for half sclk_out cycles after every frame data is transferred. 10: ss_n be high for one sclk_out cycle after every frame data is transferred. 11:reserved  Serial Clock Polarity. Valid when the frame format is set to Motorola SPI. 0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high  Serial Clock Phase. Valid when the frame format is set to Motorola SPI. 0 - Serial clock toggles in middle of first data bit 1 - Serial clock toggles at start of first data bit 1 - Serial clock toggles at start of first data bit Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |      |      |                                                          |
| Valid when the frame format is set to Motorola SPI and SPI used as a master.  0: the period between ss_n active and sclk_out active is half sclk_out cycles.  1: the period between ss_n active and sclk_out active is one sclk_out cycle.  Chip Select Mode.  Valid when the frame format is set to Motorola SPI and SPI used as a master.  00: ss_n keep low after every frame data is transferred.  01:ss_n be high for half sclk_out cycles after every frame data is transferred.  10: ss_n be high for one sclk_out cycle after every frame data is transferred.  11:reserved  Serial Clock Polarity.  Valid when the frame format is set to Motorola SPI.  0 - Inactive state of serial clock is low  1 - Inactive state of serial clock is high  Serial Clock Phase.  Valid when the frame format is set to Motorola SPI.  0 - Serial clock toggles in middle of first data bit  1 - Serial clock toggles at start of first data bit  Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |      |      |                                                          |
| SPI used as a master.  0: the period between ss_n active and sclk_out active is half sclk_out cycles.  1: the period between ss_n active and sclk_out active is one sclk_out cycle.  Chip Select Mode.  Valid when the frame format is set to Motorola SPI and SPI used as a master.  00: ss_n keep low after every frame data is transferred.  01:ss_n be high for half sclk_out cycles after every frame data is transferred.  10: ss_n be high for one sclk_out cycle after every frame data is transferred.  11:reserved  Serial Clock Polarity.  Valid when the frame format is set to Motorola SPI.  0 - Inactive state of serial clock is low  1 - Inactive state of serial clock is high  Serial Clock Phase.  Valid when the frame format is set to Motorola SPI.  0 - Serial clock toggles in middle of first data bit  1 - Serial clock toggles at start of first data bit  Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |      |      |                                                          |
| 10 RW 0X0 0: the period between ss_n active and sclk_out active is half sclk_out cycles.  1: the period between ss_n active and sclk_out active is one sclk_out cycle.  Chip Select Mode. Valid when the frame format is set to Motorola SPI and SPI used as a master.  00: ss_n keep low after every frame data is transferred. 01:ss_n be high for half sclk_out cycles after every frame data is transferred. 10: ss_n be high for one sclk_out cycle after every frame data is transferred. 11:reserved  Serial Clock Polarity. Valid when the frame format is set to Motorola SPI. 0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high  Serial Clock Phase. Valid when the frame format is set to Motorola SPI. 0 - Serial clock toggles in middle of first data bit 1 - Serial clock toggles at start of first data bit Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |      |      |                                                          |
| is half sclk_out cycles.  1: the period between ss_n active and sclk_out active is one sclk_out cycle.  Chip Select Mode. Valid when the frame format is set to Motorola SPI and SPI used as a master. 00: ss_n keep low after every frame data is transferred. 01:ss_n be high for half sclk_out cycles after every frame data is transferred. 10: ss_n be high for one sclk_out cycle after every frame data is transferred. 11:reserved  Serial Clock Polarity. Valid when the frame format is set to Motorola SPI. 0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high  Serial Clock Phase. Valid when the frame format is set to Motorola SPI. 0 - Serial clock toggles in middle of first data bit 1 - Serial clock toggles at start of first data bit Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |      |      |                                                          |
| 1: the period between ss_n active and sclk_out active is one sclk_out cycle.  Chip Select Mode. Valid when the frame format is set to Motorola SPI and SPI used as a master. 00: ss_n keep low after every frame data is transferred. 01:ss_n be high for half sclk_out cycles after every frame data is transferred. 10: ss_n be high for one sclk_out cycle after every frame data is transferred. 11:reserved  Serial Clock Polarity. Valid when the frame format is set to Motorola SPI. 0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high  Serial Clock Phase. Valid when the frame format is set to Motorola SPI. 0 - Serial clock toggles in middle of first data bit 1 - Serial clock toggles at start of first data bit Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 10    | RW   | 0X0  |                                                          |
| is one sclk_out cycle.  Chip Select Mode. Valid when the frame format is set to Motorola SPI and SPI used as a master. 00: ss_n keep low after every frame data is transferred. 01:ss_n be high for half sclk_out cycles after every frame data is transferred. 10: ss_n be high for one sclk_out cycle after every frame data is transferred. 11:reserved  Serial Clock Polarity. Valid when the frame format is set to Motorola SPI. 0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high  Serial Clock Phase. Valid when the frame format is set to Motorola SPI. 0 - Serial clock toggles in middle of first data bit 1 - Serial clock toggles at start of first data bit  Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |      |      | <u> </u>                                                 |
| Chip Select Mode. Valid when the frame format is set to Motorola SPI and SPI used as a master. 00: ss_n keep low after every frame data is transferred. 01:ss_n be high for half sclk_out cycles after every frame data is transferred. 10: ss_n be high for one sclk_out cycle after every frame data is transferred. 11:reserved  Serial Clock Polarity. Valid when the frame format is set to Motorola SPI. 0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high  Serial Clock Phase. Valid when the frame format is set to Motorola SPI. 0 - Serial clock toggles in middle of first data bit 1 - Serial clock toggles at start of first data bit Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |      | • 0  | 1: the period between ss_n active and sclk_out active    |
| Valid when the frame format is set to Motorola SPI and SPI used as a master.  00: ss_n keep low after every frame data is transferred.  01:ss_n be high for half sclk_out cycles after every frame data is transferred.  10: ss_n be high for one sclk_out cycle after every frame data is transferred.  11:reserved  Serial Clock Polarity.  Valid when the frame format is set to Motorola SPI.  0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high  Serial Clock Phase.  Valid when the frame format is set to Motorola SPI.  0 -Serial clock toggles in middle of first data bit 1 - Serial clock toggles at start of first data bit  Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |      |      | is one sclk_out cycle.                                   |
| Valid when the frame format is set to Motorola SPI and SPI used as a master.  00: ss_n keep low after every frame data is transferred.  01:ss_n be high for half sclk_out cycles after every frame data is transferred.  10: ss_n be high for one sclk_out cycle after every frame data is transferred.  11:reserved  Serial Clock Polarity.  Valid when the frame format is set to Motorola SPI.  0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high  Serial Clock Phase.  Valid when the frame format is set to Motorola SPI.  0 -Serial clock toggles in middle of first data bit 1 - Serial clock toggles at start of first data bit  Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |      |      |                                                          |
| SPI used as a master.  00: ss_n keep low after every frame data is transferred.  01:ss_n be high for half sclk_out cycles after every frame data is transferred.  10: ss_n be high for one sclk_out cycle after every frame data is transferred.  11:reserved  Serial Clock Polarity.  Valid when the frame format is set to Motorola SPI.  0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high  Serial Clock Phase.  Valid when the frame format is set to Motorola SPI.  0 - Serial clock toggles in middle of first data bit 1 - Serial clock toggles at start of first data bit  Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |      | A Y  |                                                          |
| 9:8 RW 0X0 transferred. 01:ss_n be high for half sclk_out cycles after every frame data is transferred. 10: ss_n be high for one sclk_out cycle after every frame data is transferred. 11:reserved  Serial Clock Polarity. Valid when the frame format is set to Motorola SPI. 0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high  Serial Clock Phase. Valid when the frame format is set to Motorola SPI. 0 - Serial clock toggles in middle of first data bit 1 - Serial clock toggles at start of first data bit  Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |      |      |                                                          |
| 9:8 RW 0X0 transferred. 01:ss_n be high for half sclk_out cycles after every frame data is transferred. 10: ss_n be high for one sclk_out cycle after every frame data is transferred. 11:reserved  Serial Clock Polarity. Valid when the frame format is set to Motorola SPI. 0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high  Serial Clock Phase. Valid when the frame format is set to Motorola SPI. 0 - Serial clock toggles in middle of first data bit 1 - Serial clock toggles at start of first data bit  Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       | 11   |      |                                                          |
| 9:8  RW  OXO  O1:ss_n be high for half sclk_out cycles after every frame data is transferred.  10: ss_n be high for one sclk_out cycle after every frame data is transferred.  11:reserved  Serial Clock Polarity.  Valid when the frame format is set to Motorola SPI.  0 - Inactive state of serial clock is low  1 - Inactive state of serial clock is high  Serial Clock Phase.  Valid when the frame format is set to Motorola SPI.  0 - Serial clock toggles in middle of first data bit  1 - Serial clock toggles at start of first data bit  Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       | - N  | 7    | <u> </u>                                                 |
| frame data is transferred.  10: ss_n be high for one sclk_out cycle after every frame data is transferred.  11:reserved  Serial Clock Polarity.  Valid when the frame format is set to Motorola SPI.  0 - Inactive state of serial clock is low  1 - Inactive state of serial clock is high  Serial Clock Phase.  Valid when the frame format is set to Motorola SPI.  0 -Serial clock toggles in middle of first data bit  1 - Serial clock toggles at start of first data bit  Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 9:8   | RW   | UXO  |                                                          |
| 10: ss_n be high for one sclk_out cycle after every frame data is transferred. 11:reserved  Serial Clock Polarity. Valid when the frame format is set to Motorola SPI. 0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high  Serial Clock Phase. Valid when the frame format is set to Motorola SPI. 0 - Serial clock toggles in middle of first data bit 1 - Serial clock toggles at start of first data bit  Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |      |      |                                                          |
| frame data is transferred.  11:reserved  Serial Clock Polarity.  Valid when the frame format is set to Motorola SPI.  0 - Inactive state of serial clock is low  1 - Inactive state of serial clock is high  Serial Clock Phase.  Valid when the frame format is set to Motorola SPI.  0 - Serial clock toggles in middle of first data bit  1 - Serial clock toggles at start of first data bit  Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |      |      |                                                          |
| 7 RW 0X0 Serial Clock Polarity. Valid when the frame format is set to Motorola SPI. 0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high Serial Clock Phase. Valid when the frame format is set to Motorola SPI. 0 - Serial clock toggles in middle of first data bit 1 - Serial clock toggles at start of first data bit Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       | r    |      |                                                          |
| From the first data bit  RW  OX0  Serial Clock Polarity. Valid when the frame format is set to Motorola SPI. 0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high  Serial Clock Phase. Valid when the frame format is set to Motorola SPI. 0 - Serial clock toggles in middle of first data bit 1 - Serial clock toggles at start of first data bit  Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 7     |      |      |                                                          |
| 7 RW 0X0 Valid when the frame format is set to Motorola SPI. 0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high  Serial Clock Phase. Valid when the frame format is set to Motorola SPI. 0 -Serial clock toggles in middle of first data bit 1- Serial clock toggles at start of first data bit  Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | -     |      |      |                                                          |
| 0 - Inactive state of serial clock is low 1 - Inactive state of serial clock is high  Serial Clock Phase. Valid when the frame format is set to Motorola SPI. 0 - Serial clock toggles in middle of first data bit 1 - Serial clock toggles at start of first data bit  Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |      |      | ,                                                        |
| 6 RW 0X0 Serial clock is low 1 - Inactive state of serial clock is high  Serial Clock Phase. Valid when the frame format is set to Motorola SPI. 0 - Serial clock toggles in middle of first data bit 1 - Serial clock toggles at start of first data bit  Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 7     | RW   | 0X0  |                                                          |
| Serial Clock Phase.  Valid when the frame format is set to Motorola SPI.  0 -Serial clock toggles in middle of first data bit  1- Serial clock toggles at start of first data bit  Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |      |      |                                                          |
| RW 0X0 Valid when the frame format is set to Motorola SPI. 0 -Serial clock toggles in middle of first data bit 1- Serial clock toggles at start of first data bit  Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |      |      | i                                                        |
| 0 –Serial clock toggles in middle of first data bit 1 – Serial clock toggles at start of first data bit  Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |      |      |                                                          |
| 1 – Serial clock toggles in middle of first data bit 1 – Serial clock toggles at start of first data bit  Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 6     | RW   | oxo  |                                                          |
| 5:2 RW 0X0 Control Frame Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | `     |      |      |                                                          |
| 5.7   RW   UXU                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |      |      |                                                          |
| Selects the length of the control word for the Microwire                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 5.2   | D\M  | 0.00 | Control Frame Size.                                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ٥.۷   | LVV  | 0.00 | Selects the length of the control word for the Microwire |



|     |    |     | frame format.  0000~0010:reserved  0011:4-bit serial data transfer  0100:5-bit serial data transfer  0101:6-bit serial data transfer  0110:7-bit serial data transfer  0111:8-bit serial data transfer  1000:9-bit serial data transfer  1001:10-bit serial data transfer  1010:11-bit serial data transfer  1010:13-bit serial data transfer  1101:14-bit serial data transfer  1101:15-bit serial data transfer |
|-----|----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |    |     | 1111:16-bit serial data transfer                                                                                                                                                                                                                                                                                                                                                                                  |
| 1:0 | RW | 0X2 | Data Frame Size. Selects the data frame length. 00-4bit data 01-8bit data 10-16bit data 11-reserved                                                                                                                                                                                                                                                                                                               |

# SPI\_CTRLR1

Address: Operational Base + offset( 0x04)

Control register 1

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | -    | -           | Reserved.                                                                                                                                                                                                                                                                                                                                                  |
| 15:0  | RW   | 0x0         | Number of Data Frames. 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 64 KB of data in a continuous transfer. |

# SPI\_ENR

Address: Operational Base + offset(0x08)

SPI enable register

| Bit  | Attr | Reset Value | Description                                                                                                                     |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | _)   | -           | Reserved.                                                                                                                       |
| 0    | RW   | 0x0         | SPI Enable. Enables and disables all SPI operations. Transmit and receive FIFO buffers are cleared when the device is disabled. |

# SPI\_SER

Address: Operational Base + offset(0x0C)

Slave enable register

| Bit  | Attr | Reset Value | Description                                                                                      |
|------|------|-------------|--------------------------------------------------------------------------------------------------|
| 31:2 | -    | -           | Reserved.                                                                                        |
| 1:0  | RW   | 0×0         | Slave Select Enable Flag. This register is valid only when SPI is configured as a master device. |



### SPI\_BAUDR

Address:operational base+offset(0x10)

Baud rate select

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | -    | -           | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 15:0  | RW   | 0x0         | 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: Fsclk_out = Fspi_clk/ SCKDV Where SCKDV is any even value between 2 and 65534. For example: for Fspi_clk = 3.6864MHz and SCKDV = 2 Fsclk out = 3.6864/2= 1.8432MHz |

#### SPI\_TXFTLR

Address: Operational Base + offset(0x14)

Transmit FIFO Threshold Level

| Bit  | Attr | Reset Value | Description                                                                                                                                             |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | -    | -           | Reserved.                                                                                                                                               |
| 4:0  | RW   | 0x0         | Transmit FIFO Threshold.  When the number of transmit FIFO entries is less than or equal to this value, the transmit FIFO empty interrupt is triggered. |

#### SPI\_RXFTLR

Address: Operational Base + offset(0x18)

Receive FIFO Threshold Level

| Receive 11 0 Threshold Level |       |             |                                                                                                                                                            |
|------------------------------|-------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                          | Attr  | Reset Value | Description                                                                                                                                                |
| 31:5                         | - \ 1 |             | Reserved.                                                                                                                                                  |
| 4:0                          | RW    | 0x0         | Receive FIFO Threshold.  When the number of receive FIFO entries is greater than or equal to this value + 1, the receive FIFO full interrupt is triggered. |

### SPI\_TXFLR

Address: Operational Base + offset(0x1C)

Transmit FIFO Level Register

| Bit  | Attr | Reset Value | Description                                            |
|------|------|-------------|--------------------------------------------------------|
| 31:6 | -    | -           | Reserved.                                              |
| 5:0  | R    | 0x0         | Transmit FIFO Level. Contains the number of valid data |
|      |      |             | entries in the transmit FIFO.                          |

### SPI\_RXFLR

Address: Operational Base + offset(0x20)

Receive FIFO Level Register

| 1 |     |      |             |             |
|---|-----|------|-------------|-------------|
|   | Bit | Attr | Reset Value | Description |



| 31:6 | -   | -     | Reserved.                                             |
|------|-----|-------|-------------------------------------------------------|
| F.0  | D   | ()Y() | Receive FIFO Level. Contains the number of valid data |
| 5:0  | U K |       | entries in the receive FIFO.                          |

### SPI\_SR

Address: Operational Base + offset(0x24)

Status Register

| Bit  | Attr | Reset Value | Description                                              |
|------|------|-------------|----------------------------------------------------------|
| 31:5 | -    | -           | Reserved.                                                |
|      |      |             | Receive FIFO Full.                                       |
| 4    | R    | 0x0         | 0 - Receive FIFO is not full                             |
|      |      |             | 1 – Receive FIFO is full                                 |
|      |      |             | Receive FIFO Empty.                                      |
| 3    | R    | 0x1         | 0 – Receive FIFO is not empty                            |
|      |      |             | 1 – Receive FIFO is empty                                |
|      |      |             | Transmit FIFO Empty.                                     |
| 2    | R    | 0x1         | 0 – Transmit FIFO is not empty                           |
|      |      |             | 1 – Transmit FIFO is empty                               |
|      |      |             | Transmit FIFO Full.                                      |
| 1    | R    | 0x0         | 0 - Transmit FIFO is not full                            |
|      |      |             | 1 – Transmit FIFO is full                                |
|      |      |             | SPI Busy Flag. When set, indicates that a serial         |
|      |      |             | transfer is in progress; when cleared indicates that the |
| 0    | R    | 0x0         | SPI is idle or disabled.                                 |
|      |      |             | 0 – SPI is idle or disabled                              |
|      |      |             | 1 – SPI is actively transferring data                    |

# SPI\_IPR

Address: Operational Base + offset(0x28)

Interrupt Polarity Register

| Bit  | Attr | Reset Value | Description                               |
|------|------|-------------|-------------------------------------------|
| 31:1 | -    | - \         | Reserved.                                 |
|      |      |             | Interrupt Polarity Register               |
| 0    | RW   | 0x0         | 0:Active Interrupt Polarity Level is HIGH |
|      |      |             | 1: Active Interrupt Polarity Level is LOW |

### SPI\_IMR

Address: Operational Base + offset(0x2C)
Interrupt Mask Register

| Bit  | Attr | Reset Value | Description                              |
|------|------|-------------|------------------------------------------|
| 31:5 | -    | -           | Reserved.                                |
| 7    |      |             | Receive FIFO Full Interrupt Mask         |
| 4    | RW   | 0x0         | 0 – spi_rxf_intr interrupt is masked     |
|      |      |             | 1 – spi_rxf_intr interrupt is not masked |
|      |      |             | Receive FIFO Overflow Interrupt Mask     |
| 3    | RW   | 0x0         | 0 – spi_rxo_intr interrupt is masked     |
|      |      |             | 1 – spi_rxo_intr interrupt is not masked |
|      |      |             | Receive FIFO Underflow Interrupt Mask    |
| 2    | RW   | 0x0         | 0 – spi_rxu_intr interrupt is masked     |
|      |      |             | 1 – spi_rxu_intr interrupt is not masked |
| 4    | RW   | N 00        | Transmit FIFO Overflow Interrupt Mask    |
| 7    | KVV  | 0x0         | 0 – spi_txo_intr interrupt is masked     |



|   |   |    |     | 1 – spi_txo_intr interrupt is not masked |
|---|---|----|-----|------------------------------------------|
| ſ |   |    |     | Transmit FIFO Empty Interrupt Mask       |
|   | 0 | RW | 0x0 | 0 – spi_txe_intr interrupt is masked     |
|   |   |    |     | 1 – spi_txe_intr interrupt is not masked |

# SPI\_ISR

Address: Operational Base + offset(0x30)

Interrupt Status Register

| Bit  | Attr | Reset Value | Description                                            |
|------|------|-------------|--------------------------------------------------------|
| 31:5 | -    | -           | Reserved.                                              |
|      |      |             | Receive FIFO Full Interrupt Status                     |
| 4    | R    | 0x0         | 0 = spi_rxf_intr interrupt is not active after masking |
|      |      |             | 1 = spi_rxf_intr interrupt is full after masking       |
|      |      |             | Receive FIFO Overflow Interrupt Status                 |
| 3    | R    | 0x0         | 0 = spi_rxo_intr interrupt is not active after masking |
|      |      |             | 1 = spi_rxo_intr interrupt is active after masking     |
|      |      |             | Receive FIFO Underflow Interrupt Status                |
| 2    | R    | 0x0         | 0 = spi_rxu_intr interrupt is not active after masking |
|      |      |             | 1 = spi_rxu_intr interrupt is active after masking     |
|      |      |             | Transmit FIFO Overflow Interrupt Status                |
| 1    | R    | 0x0         | 0 = spi_txo_intr interrupt is not active after masking |
|      |      |             | 1 = spi_txo_intr interrupt is active after masking     |
|      |      |             | Transmit FIFO Empty Interrupt Status                   |
| 0    | R    | 0x0         | 0 = spi_txe_intr interrupt is not active after masking |
|      |      |             | 1 = spi_txe_intr interrupt is active after masking     |

### SPI\_RISR

Address: Operational Base + offset(0x34)

Raw Interrupt Status Register

| Bit      | Attr | Reset Value | Description                                               |
|----------|------|-------------|-----------------------------------------------------------|
| 31:5     | -    | -           | Reserved.                                                 |
|          |      |             | Receive FIFO Full Raw Interrupt Status                    |
| 4        | R    | 0x0         | 0 = spi_rxf_intr interrupt is not active prior to masking |
|          |      |             | 1 = spi_rxf_intr interrupt is full prior to masking       |
|          |      |             | Receive FIFO Overflow Raw Interrupt Status                |
| 3        | R    | 0x0         | 0 = spi_rxo_intr interrupt is not active prior to         |
| ٦        | K    | UXU         | masking                                                   |
|          |      |             | 1 = spi_rxo_intr interrupt is active prior to masking     |
|          |      |             | Receive FIFO Underflow Raw Interrupt Status               |
| 2        | R    | 0x0         | 0 = spi_rxu_intr interrupt is not active prior to         |
| 2        |      | 0.00        | masking                                                   |
| <b>Y</b> |      |             | 1 = spi_rxu_intr interrupt is active prior to masking     |
|          |      |             | Transmit FIFO Overflow Raw Interrupt Status               |
| 1        | R    | 0x0         | 0 = spi_txo_intr interrupt is not active prior to masking |
|          |      |             | 1 = spi_txo_intr interrupt is active prior to masking     |
|          |      |             | Transmit FIFO Empty Raw Interrupt Status                  |
| 0        | R    | 0x1         | 0 = spi_txe_intr interrupt is not active prior to masking |
|          |      |             | 1 = spi_txe_intr interrupt is active prior to masking     |

# SPI\_ICR

Address: Operational Base + offset(0x38)

Interrupt Clear Register



| Bit  | Attr | Reset Value | Description                             |
|------|------|-------------|-----------------------------------------|
| 31:4 | -    | -           | Reserved.                               |
| 3    | W    | 0x0         | Clear Transmit FIFO Overflow Interrupt. |
| 2    | W    | 0x0         | Clear Receive FIFO Overflow Interrupt.  |
| 1    | W    | 0x0         | Clear Receive FIFO Underflow Interrupt. |
| 0    | W    | 0x0         | Clear Combined Interrupt.               |

#### SPI\_DMACR

Address: Operational Base + offset(0x3C)

DMA Control Register

| Bit  | Attr | Reset Value | Description                                                               |
|------|------|-------------|---------------------------------------------------------------------------|
| 31:2 | -    | -           | Reserved.                                                                 |
| 1    | RW   | 0x0         | Transmit DMA Enable.  0 = Transmit DMA disabled  1 = Transmit DMA enabled |
| 0    | RW   | 0x0         | Receive DMA Enable.  0 = Receive DMA disabled  1 = Receive DMA enabled    |

#### SPI\_DMATDLR

Address: Operational Base + offset(0x40)

DMA Transmit Data Level

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                            |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | -    | -           | Reserved.                                                                                                                                                                                                                                                                                                                              |
| 4:0  | RW   | 0x0         | Transmit Data Level. 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 Enable (DMACR[1]) = 1. |

### SPI\_DMARDLR ^

Address: Operational Base + offset(0x44)

DMA Receive Data Level

| DITA NCC | DINA Receive Data Level |             |                                                                                                                                                                                                                                                                                                                      |  |  |  |
|----------|-------------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit      | Attr                    | Reset Value | Description                                                                                                                                                                                                                                                                                                          |  |  |  |
| 31:5     | -0                      | , <b>-</b>  | Reserved.                                                                                                                                                                                                                                                                                                            |  |  |  |
| 4:0      | RW                      | 0x0         | Receive Data Level. 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 Enable(DMACR[0])=1. |  |  |  |

### SPI\_TXDR

Address: Operational Base + offset(0x400~0x7FC)

Transimt FIFO Data Register

| Bit   | Attr | Reset Value | Description                                                                                |
|-------|------|-------------|--------------------------------------------------------------------------------------------|
| 31:16 | -    | -           | Reserved.                                                                                  |
| 15:0  | W    | 0×0         | Transimt FIFO Data Register. When it is written to, data are moved into the transmit FIFO. |



### SPI\_RXDR

Address: Operational Base + offset(0x800~0xBFC)

Receive FIFO Data Register

| Bit   | Attr | Reset Value | Description                                                                                 |
|-------|------|-------------|---------------------------------------------------------------------------------------------|
| 31:16 | -    | -           | Reserved.                                                                                   |
| 15:0  | R    | 0x0         | Receive FIFO Data Register. When theregister is read, data in the receive FIFO is accessed. |

Notes: Attr: **RW**- Read/writable, **R**- read only, **W**- write only

# 35.5 Timing Diagram



Note: x=0,1

Fig. 35-7SPI controller timing diagram

Table 35-1Meaning of the parameter in Fig.35-7

|                    | 8 - F                                                |        |        |        |      |
|--------------------|------------------------------------------------------|--------|--------|--------|------|
| Parameter          | Description                                          | min    | typ    | max    | unit |
| t <sub>DTXD</sub>  | spix_txd propagation delay from spix_sclk drive edge | -0.639 | -1.057 | -1.694 | ns   |
| t <sub>SURXD</sub> | spix_rxd setup time to spix_sclk sample edge         | 5.846  | 8.490  | 12.204 | ns   |

Note:x=0,1



Fig. 35-8SPI controller timing diagram in slave mode

Table 35-2Meaning of the parameter in Fig.35-8

| Parameter            | Description                                                                      | min   | typ    | max    | unit |
|----------------------|----------------------------------------------------------------------------------|-------|--------|--------|------|
| Т                    | spix_sclk cycle time (cannot be less than 60 ns)                                 | -     | 1      | -      | ns   |
| t <sub>SMP2DRV</sub> | spix_sclk pulse width from sample edge to drive edge (cannot be less than 30 ns) | -     | ı      | -      | ns   |
| t <sub>DRV2SMP</sub> | spix_sclk pulse width from drive edge to sample edge (cannot be less than 30 ns) | -     | ı      | ı      | ns   |
| t <sub>DTXD</sub>    | spix_txd propagation delay from T/3 after spix_sclk drive edge                   | 6.771 | 10.146 | 14.691 | ns   |
| t <sub>HRXD</sub>    | spix_rxd hold time from T/3 after spix_sclk sample edge                          | 0.238 | 0.489  | 0.676  | ns   |

*Note:x*=*0*,*1* 

# 35.6 Interface description

Table 35-3SPI interface description in master mode

| <b>Module Pin</b> | Direction | Pad Name   | IOMUX Setting              |
|-------------------|-----------|------------|----------------------------|
| spi0_clk          | I/O       | GPIO1_A[5] | GRF_GPIO1A_IOMUX[11:10]=10 |
| spi0_csn0         | I/O       | GPIO1_A[4] | GRF_GPIO1A_IOMUX[9:8]=10   |
| spi0_txd          | 0         | GPIO1_A[7] | GRF_GPIO1A_IOMUX[15:14]=10 |
| spi0_rxd          | I         | GPIO1_A[6] | GRF_GPIO1A_IOMUX[13:12]=10 |
| spi1_clk          | I/O       | GPIO2_C[3] | GRF_GPIO2C_IOMUX[7:6]=10   |
| spi1_csn0         | I/O       | GPIO2_C[4] | GRF_GPIO2C_IOMUX[9:8]=10   |
| spi1_txd          | 0         | GPIO2_C[5] | GRF_GPIO2C_IOMUX[11:10]=10 |
| spi1_rxd          | I         | GPIO2_C[6] | GRF_GPIO2C_IOMUX[13:12]=10 |
| spi1_csn1         | 0         | GPIO2_C[7] | GRF_GPIO2C_IOMUX[15:14]=10 |
| spi0_csn1         | 0         | GPIO4_B[7] | GRF_GPIO4B_IOMUX[14]=1     |

Note: spi0\_csn1, spi1\_csn1 can only be used in master mode

|                   | The state of the s |            |                            |  |  |  |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|----------------------------|--|--|--|
| <b>Module Pin</b> | Direction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Pad Name   | IOMUX Setting              |  |  |  |
| spi0_clk          | I/O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | GPIO1_A[5] | GRF_GPIO1A_IOMUX[11:10]=10 |  |  |  |
| spi0_csn0         | I/O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | GPIO1_A[4] | GRF_GPIO1A_IOMUX[9:8]=10   |  |  |  |
| spi0_txd          | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | GPIO1_A[7] | GRF_GPIO1A_IOMUX[15:14]=10 |  |  |  |
| spi0_rxd          | I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | GPIO1_A[6] | GRF_GPIO1A_IOMUX[13:12]=10 |  |  |  |
| spi1_clk          | I/O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | GPIO2_C[3] | GRF_GPIO2C_IOMUX[7:6]=10   |  |  |  |
| spi1_csn0         | I/O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | GPIO2_C[4] | GRF_GPIO2C_IOMUX[9:8]=10   |  |  |  |
| spi1_txd          | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | GPIO2_C[5] | GRF_GPIO2C_IOMUX[11:10]=10 |  |  |  |
| spi1_rxd          | I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | GPIO2_C[6] | GRF_GPIO2C_IOMUX[13:12]=10 |  |  |  |

Table 35-4SPI interface description in slave mode

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

Master:  $F_{\text{spi\_clk}} >= 2 \times (\text{maximum } F_{\text{sclk\_out}})$ Slave:  $F_{\text{spi\_clk}} >= 6 \times (\text{maximum } F_{\text{sclk\_in}})$ 

#### Master Transfer Flow

When configured as a serial-master device, the SPI initiates and controls all serial transfers. The serial bit-rate clock, generated and controlled by the SPI, is driven out on the sclk\_out line. When the SPI is disabled (SPI\_ENR = 0), no serial transfers can occur and sclk\_out is held in "inactive" state, as defined by the serial protocol under which it operates.



Fig. 35-9SPI Master transfer flow diagram

#### Slave Transfer Flow

When the SPI is configured as a slave device, all serial transfers are initiated and controlled by the serial bus master.

When the SPI serial slave is selected during configuration, it enables its txd data onto the serial bus. All data transfers to and from the serial slave are regulated on the serial clock line (sclk\_in), driven from the serial-master device. Data are propagated from the serial slave on one edge of the serial clock line and sampled on the opposite edge.



Fig. 35-10SPI Slave transfer flow diagram

# **Chapter 36 UART Interface**

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

#### 36.1.1 Features

- AMBA APB interface Allows for easy integration into a Synthesizable Components for AMBA 2 implementation.
- Support interrupt interface to interrupt controller.
- UART1/UART2/UART3 contain two 32Bytes FIFOs for data receive and transmit, UART0's two embedded FIFOs are both 64Bytes for BT transfer.
- Programmable serial data baud rate as calculated by the following:baud rate = (serial clock frequency)/(16×divisor).
- UART0 / UART1 / UART3 support auto flow-control, UART2 do not support auto flow-control.
- UARTO is in cpu system, UART1 is in alive system, UART2 / UART3 are in peri system.

# 36.2 Block Diagram

This section provides a description about the functions and behavior under various conditions.

The UART comprises with:

- AMBA APB interface
- FIFO controllers
- Register block
- Modem synchronization block and baud clock generation block
- Serial receiver and serial transmitter



Fig. 36-1UART Architecture



#### APB INTERFACE

The host processor accesses data, control, and status information on the UARTthrough the APB interface. The UARTsupports 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**

Produces the transmitter and receiver baud clock along with the output reference clock signal (baudout\_n).

#### **Serial Transmitter**

Converts the parallel data, written to the UART, into serial form and adds all additional bits, as specified by the control register, for transmission. This makeup of serial data, referred to as a character can exit the block in two forms, either serial UART format or IrDA 1.0 SIR format.

#### **Serial Receiver**

Converts the serial data character (as specified by the control register) received in either the UART or IrDA 1.0 SIR format to parallel form. Parity error detection, framing error detection and line break detection is carried out in this block.

# 36.3 Function description

#### UART (RS232) Serial Protocol

Because the serial communication is asynchronous, additional bits (start and stop) are added to the serial data to indicate the beginning and end. An additional parity bit may be added to the serial character. This bit appears after the last data bit and before the stop bit(s) in the character structure to perform simple error checking on the received data, as shown in Figure.



Fig. 36-2UART Serial protocol

#### **Baud Clock**

The baud rate controlled by the serial clock (sclk or pclk in a single clock implementation) and the Divisor Latch Register (DLH and DLL). As the exact number of baud clocks that each bit was transmitted for is known, calculating the mid point for sampling is not difficult, that is every 16 baud clocks after the mid point sample of the start bit.



#### FIFO Support

#### 1.NONE FIFO MODE

If FIFO support is not selected, then no FIFOs are implemented and only a single receive data byte and transmit data byte can be stored at a time in the RBR and THR.

#### 2.FIFO MODE

The FIFO depth is 32, 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:

- a) When the Transmitter Holding Register is empty in non-FIFO mode.
- b) When the transmitter FIFO is empty in FIFO mode with ProgrammableTHRE interrupt mode disabled.
- c) 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:

- a) When there is a single character available in the Receive Buffer Register in non-FIFO mode.
- b) 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. 36-4UART 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. 36-5UART 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. 36-6 UART AUTO CTS TIMING

# 36.4 Register description

There are 4 UARTs in RK30xx, and each one has its own base address.

36.4.1 Registers Summary

| Name       | Offset        | Size | Reset Value | Description                       |
|------------|---------------|------|-------------|-----------------------------------|
| UART_RBR   | 0x0000        | W    | 0x0000_0000 | Receive Buffer Register           |
| UART_THR   |               |      |             | Transmit Holding Register         |
| UART_DLL   |               |      |             | Divisor Latch (Low)               |
| UART_DLH   | 0x0004        | W    | 0x0000_0000 | Divisor Latch (High)              |
| UART_IER   |               |      |             | Interrupt Enable Register         |
| UART_IIR   | 0x0008        | W    | 0x0000_0000 | Interrupt Identification Register |
| UART_FCR   |               |      | ^           | FIFO Control Register             |
| UART_LCR   | 0x000C        | W    | 0x0000_0000 | Line Control Register             |
| UART_MCR   | 0x0010        | W    | 0x0000_0000 | Modem Control Register            |
| UART_LSR   | 0x0014        | W    | 0x0000_0060 | Line Status Register              |
| UART_MSR   | 0x0018        | W    | 0x0000_0000 | Modem Status Register             |
| UART_SCR   | 0x001c        | W    | 0x0000_0000 | Scratchpad Register               |
| Reserved   | 0x0020        | W    | 0x0000_0000 |                                   |
|            | -2C           |      |             |                                   |
| UART_SRBR  | 0x0030        | W    | 0x0000_0000 | Shadow Receive Buffer Register    |
| UART_STHR  | -6C           | W    | 0x0000_0000 | Shadow Transmit Holding Register  |
| UART_FAR   | 0x0070        | W    | 0x0000_0000 | FIFO Access Register              |
| UART_TFR   | 0x0074        | W    | 0x0000_0000 | Transmit FIFO Read                |
| UART_RFW   | 0x0078        | W    | 0x0000_0000 | Receive FIFO Write                |
| UART_USR   | 0x007C        | W    | 0x0000_0006 | UART Status Register              |
| UART_TFL   | 0x0080        | W    | 0x0000_0000 | Transmit FIFO Level               |
| UART_RFL   | 0x0084        | W    | 0x0000_0000 | Receive FIFO Level                |
| UART_SRR   | 0x0088        | W    | 0x0000_0000 | Software Reset Register           |
| UART_SRTS  | 0x008C        | W    | 0x0000_0000 | Shadow Request to Send            |
| UART_SBCR  | 0x0090        | W    | 0x0000_0000 | Shadow Break Control Register     |
| UART_SDMAM | 0x0094        | W    | 0x0000_0000 | Shadow DMA Mode                   |
| UART_SFE   | 0x0098        | W    | 0x0000_0000 | Shadow FIFO Enable                |
| UART_SRT   | 0x009C        | W    | 0x0000_0000 | Shadow RCVR Trigger               |
| UART_STET  | 0x00A0        | W    | 0x0000_0000 | Shadow TX Empty Trigger           |
| UART_HTX   | 0x00A4        | W    | 0x0000_0000 | Halt TX                           |
| UART_DMASA | 0x00A8        | W    | 0x0000_0000 | DMA Software Acknowledge          |
| Reserved   | 0x00AC<br>-F0 | W    | 0x0000_0000 |                                   |
| UART_CPR   | 0x00F4        | W    | 0x0000_0000 | Component Parameter Register      |
| UART_UCV   | 0x00F8        | W    | 0x3330_372a | UART Component Version            |
| UART_CTR   | 0x00FC        | W    | 0x4457_0110 | Component Type Register           |

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



# 36.4.2 Registers detail description

# UART\_RBR

Address: Operational Base + offset(0x00)

Receive Buffer Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7:0  | RW   | 0x0         | 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 over-run error.  If in FIFO mode (FIFO_MODE != NONE) and FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO is preserved, but any incoming data are lost and an over-run error occurs. |

# **UART\_THR**

Address: Operational Base + offset( 0x00)

Transmit Holding Register

| Bit  | Attr | Register  Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | Attr | Reset value           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 31:8 | -    | -                     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 7:0  | RW   | 0x0                   | 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.  If in FIFO mode and FIFOs are enabled (FCR[0] = 1) 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\_DLL**

Address: Operational Base + offset( 0x00)

Divisor Latch (Low)

| Bit  | Attr | Reset Value | Description                                         |
|------|------|-------------|-----------------------------------------------------|
| 31:8 | -    | -           | Reserved                                            |
| 7:0  | RW   | 0x0         | 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 (sclk) frequency divided by sixteen times the value of the baud rate divisor, as follows: baud rate = (serial clock freq) / (16 * divisor).  Note that with the Divisor Latch Registers (DLL and DLH) set to zero, the baud clock is disabled and no |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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.                                                                                                                                                                                                                                                                                                                                                                                                                          |

# **UART\_DLH**

Address: Operational Base + offset( 0x04)

Divisor Latch (High)

| Bit  | Attr | Reset Value | Description                                                                                                    |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                                       |
| 7:0  | RW   | 0x0         | Upper 8 bits of a 16-bit, read/write, Divisor Latch register that contains the baud rate divisor for the UART. |

# UART\_IER

Address: Operational Base + offset(0x04)

Interrupt Enable Register

| Interrupt |      |             |                                                                                                                                                                                                                           |
|-----------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit       | Attr | Reset Value | Description                                                                                                                                                                                                               |
| 31:8      | -    | -           | Reserved                                                                                                                                                                                                                  |
| 7         | RW   | 0x0         | Programmable THRE Interrupt Mode Enable This is used to enable/disable the generation of THRE Interrupt. 0 = disabled 1 = enabled                                                                                         |
| 6:4       | -    |             | Reserved                                                                                                                                                                                                                  |
| 3         | RW   | 0X0         | Enable Modem Status Interrupt. This is used to enable/disable the generation of Modem Status Interrupt. This is the fourth highest priority interrupt. 0 = disabled 1 = enabled                                           |
| 2         | RW   | 0X0         | Enable Receiver Line Status Interrupt. This is used to enable/disable the generation of Receiver Line Status Interrupt. This is the highest priority interrupt. 0 = disabled 1 = enabled                                  |
| 1         | RW   | 0X0         | 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.  0 = disabled  1 = enabled |
| 0         | RW   | 0X0         | 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.  0 = disabled |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 = enabled                                                                                                                                                  |

### **UART\_IIR**

Address: Operational Base + offset( 0x08)

Interrupt Identification Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                 |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                                                                                                                                                                                                                    |
| 7:6  | R    | 0x01        | FIFOs Enabled. This is used to indicate whether the FIFOs are enabled or disabled. 00 = disabled 11 = enabled                                                                                                                                                                               |
| 5:4  | -    | -           | Reserved                                                                                                                                                                                                                                                                                    |
| 3:0  | R    | 0x01        | Interrupt ID. This indicates the highest priority pending interrupt which can be one of the following types:  0000 = modem status  0001 = no interrupt pending  0010 = THR empty  0100 = received data available  0110 = receiver line status  0111 = busy detect  1100 = character timeout |

# UART\_FCR

Address: Operational Base + offset( 0x08)

FIFO Control Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 7:6  | ×    | 0x0         | RCVR Trigger. This is used to select the trigger level in the receiver FIFO 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. The following trigger levels are supported:  00 = 1 character in the FIFO 01 = FIFO 1/4 full 10 = FIFO 1/2 full 11 = FIFO 2 less than full |
| 5:4  | W    | 0x0         | TX Empty Trigger. 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. The following trigger levels are supported:  00 = FIFO empty 01 = 2 characters in the FIFO                                                                                                                                      |



|   | 1 |     | ,                                                                                                                                                                                                                                                                                                 |
|---|---|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |   |     | 10 = FIFO ¼ full                                                                                                                                                                                                                                                                                  |
|   |   |     | 11 = FIFO ½ full                                                                                                                                                                                                                                                                                  |
| 3 | W | 0x0 | DMA Mode. 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 .  0 = mode 0  1 = mode 11100 = character timeout                                                                            |
| 2 | W | 0x0 | 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. Note that this bit is'self-clearing'. It is not necessary to clear this bit. |
| 1 | W | 0x0 | 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 . Note that this bit is 'self-clearing'. It is not necessary to clear this bit |
| 0 | W | 0x0 | FIFO Enable. This enables/disables the transmit (XMIT) and receive (RCVR) FIFOs. Whenever the value of this bit is changed both the XMIT and RCVR controller portion of FIFOs is reset.                                                                                                           |

# UART\_LCR

Address: Operational Base + offset(0x0C)

Line Control Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7    | RW   | 0x0         | 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 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 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 thereceiver and the sir_out_n line is forced low |
| 5    | -    | -           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 4    | RW   | 0x0         | 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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----|----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | RW | 0x0 | 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. 0 = parity disabled 1 = parity enabled                                                                                                                                                                                                                                                                                                                                                   |
| 2   | RW | 0x0 | 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, twostop bits are transmitted. Note that regardless of the number of stop bits selected, the receiver checks only the first stop bit.  0 = 1 stop bit 1 = 1.5 stop bits when DLS (LCR[1:0]) is zero, else 2 stop bit |
| 1:0 | RW | 0x0 | 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:  00 = 5 bits  01 = 6 bits  10 = 7 bits  11 = 8 bits                                                                                                                                                                                                                                                                                                    |

# UART\_MCR

Address: Operational Base + offset(0x10)

Modem Control Register

| Bit  | Attr  | Reset Value | Description                                                                                                                                                                                                                          |
|------|-------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7 | - 🗼 🗸 |             | Reserved                                                                                                                                                                                                                             |
| 6    | RW    | 0x0         | SIR Mode Enable. This is used to enable/disable the IrDA SIR Mode .  0 = IrDA SIR Mode disabled  1 = IrDA SIR Mode enabled                                                                                                           |
| 5    | RW    | 0x0         | Auto Flow Control Enable.  0 = Auto Flow Control Mode disabled  1 = Auto Flow Control Mode enabled                                                                                                                                   |
| 4    | RW    | 0×0         | LoopBack Bit. This is used to put the UART into a diagnostic mode for test purposes.                                                                                                                                                 |
| 3    | RW    | 0x0         | 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: 0 = out2_n de-asserted (logic 1) 1 = out2_n asserted (logic 0) |
| 2    | RW    | 0x0         | OUT1                                                                                                                                                                                                                                 |



| 1 | RW | 0x0 | 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                                      |
|---|----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 | RW | 0x0 | 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:  0 = dtr_n de-asserted (logic 1)  1 = dtr_n asserted (logic 0) |

# UART\_LSR

Address: Operational Base + offset(0x14) Line Status Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 7    | R    | 0×0         | Receiver FIFO Error bit. This bit is relevant 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.  0 = no error in RX FIFO  1 = error in RX FIFO                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 6    | R    | 0x1         | Transmitter Empty bit. If FIFOs enabled (FCR[0] set to one), this bit is set whenever the Transmitter Shift Register and the FIFO are both empty. If FIFOs are disabled, this bit is set whenever the Transmitter Holding Register and the Transmitter Shift Register are both empty.                                                                                                                                                                                                                                                                                                                                                                                                  |
| 5    | R    | 0×1         | Transmit Holding Register Empty bit. If THRE mode is disabled (IER[7] set to zero) and regardless of FIFO's being implemented/enabled or not, this bit indicates that the THR or TX FIFO is empty.  This bit is set whenever data is transferred from the THR or TX FIFO to the transmitter shift register and no new data has been written to the THR or TX FIFO. This also causes a THRE Interrupt to occur, if the THRE Interrupt is enabled. If IER[7] set to one and FCR[0] set to one respectively, the functionality is switched to indicate the transmitter FIFO is full, and no longer controls THRE interrupts, which are then controlled by the FCR[5:4] threshold setting. |
| 4    | R    | 0x0         | Break Interrupt bit. This is used to indicate the detection of a break sequence on the serial input data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 3    | R    | 0x0         | 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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2    |      | 0x0         | 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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 1    | R    | 0x0         | 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.                                                                                                 |
|---|---|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 | R | 0x0 | Data Ready bit. This is used to indicate that the receiver contains at least one character in the RBR or the receiver FIFO.  0 = no data ready  1 = data ready |

# UART\_MSR

Address: Operational Base + offset(0x18)

Modem Status Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                 |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                                                                                                                    |
| 7    | R    | 0x0         | Data Carrier Detect. This is used to indicate the current state of the modem control line dcd_n.                                                                                            |
| 6    | R    | 0x0         | Ring Indicator. This is used to indicate the current state of the modem control line ri_n.                                                                                                  |
| 5    | R    | 0x0         | Data Set Ready. This is used to indicate the current state of the modem control line dsr_n.                                                                                                 |
| 4    | R    | 0x0         | Clear to Send. This is used to indicate the current state of the modem control line cts_n.                                                                                                  |
| 3    | R    | 0x0         | 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.                                                     |
| 2    | R    | 0x0         | 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. |
| 1    | R    | 0x0         | 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.                                                          |
| 0    | R    | 0x0         | 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.                                                           |

# UART\_SCR

Address: Operational Base + offset(0x1C)

Scratchpad Register

| Bit  | Attr | Reset Value | Description                                            |
|------|------|-------------|--------------------------------------------------------|
| 31:8 | _    | -           | Reserved                                               |
| 7:0  | RW   | 0x0         | This register is for programmers to use as a temporary |
| 7.0  | 1744 | 0.00        | storage space.                                         |

# **UART\_SRBR**

Address: Operational Base + offset(0x30-6C)

Shadow Receive Buffer Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                            |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                                                                                                                               |
| 7:0  | R    | 0x0         | This is a shadow register for the RBR and has been allocated sixteen 32-bit locations 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 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 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(0x30-6C)

Shadow Transmit Holding Register

| Bit  | Attr | Reset Value | Description                            |
|------|------|-------------|----------------------------------------|
| 31:8 | -    | -           | Reserved                               |
| 7:0  | R    | 0x0         | This is a shadow register for the THR. |

# UART\_FAR

Address: Operational Base + offset(0x70)

FIFO Access Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                             |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | -    | -           | Reserved                                                                                                                                                                                                                                                                                                                                                                                |
| 0    | RW   | 0x0         | 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 enabled it allows the RBR to be written by the master and the THR to be read by the master.  0 = FIFO access mode disabled 1 = FIFO access mode enabled |

# UART\_TFR

Address: Operational Base + offset(0x74)

Transmit FIFO Read

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | -    | -           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7:0  | R    | 0x0         | 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. When FIFOs are not implemented or not enabled, reading this register gives the data in the THR. |

# **UART\_RFW**



Address: Operational Base + offset(0x78)

Receive FIFO Write

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                               |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | -    | -           | Reserved                                                                                                                                                                                                                                                                                                                                                                                  |
| 9     | W    | 0x0         | Receive FIFO Framing Error. These bits are only valid when FIFO access mode is enabled (FAR[0] is set to one).                                                                                                                                                                                                                                                                            |
| 8     | W    | 0×0         | Receive FIFO Parity Error. These bits are only valid when FIFO access mode is enabled (FAR[0] is set to one).                                                                                                                                                                                                                                                                             |
| 7:0   | w    | 0x0         | Receive FIFO Write Data. These bits are only valid when FIFO access mode is enabled (FAR[0] is set to one). When FIFOs are enabled, the data that is written to the RFWD is pushed into the receive FIFO. Each consecutive write pushes the new data to the next write location in the receive FIFO. When FIFOs not enabled, the data that is written to the RFWD is pushed into the RBR. |

# UART\_USR

Address: Operational Base + offset(0x7C)

**UART Status Register** 

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                    |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | -    | -           | Reserved                                                                                                                                                                                                       |
| 4    | R    | 0x0         | Receive FIFO Full. This is used to indicate that the receive FIFO is completely full.  0 = Receive FIFO not full  1 = Receive FIFO Full  This bit is cleared when the RX FIFO is no longer full                |
| 3    | R    | 0x0         | Receive FIFO Not Empty. This is used to indicate that the receive FIFO contains one or more entries.  0 = Receive FIFO is empty  1 = Receive FIFO is not empty  This bit is cleared when the RX FIFO is empty  |
| 2    | R    | 0x1         | Transmit FIFO Empty. This is used to indicate that the transmit FIFO is completely empty.  0 = Transmit FIFO is not empty  1 = Transmit FIFO is empty  This bit is cleared when the TX FIFO is no longer empty |
| 1    | R    | 0x1         | Transmit FIFO Not Full. This is used to indicate that the transmit FIFO in not full.  0 = Transmit FIFO is full  1 = Transmit FIFO is not full  This bit is cleared when the TX FIFO is full.                  |
| 0    | R    | 0x0         | UART Busy. This is indicates that a serial transfer is in progress, when cleared indicates that the uart is idle or inactive.  0 = Uart is idle or inactive  1 = Uart is busy (actively transferring data)     |

# **UART\_TFL**

Address: Operational Base + offset(0x80)

Transmit FIFO Level



| Bit  | Attr | Reset Value | Description                                                                             |
|------|------|-------------|-----------------------------------------------------------------------------------------|
| 31:5 | -    | -           | Reserved                                                                                |
| 4:0  | R    | 0x0         | Transmit FIFO Level. This is indicates the number of data entries in the transmit FIFO. |

# UART\_RFL

Address: Operational Base + offset(0x84)

Receive FIFO Level

| Bit  | Attr | Reset Value | Description                                                                           |
|------|------|-------------|---------------------------------------------------------------------------------------|
| 31:5 | -    | -           | Reserved                                                                              |
| 4:0  | R    | 0x0         | Receive FIFO Level. This is indicates the number of data entries in the receive FIFO. |

# **UART\_SRR**

Address: Operational Base + offset(0x88)

Software Reset Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                         |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | -    | -           | Reserved                                                                                                                                                            |
| 2    | W    | 0x0         | XMIT FIFO Reset. This is a shadow register for the XMIT FIFO Reset bit (FCR[2]).                                                                                    |
| 1    | W    | 0x0         | RCVR FIFO Reset. This is a shadow register for the RCVR FIFO Reset bit (FCR[1]).                                                                                    |
| 0    | W    | 0x0         | 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(0x8C)

Shadow Request to Send

| Bit  | Attr | Reset Value | Description                                                                                                                                                               |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | -    | - • ( )     |                                                                                                                                                                           |
| 0    | RW   | 0x0         | 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. |

#### UART\_SBCR

Address: Operational Base + offset(0x90)

Shadow Break Control Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                            |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | -    | -           | Reserved                                                                                                                                                                               |
| 0    | RW   | 0×0         | Shadow Break Control Bit. This is a shadow register for<br>the Break bit (LCR[6]), this can be used to remove the<br>burden of having to performing a read modify write on<br>the LCR. |

# **UART\_SDMAM**

Address: Operational Base + offset(0x94)

Shadow DMA Mode

| Bit  | Attr | Reset Value | Description                                        |
|------|------|-------------|----------------------------------------------------|
| 31:1 | -    | -           | Reserved                                           |
| 0    | RW   | 0x0         | Shadow DMA Mode. This is a shadow register for the |



|  | DMA mode bit (FCR[3]). |
|--|------------------------|

# **UART\_SFE**

Address: Operational Base + offset(0x98)

Shadow FIFO Enable

| Bit  | Attr | Reset Value | Description                                                                     |
|------|------|-------------|---------------------------------------------------------------------------------|
| 31:1 | -    | -           | Reserved                                                                        |
| 0    | RW   | 0x0         | Shadow FIFO Enable. This is a shadow register for the FIFO enable bit (FCR[0]). |

#### **UART\_SRT**

Address: Operational Base + offset(0x9C)

Shadow RCVR Trigger

|      |      | J J -       |                                                                                      |
|------|------|-------------|--------------------------------------------------------------------------------------|
| Bit  | Attr | Reset Value | Description                                                                          |
| 31:2 | -    | -           | Reserved                                                                             |
| 1:0  | RW   | 0x0         | Shadow RCVR Trigger. This is a shadow register for the RCVR trigger bits (FCR[7:6]). |

# UART\_STET

Address: Operational Base + offset(0Xa0)

Shadow TX Empty Trigger

| Bit  | Attr | Reset Value | Description                                                                                  |
|------|------|-------------|----------------------------------------------------------------------------------------------|
| 31:2 | -    | -           | Reserved                                                                                     |
| 1:0  | RW   | 0x0         | Shadow TX Empty Trigger. This is a shadow register for the TX empty trigger bits (FCR[5:4]). |

#### UART\_HTX

Address: Operational Base + offset(0Xa4)

Halt TX

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                      |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | -    | - • 1       | Reserved                                                                                                                                                                                         |
| 0    | RW   | 0x0         | 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.  0 = Halt TX disabled  1 = Halt TX enabled |

# UART\_DMASA

Address: Operational Base + offset(0xa8)

RTC counter reset register

| Bit  | Attr | Reset Value | Description                                                                                                                |  |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------|--|
| 31:1 | -    | -           | Reserved                                                                                                                   |  |
| 0    | W    | 0×0         | This register is use to perform a DMA software acknowledge if a transfer needs to be terminated due to an error condition. |  |

#### **UART\_UCV**

Address: Operational Base + offset(0xf8)

**UART Component Version** 

| Bit  | Attr | Reset Value | Description                                |
|------|------|-------------|--------------------------------------------|
| 31:0 | R    | 0x330372a   | ASCII value for each number in the version |



# UART\_CTR

Address: Operational Base + offset(0xfc)

Component Type Register

| Bit  | Attr | Reset Value | Description                                                 |
|------|------|-------------|-------------------------------------------------------------|
| 31:0 | R    | 0x44570110  | This register contains the peripherals identification code. |

Notes: Attr: **RW** - Read/writable, **R** - read only, **W** - write only

# 36.5 Interface description

Table 36-1 UART Interface Description

| Module pin  | Direction       | Pad name   | IOMUX                      |  |  |  |
|-------------|-----------------|------------|----------------------------|--|--|--|
|             | UARTO Interface |            |                            |  |  |  |
| uart0_sin   | I               | GPIO1_A[0] | GRF_GPIO1A_IOMUX[0]=1      |  |  |  |
| uart0_sout  | 0               | GPIO1_A[1] | GRF_GPIO1A_IOMUX[2]=1      |  |  |  |
| uart0_cts_n | I               | GPIO1_A[2] | GRF_GPIO1A_IOMUX[4]=1      |  |  |  |
| uart0_rts_n | 0               | GPIO1_A[3] | GRF_GPIO1A_IOMUX[6]=1      |  |  |  |
|             |                 | UART1 Inte | erface                     |  |  |  |
| uart1_sin   | I               |            | GRF_GPIO1A_IOMUX[9:8]=01   |  |  |  |
| uart1_sout  | 0               |            | GRF_GPIO1A_IOMUX[11:10]=01 |  |  |  |
| uart1_cts_n | I               |            | GRF_GPIO1A_IOMUX[13:12]=01 |  |  |  |
| uart1_rts_n | 0               | GPIO1_A[7] | GRF_GPIO1A_IOMUX[15:14]=01 |  |  |  |
|             |                 | UART2 Inte | erface                     |  |  |  |
| uart2_sin   | I               |            | GRF_GPIO1B_IOMUX[0]=1      |  |  |  |
| uart2_sout  | 0               | GPIO1_B[1] | GRF_GPIO1B_IOMUX[2]=1      |  |  |  |
|             |                 | UART3 Inte | erface                     |  |  |  |
| uart3_sin   | I               | GPIO3_D[3] | GRF_GPIO3D_IOMUX[6]=1      |  |  |  |
| uart3_sout  | 0               | GPIO3_D[4] | GRF_GPIO3D_IOMUX[8]=1      |  |  |  |
| uart3_cts_n | I               | GPIO3_D[5] | GRF_GPIO3D_IOMUX[10]=1     |  |  |  |
| uart3_rts_n | 0               | GPIO3_D[6] | GRF_GPIO3D_IOMUX[12]=1     |  |  |  |

# **36.6 Application Notes**

#### 36.6.1 None FIFO Mode Transfer Flow



Fig. 36-7UARTnone fifo mode

# 36.6.2 FIFO Mode Transfer Flow



Fig. 36-8UART 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 32-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.

#### 36.6.3 Baud Rate Calculation

#### UART clock generation

Fig.36-10 shows the UART clock generation.

UART source clocks can be selected from CODEC PLL and GENERAL PLL outputs.

UART clocks can be generated by 1 to 64 division of its source clock, or can be fractionally divided again, or be provided by XIN24M.



Fig. 36-9 UART clock generation

#### **UART** baud rate configuration

Table 36-2 provides some reference configuration for different UART baud rates.

| Table 36-2 UART | `baud rate | e configuration |
|-----------------|------------|-----------------|
|-----------------|------------|-----------------|

|            | <u> </u>                                                   |  |  |
|------------|------------------------------------------------------------|--|--|
| Baud Rate  | Reference Configuration                                    |  |  |
| 115.2 Kbps | Config GENERAL PLL to get 648MHz clock output;             |  |  |
|            | Divide 648MHz clock by 1152/50625 to get 14.7456MHz clock; |  |  |
|            | Config UART_DLL to 8.                                      |  |  |
| 460.8 Kbps | Config GENERAL PLL to get 648MHz clock output;             |  |  |
|            | Divide 648MHz clock by 1152/50625 to get 14.7456MHz clock; |  |  |
|            | Config UART_DLL to 2.                                      |  |  |
| 921.6 Kbps | Config GENERAL PLL to get 648MHz clock output;             |  |  |
|            | Divide 648MHz clock by 1152/50625 to get 14.7456MHz clock; |  |  |
|            | Config UART_DLL to 1.                                      |  |  |
| 1.5 Mbps   | Choose GENERAL PLL to get 384MHz clock output;             |  |  |
|            | Divide 384MHz clock by 16 to get 24MHz clock;              |  |  |
|            | Config UART_DLL to 1                                       |  |  |



| 3 Mbps   | Choose GENERAL PLL to get 384MHz clock output; Divide 384MHz clock by 8 to get 48MHz clock; Config UART_DLL to 1 |
|----------|------------------------------------------------------------------------------------------------------------------|
| 4 Mbps   | Config GENERAL PLL to get 384MHz clock output; Divide 384MHz clock by 6 to get 64MHz clock; Config UART_DLL to 1 |
|          |                                                                                                                  |
|          |                                                                                                                  |
|          |                                                                                                                  |
|          |                                                                                                                  |
|          |                                                                                                                  |
|          |                                                                                                                  |
|          |                                                                                                                  |
|          |                                                                                                                  |
|          |                                                                                                                  |
|          |                                                                                                                  |
|          |                                                                                                                  |
|          |                                                                                                                  |
| 50       |                                                                                                                  |
| <b>y</b> |                                                                                                                  |
|          |                                                                                                                  |
|          |                                                                                                                  |



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

#### 37.1.1 Features

- Item Compatible with I2C-bus
- AMBA APB slave interface
- Supports master mode of I2C bus
- Software programmable clock frequency and transfer rate up to 400Kbit/sec
- Supports 7 bits and 10 bits addressing modes
- Interrupt or polling driven multiple bytes data transfer
- Clock stretching and wait state generation
- I2C0/I2C1 is in cpu system, I2C2 /I2C3 /I2C4 are in peri system

# 37.2 Block Diagram

This chapter provides a description about the functions and behavior under various conditions.

#### **APB BUS**



Fig. 37-1I2C architechture

#### I2C rf

I2C\_rf module is used to control the I2C controller operation by the host with APB interface. It implements the register set and the interrupt functionality. The CSR component operates synchronously with the pclk clock.

#### I2C\_pe

I2C\_pe module implements the I2C master operation for transmit data to and receive data from other I2C devices. The I2C master controller operates synchronously with the pclk.

#### I2C\_top

I2C top module is the top module of the I2C controller.



The I2C controller supports only Masterfunction. Itsupports the 7-bits/10-bits addressing mode and support general call address. The maximum clock frequency and transfer rate can be up to 400Kbit/sec.

The operations of I2C controller is divided to 2 parts and described separately: initialization and master mode programming.

#### **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 & configuration must be conformed, which includes:

- I2C interrupt connection type: CPU interrupt scheme should be considered. If the I2C interrupt is connected to extra Interrupt Controller module, we need decide the INTC vector.
- I2C Clock Rate: The I2C controller uses the APB clock as the system clock so the APB clock will determine the I2C bus clock. The correct register setting is subject to the system requirement.

#### **Master Mode Programming**

**SCL Clock**: When the I2C controller is programmed in Master mode, the SCL frequency is determine by I2C\_CLKDIV register. The SCL frequency is calculated by the following formula

SCL Divisor = 8\*(CLKDIVL + CLKDIVH)

SCL = PCLK/ SCLK Divisor

#### **Data Receiver Register Access**

When the i2c controller received MRXCNT bytes data. CPU can get the datas through register RXDATA0 ~ RXDATA7. The controller can receive up to 32 byte datas in one transaction.

When MRXCNT register is written, the I2C controller will start to drive SCL to receive datas.

#### **Transmit Trasmitter Register**

Datas to transmit are written to TXDATA0~7 by CPU. The controller can transmit up to 32 byte datas in one transaction. The lower byte will be transmit first.

When MTXCNT register is written, the I2C controller will start to transmit datas.

#### **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 mode.

When I2C\_CON[2:1] is 2'b00, the controller transmit all valid datas 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

When I2C\_CON[2:1] is 2'b01, the controller will transmit device address in MRXADDR first (Write/Read bit = 0) and then transmit device register address in



MRXRADDR. After that, the controller will assert restart signal and resend MRXADDR (Write/Read bit = 1). At last, the controller enter receive mode.

When I2C CON[2:1] is 2'b10, the controller is in receive mode, it will triggered clock to read MRXCNT byte datas.

When I2C CON[2:1] is 2'b11,the controller will transmit device address in MRXADDR first (Write/Read bit = 1) and then transmit device register address in MRXRADDR . After that, the controller will assert restart signal and resend MRXADDR (Write/Read bit = 1). At last, the controller enter receive mode.

#### **Read/Write Command**

When I2C\_OPMODE(I2C\_CON[2:1]) is 2'b01 or 2'b11, the Read/Write command bit is decieded 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 transfer finish interrupt (Bit 0): The bit is asserted when Master finish transferring a byte.

Byte received finish interrupt (Bit 1): The bit is asserted when Master finish receiving a byte.

MTXCNT bytes data transfer finish interrupt (Bit 2): The bit is asserted when Master finish transferring MTXCNT bytes.

MRXCNT bytes data received finish interrupt (Bit 3): The bit is asserted when Master finish receiving MRXCNT bytes.

Start interrupt (Bit 4): The bit is asserted when Master finish asserting start command to I2C bus.

Stop interrupt (Bit 5): The bit is asserted when Master finish asserting stop command to I2C bus.

Nak received interrupt (Bit 6): The bit is asserted when Master receive 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 responsibity 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

(a) 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. 37-2I2C DATA Validity

## (b) 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. 37-3 I2C Start and stop conditions

#### • Data transfer

#### (a) Acknowledge

After a byte of data transferring (clocks labeled as  $1\sim8$ ), in  $9^{th}$  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. 37-4I2C Acknowledge

# (b) Byte transfer

The master own I2C bus might initiate multi byte ot transfers to a slave, the transfers starts from a "START" command and ends in a "STOP" command. After every byte transfer, the receiver must reply an ACK to transmitter.



Fig. 37-5 I2C byte trasnfer

# 37.4 Register description

# 37.4.1 Register Summary

| Name          | Offset | Size | Reset<br>Value | Description                                            |
|---------------|--------|------|----------------|--------------------------------------------------------|
| I2C_CON       | 0x0000 | W    | 0x00000000     | control register                                       |
| I2C_CLKDIV    | 0x0004 | W    | 0x0000001      | Clock dividor register                                 |
| I2C_MRXADDR   | 0x0008 | W    | 0x00000000     | the slave address accessed for master rx mode          |
| I2C_MRXRADDR  | 0x000c | W    | 0×00000000     | the slave register address accessed for master rx mode |
| I2C_MTXCNT    | 0x0010 | W    | 0x0000000      | master transmit count                                  |
| I2C_MRXCNT    | 0x0014 | W    | 0x0000000      | master rx count                                        |
| I2C_IEN       | 0x0018 | W    | 0x0000000      | interrupt enable register                              |
| I2C_IPD       | 0x001c | W    | 0x0000000      | interrupt pending register                             |
| I2C_FCNT      | 0x0020 | W    | 0x0000000      | finished count                                         |
| I2C_TXDATA0   | 0x0100 | V    | 0x0000000      | I2C tx data register 0                                 |
| I2C_TXDATA1   | 0x0104 | W    | 0x0000000      | I2C tx data register 1                                 |
| I2C_TXDATA2   | 0x0108 | V    | 0x0000000      | I2C tx data register 2                                 |
| I2C_TXDATA3 / | 0x010c | W    | 0x0000000      | I2C tx data register 3                                 |
| I2C_TXDATA4   | 0x0110 | W    | 0x0000000      | I2C tx data register 4                                 |
| I2C_TXDATA5   | 0x0114 | W    | 0x0000000      | I2C tx data register 5                                 |
| I2C_TXDATA6   | 0x0118 | W    | 0x0000000      | I2C tx data register 6                                 |
| I2C_TXDATA7   | 0x011c | W    | 0x0000000      | I2C tx data register 7                                 |
| I2C_RXDATA0   | 0x0200 | W    | 0x0000000      | I2C rx data register 0                                 |
| I2C_RXDATA1   | 0x0204 | W    | 0x00000000     | I2C rx data register 1                                 |
| I2C_RXDATA2   | 0x0208 | W    | 0x0000000      | I2C rx data register 2                                 |
| I2C_RXDATA3   | 0x020c | W    | 0x00000000     | I2C rx data register 3                                 |
| I2C_RXDATA4   | 0x0210 | W    | 0x0000000      | I2C rx data register 4                                 |
| I2C_RXDATA5   | 0x0214 | W    | 0x00000000     | I2C rx data register 5                                 |
| I2C_RXDATA6   | 0x0218 | W    | 0x0000000      | I2C rx data register 6                                 |
| I2C_RXDATA7   | 0x021c |      |                | I2C rx data register 7                                 |

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



# I2C\_CON

Address: Operational Base + offset (0x0000)

control register

| Bit  | register<br>Attr | Reset Value | Description                                      |
|------|------------------|-------------|--------------------------------------------------|
| 31:7 | RO               | 0x0         | reserved                                         |
| 31.7 | KO               | 0.00        | act2nak                                          |
|      |                  |             |                                                  |
| 6    | RW               | 0x0         | operation when nak handshake is received         |
|      |                  |             | 0: ignored                                       |
|      |                  |             | 1: stop transaction                              |
|      |                  |             | ack                                              |
|      |                  |             | last byte acknowledge control                    |
| 5    | RW               | 0x0         | last byte acknowledge control in master rx       |
|      |                  |             | mode .                                           |
|      |                  |             | 0: ack                                           |
|      |                  |             | 1: nak                                           |
|      |                  |             | stop                                             |
|      |                  |             | stop enable                                      |
| 4    | W1C              | 0x0         | when this bit is written to 1, I2C will generate |
|      |                  |             | stop signal. It cleared itself when stop         |
|      |                  |             | operation ends.                                  |
|      |                  |             | start                                            |
|      |                  |             | start enable                                     |
| 3    | W1C              | 0x0         | when this bit is written to 1, I2C will generate |
|      |                  |             | start signal. It cleared itself when start       |
|      |                  |             | operation ends.                                  |
|      |                  | VO X        | i2c_mode                                         |
|      |                  |             | 00: tx only                                      |
|      | A 4              |             | 01: tx address (device + register address)       |
| 2:1  | RW               | 0x0         | > restart> tx address ->rx only                  |
|      |                  | OXO         | 10:rx only                                       |
|      |                  |             | 11: tx address (device + register address,       |
| 12   |                  |             | write/read bit is 1)> restart> tx address        |
|      |                  |             | (device address)> rx data                        |
| 0    | RW               | 0x0         | i2c_en                                           |
| J    | 1                | UXU         | i2c module enable                                |

# I2C\_CLKDIV

Address: Operational Base + offset (0x0004)

Clock dividor register

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
|     |      |             |             |



| Bit   | Attr | Reset Value | Description                            |
|-------|------|-------------|----------------------------------------|
|       |      |             | CLKDIVH                                |
| 31:16 | RW   | 0x0000      | scl high level clock count             |
|       |      |             | $T (SCL_HIGH) = T(PCLK) * CLKDIVH * 8$ |
|       |      |             | CLKDIVL                                |
| 15:0  | RW   | 0x0001      | scl low level clock count              |
|       |      |             | $T (SCL_LOW) = T(PCLK) * CLKDIVL * 8$  |

# I2C\_MRXADDR

Address: Operational Base + offset (0x0008) the slave address accessed for master rx mode

| Bit   | Attr | Reset Value | Description                           |
|-------|------|-------------|---------------------------------------|
| 31:27 | RO   | 0x0         | reserved                              |
| 26    | RW   | 0.0         | addhvld                               |
| 20    | FCVV | 0x0         | address high byte valid               |
| 25    | RW   | 0x0         | addmvld                               |
| 25    | KVV  |             | address middle byte valid             |
| 24    | RW   | 0x0         | addlvld                               |
| 24    | KVV  | UXU         | address low byte valid                |
|       |      |             | saddr                                 |
| 23:0  | RW   | 0x000000    | master address register               |
|       |      |             | the lowest bit indicate write or read |

# I2C\_MRXRADDR

Address: Operational Base + offset (0x000c)

the slave register address accessed for master rx mode

| Bit   | Attr | Reset Value | Description                     |
|-------|------|-------------|---------------------------------|
| 31:27 | RO   | 0x0         | reserved                        |
| 26    | RW   | 0.0         | sraddhvld                       |
| 20    | KW   | 0x0         | address high byte valid         |
| 25    | RW   | 0x0         | sraddmvld                       |
| 25    |      |             | address middle byte valid       |
| 24    | RW   | 0×0         | sraddlvld                       |
| 24    |      |             | address low byte valid          |
| 23:0  | RW   | 0x000000    | sraddr                          |
|       |      |             | slave register address accessed |

# I2C\_MTXCNT

Address: Operational Base + offset (0x0010)

master transmit count

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:6 | RO   | 0x0         | reserved    |



# I2C\_MRXCNT

Address: Operational Base + offset (0x0014)

master rx count

|      | master ix edulic |             |                 |  |  |
|------|------------------|-------------|-----------------|--|--|
| Bit  | Attr             | Reset Value | Description     |  |  |
| 31:6 | RO               | 0x0         | reserved        |  |  |
| 5:0  | RW               | 0×00        | mrxcnt          |  |  |
| 3.0  | KVV              | 0000        | master rx count |  |  |

# I2C\_IEN

Address: Operational Base + offset (0x0018)

interrupt enable register

| micerrap | <u>r enable</u> | register    | A                                         |
|----------|-----------------|-------------|-------------------------------------------|
| Bit      | Attr            | Reset Value | Description                               |
| 31:7     | RO              | 0x0         | reserved                                  |
| 6        | RW              | 0×0         | nakrcvien                                 |
| O        | KVV             | UXU         | nak handshake received interrupt enable   |
| 5        | RW              | 0×0         | stopien                                   |
| 3        | KVV             | UXU         | stop operation finished interrupt enable  |
| 4        | RW              | 0×0         | startien                                  |
| 7        | INVV            | OXO         | start operation finished interrupt enable |
|          |                 |             | mbrfien                                   |
| 3        | RW              | 0x0         | MRXCNT data received finished interrupt   |
|          |                 | • \         | enable                                    |
|          |                 |             | mbtfien                                   |
| 2        | RW              | 0x0         | MTXCNT data transfer finished interrupt   |
|          |                 |             | enable                                    |
| 1        | RW              | 0×0         | brfien                                    |
| 1        | IXVV            | UXU         | byte rx finished interrupt enable         |
| 0        | RW              | 0.0         | btfien                                    |
| U        | KVV             | 0×0         | byte tx finished interrupt enable         |

# I2C\_IPD

Address: Operational Base + offset (0x001c)

interrupt pending register

|      |      | <u> </u>        |                                               |
|------|------|-----------------|-----------------------------------------------|
| Bit  | Attr | Reset Value     | Description                                   |
| 31:7 | RO   | 0x0             | reserved                                      |
| 6    | RW   | (() <b>x</b> () | nakrcvipd                                     |
|      | KVV  |                 | nak handshake received interrupt pending bit  |
| 5    | RW   | (() <b>x</b> () | stopipd                                       |
|      |      |                 | stop operation finished interrupt pending bit |



| Bit | Attr | Reset Value | Description                                    |
|-----|------|-------------|------------------------------------------------|
| 4   | RW   | 0x0         | startipd                                       |
| 4   | KVV  | UXU         | start operation finished interrupt pending bit |
|     |      |             | mbrfipd                                        |
| 3   | RW   | 0x0         | MRXCNT data received finished interrupt        |
|     |      |             | pending bit                                    |
|     |      |             | mbtfipd                                        |
| 2   | RW   | 0x0         | MTXCNT data transfer finished interrupt        |
|     |      |             | pending bit                                    |
| 1   | RW   | 0x0         | brfipd                                         |
| 1   | KVV  | UXU         | byte rx finished interrupt pending bit         |
| 0   | DW   | 0×0         | btfipd                                         |
|     | RW   |             | byte tx finished interrupt pending bit         |

# I2C\_FCNT

Address: Operational Base + offset (0x0020)

finished count

| Bit  | Attr | Reset Value | Description                                  |
|------|------|-------------|----------------------------------------------|
| 31:6 | RO   | 0x0         | reserved                                     |
|      |      |             | fcnt                                         |
|      |      |             | finished count                               |
| 5:0  | RW   | 0x00        | the count of data which has been transmitted |
|      |      |             | or received                                  |
|      |      |             | for debug purpose                            |

# I2C\_TXDATA0

Address: Operational Base + offset (0x0100)

I2C tx data register 0

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:0 | RW   | 0x0000000   | txdata0     |

# I2C\_TXDATA1

Address: Operational Base + offset (0x0104)

I2C tx data register 1

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:0 | RW   | 0x00000000  | txdata1     |

# I2C\_TXDATA2

Address: Operational Base + offset (0x0108)

I2C tx data register 2

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:0 | RW   | 0x00000000  | txdata2     |



#### I2C\_TXDATA3

Address: Operational Base + offset (0x010c)

I2C tx data register 3

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:0 | RW   | 0x00000000  | txdata3     |

# I2C\_TXDATA4

Address: Operational Base + offset (0x0110)

I2C tx data register 4

| Bit  | Attr | Reset Value | Description |  |
|------|------|-------------|-------------|--|
| 31:0 | RW   | 0x00000000  | txdata4     |  |

# I2C\_TXDATA5

Address: Operational Base + offset (0x0114)

I2C tx data register 5

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:0 | RW   | 0x0000000   | txdata5     |

# I2C\_TXDATA6

Address: Operational Base + offset (0x0118)

I2C tx data register 6

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:0 | RW   | 0x00000000  | txdata6     |

# I2C\_TXDATA7

Address: Operational Base + offset (0x011c)

I2C tx data register 7

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:0 | RW   | 0x00000000  | txdata7     |

# I2C\_RXDATA0

Address: Operational Base + offset (0x0200)

I2C rx data register 0

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:0 | RW   | 0x0000000   | rxdata0     |

#### I2C\_RXDATA1

Address: Operational Base + offset (0x0204)

I2C rx data register 1

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:0 | RW   | 0x00000000  | rxdata1     |



# I2C\_RXDATA2

Address: Operational Base + offset (0x0208)

I2C rx data register 2

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:0 | RW   | 0x0000000   | rxdata2     |

#### I2C\_RXDATA3

Address: Operational Base + offset (0x020c)

I2C rx data register 3

| Bit  | Attr | Reset Value | Description |  |
|------|------|-------------|-------------|--|
| 31:0 | RW   | 0x00000000  | rxdata3     |  |

# I2C\_RXDATA4

Address: Operational Base + offset (0x0210)

I2C rx data register 4

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:0 | RW   | 0x0000000   | rxdata4     |

# I2C\_RXDATA5

Address: Operational Base + offset (0x0214)

I2C rx data register 5

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:0 | RW   | 0x00000000  | rxdata5     |

#### I2C\_RXDATA6

Address: Operational Base + offset (0x0218)

I2C rx data register 6

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:0 | RW   | 0x00000000  | rxdata6     |

## I2C RXDATA7

Address: Operational Base + offset (0x021c)

I2C rx data register 7

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:0 | RW   | 0x0000000   | rxdata7     |

# **37.5 Timing Diagram**



Fig. 37-6 I2C timing diagram

Table 37-1 I2C timing parameters

|                     |                                      |        | is parameters |     |      |
|---------------------|--------------------------------------|--------|---------------|-----|------|
| Parameter           | Description                          | min    | typ           | max | unit |
|                     | 100K                                 | hz mod | le            |     |      |
| f <sub>SCL</sub>    | SCL clock frequency                  | -      | 100           | _   | KHz  |
| T <sub>HD:DAT</sub> | SDA hold time to rising edge of SCL  | -      | 2.5           |     | us   |
| T <sub>SU:DAT</sub> | SDA setup time to rising edge of SCL | ı      | 2.5           | _   | us   |
| t <sub>LOW</sub>    | Low period of SCL                    | -      | 5             | -   | us   |
| t <sub>HIGH</sub>   | High period of SCL                   | -      | 5             | -   | us   |
|                     | 400K                                 | hz mod | de            | -   |      |
| $f_{SCL}$           | SCL clock frequency                  | -      | 400           | -   | KHz  |
| T <sub>HD:DAT</sub> | SDA hold time to rising edge of SCL  | ` (C   | 0.625         | -   | us   |
| T <sub>SU:DAT</sub> | SDA setup time to rising edge of SCL | 1      | 0.625         | -   | us   |
| t <sub>LOW</sub>    | Low period of SCL                    | -      | 1.25          | -   | us   |
| t <sub>HIGH</sub>   | High period of SCL                   | -      | 1.25          | -   | us   |

# 37.6 Interface description

Table 37-212C Interface Description

| Module pin | Direction      | Pad name   | IOMUX                                         |  |  |
|------------|----------------|------------|-----------------------------------------------|--|--|
|            |                | I2C0 Inte  | rface                                         |  |  |
| i2c0_sda   | I/O            | GPIO2_D[4] | GRF_GPIO2D_IOMUX[8]=1&<br>GRF_SOC_CON1[11]=1  |  |  |
| i2c0_scl   | I/O            | GPIO2_D[5] | GRF_GPIO2D_IOMUX[10]=1&<br>GRF_SOC_CON1[11]=1 |  |  |
|            | I2C1 Interface |            |                                               |  |  |
| i2c1_sda   | I/O            | GPIO2_D[6] | GRF_GPIO2D_IOMUX[12]=1&<br>GRF_SOC_CON1[12]=1 |  |  |
| i2c1_scl   | I/O            | GPIO2_D[7] | GRF_GPIO2D_IOMUX[14]=1&<br>GRF_SOC_CON1[12]=1 |  |  |
|            |                | I2C2 Inte  | rface                                         |  |  |
| i2c2_sda   | I/O            | GPIO3_A[0] | GRF_GPIO3A_IOMUX[0]=1&<br>GRF_SOC_CON1[13]=1  |  |  |
| i2c2_scl   | I/O            | GPIO3_A[1] | GRF_GPIO3A_IOMUX[2]=1&<br>GRF_SOC_CON1[13]=1  |  |  |
|            |                | I2C3 Inte  | rface                                         |  |  |



| i2c3_sda | I/O            | GPIO3_A[2] | GRF_GPIO3A_IOMUX[4]=1&  |  |
|----------|----------------|------------|-------------------------|--|
|          |                |            | GRF_SOC_CON1[14]=1      |  |
| i2c3_scl | I/O            | GPIO3_A[3] | GRF_GPIO3A_IOMUX[6]=1&  |  |
|          |                |            | GRF_SOC_CON1[14]=1      |  |
|          | I2C3 Interface |            |                         |  |
| i2c4_sda | I/O            | GPIO3_A[4] | GRF_GPIO3A_IOMUX[8]=1&  |  |
|          |                |            | GRF_SOC_CON1[15]=1      |  |
| i2c4_scl | I/O            | GPIO3_A[5] | GRF_GPIO3A_IOMUX[10]=1& |  |
|          |                |            | GRF_SOC_CON1[15]=1      |  |

# **37.7 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 following.

Transmit only mode (I2C\_CON[1:0]=2′b00)



Fig. 37-7I2C Flow chat for tx only mode

Stop

Receive only mode (I2C\_CON[1:0]=2'b10)



I2C\_MRXCNT

Fig. 37-8I2C Flow chat for rx only mode

Stop

Mix mode (I2C\_CON[1:0]=2'b01 or I2C\_CON[1:0]=2'b10)





Fig. 37-9I2C Flow chat for mix mode

# **Chapter 38 GPIO**

## 38.1 Overview

GPIO is a programmable General Purpose Programming I/O peripheral. This component is a APB slave device.GPIO controls the output data and direction of external I/O pads. It also can read back thedata on external pads using memory-mapped registers.

The features of GPIO are as follow:

- 32 bits APB bus width
- 32 independently configurable signals
- Separate data registers and data direction registers for each signal
- Software control for each signal, or for each bit of each signal
- Configurable interrupt mode for Port A
- Port A has 32 bits

Notes: Port A 32bits are corresponding to port A/B/C/D 8bits in Chapter1

# 38.2 Block Diagram



Fig. 38-1GPIO block diagram

# **Block descriptions:**

#### **APB Interface**

The APB Interface implements the APB slave operation. It's bus width is 32 bits.

#### Port I/O Interface

External data Interface to or from I/O pads.

#### **Interrupt Detection**

Interrupt interface to or from interrupt controller.



# 38.3 Function description

38.3.1 Operation

## **Control Mode(software)**

Under software control, the data and direction control for the signal aresourced from the data register (GPIO\_SWPORTA\_DR) and direction control register (GPIO\_SWPORTA\_DDR).

The direction of the external I/O pad is controlled by a write to the Porta datadirection register (GPIO\_SWPORTA\_DDR). The data written to this memory-mapped register gets mappedonto an output signal, GPIO\_PORTA\_DDR, of the GPIO peripheral. This output signal controls the direction of an external I/O pad.

The data written to the Porta data register (GPIO\_SWPORTA\_DR) drives the output buffer of the I/O pad. External data are input on the external data signal, GPIO\_EXT\_PORTA. Reading the external signal register(GPIO\_EXT\_PORTA) shows the value on the signal, regardless of the direction. This register is read-only, meaning that it cannot be written from the APB software interface.

#### **Reading External Signals**

The data on the GPIO\_EXT\_PORTA external signal can always be read. The data on the external GPIO signal is read by an APB read of the memory-mapped register, GPIO\_EXT\_PORTA.

An APB read to the GPIO\_EXT\_PORTA register yields a value equal to that which is on the GPIO\_EXT\_PORTA signal.

#### **Interrupts**

Port A can be programmed to accept external signals as interrupt sources on any of the bits of the signal. The type of interrupt is programmable with one of the following settings:

- Active-high and level
- Active-low and level
- Rising edge
- Falling edge

The interrupts can be masked by programming the GPIO\_INTMASK register. The interrupt status can be read before masking (called raw status) and after masking.

The interrupts are combined into a single interrupt output signal, which has the same polarity as the individual interrupts. In order to mask the combined interrupt, all individual interrupts have to be masked. The single combined interrupt does not have its own mask bit.



Whenever Port A is configured for interrupts, the data direction must be set to Input. If the data direction register is reprogrammed to Output, then any pending interrupts are not lost. However, no new interrupts are generated.

For edge-detected interrupts, the ISR can clear the interrupt by writing a 1 to the GPIO\_PORTA\_EOI register for the corresponding bit to disable the interrupt. This write also clears the interrupt status and raw status registers. Writing to the GPIO PORTA EOI register has no effect on level-sensitive interrupts. If level-sensitive interrupts cause the processor to interrupt, then the ISR can poll the GPIO\_INT\_RAWSTATUS register until the interrupt source disappears, or it can write to the GPIO\_INTMASK register to mask the interrupt before exiting the ISR. If the ISR exits without masking or disabling the interrupt prior to exiting, then the level-sensitive interrupt repeatedly requests an interrupt until the interrupt is cleared at the source.



Fig. 38-2 Interrupt RTL Block Diagram

#### **Debounce operation**

Port A has been configured to include the debounce capability interrupt feature. The external signal can be debounced to remove any spurious glitches that are less than one period of the external debouncing clock.

When input interrupt signals are debounced using a debounce clock(pclk), the signals must be active for a minimum of two cycles of the debounce clock to guarantee that they are registered. Any input pulse widths less than a debounce clock period are bounced. A pulse width between one and two debounce clock widths may or may not propagate, depending on its phase relationship to the debounce clock. If the input pulse spans two rising edges of the debounce clock, it is registered. If it spans only one risingedge, it is not registered.

### Synchronization of Interrupt Signals to the System Clock

Interrupt signals are internally synchronized to pclk. Synchronization topclk must occur for edge-detect signals. With level-sensitive interrupts, synchronization is optional andunder software control(GPIO\_LS\_SYNC).



#### 38.3.2 Programming

#### **Programming Considerations**

- Reading from an unused location or unused bits in a particular register always returns zeros. Thereis no error mechanism in the APB.
- Programming the GPIO registers for interrupt capability, edge-sensitive or level-sensitiveinterrupts, and interrupt polarity should be completed prior to enabling the interrupts on Port A inorder to prevent spurious glitches on the interrupt lines to the interrupt controller.
- Writing to the interrupt clear register clears an edge-detected interrupt and has no effect on alevel-sensitive interrupt.

# 6 GPIOs' hierarchy in the chip

GPIO0, GPIO1, GPIO2 are in CPU subsystem, GPIO3, GPIO4 are in peripheral subsystem, and GPIO6 is in alive subsystem.

# 38.4 Register description

This chapter describes the control/status registers of the design. Software should read and write these registers using 32-bits accesses. There are 6 GPIOs (GPIO0 ~ GPIO4, GPIO6), and each of them has same register group. Therefore, 6 GPIOs' register groups have 6 different base-address.

38.4.1 Registers Summary

| Name                   | Offset | Size | Reset<br>Value | Description                                           |
|------------------------|--------|------|----------------|-------------------------------------------------------|
| GPIO_SWPORTA_DR        | 0x0000 | W    | 0x00000000     | Port A data register                                  |
| GPIO_SWPORTA_DD<br>R   | 0x0004 | W    | 0x00000000     | Port A data direction register                        |
| GPIO_INTEN             | 0x0030 | W    | 0x00000000     | Interrupt enable register                             |
| GPIO_INTMASK           | 0x0034 | W    | 0x00000000     | Interrupt mask register                               |
| GPIO_INTTYPE_LEVE      | 0x0038 | W    | 0x00000000     | Interrupt level register                              |
| GPIO_INT_POLARITY      | 0x003C | W    | 0x00000000     | Interrupt polarity register                           |
| GPIO_INT_STATUS        | 0x0040 | W    | 0x00000000     | Interrupt status of port A                            |
| GPIO_INT_RAWSTAT<br>US | 0x0044 | w    | 0x00000000     | Raw Interrupt status of port A                        |
| GPIO_DEBOUNCE          | 0x0048 | W    | 0x00000000     | Debounce enable register                              |
| GPIO_PORTA_EOI         | 0x004C | W    | 0x00000000     | Port A clear interrupt register                       |
| GPIO_EXT_PORTA         | 0x0050 | W    | 0x00000000     | Port A external port register                         |
| GPIO_LS_SYNC           | 0x0060 | W    | 0x00000000     | Level_sensitive<br>synchronization enable<br>register |

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



# 38.4.2 Detail Register Description

# **GPIO\_SWPORTA\_DR**

Address: Operational Base + offset(0x00)

Port A data register

| Bit  | Attr | Reset Value | Description                                               |
|------|------|-------------|-----------------------------------------------------------|
|      |      |             | Values written to this register are output on the I/O     |
|      |      |             | signals for Port A if the corresponding data direction    |
| 31:0 | RW   | 0x00        | bits for Port A are set to Output mode.                   |
|      |      |             | The value read back is equal to the last value written to |
|      |      |             | this register.                                            |

# **GPIO\_SWPORTA\_DDR**

Address: Operational Base + offset(0x04)

Port A data register

| Bit  | Attr    | Reset Value | Description                                            |
|------|---------|-------------|--------------------------------------------------------|
|      |         |             | Values written to this register independently control  |
| 31:0 | 31:0 RW | 0x00        | the direction of the corresponding data bit in Port A. |
| 31.0 | KVV     |             | 0: Input (default)                                     |
|      |         |             | 1: Output                                              |

## **GPIO\_INTEN**

Address: Operational Base + offset(0x30)

Interrupt enable register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0×00        | Allows each bit of Port A to be configured for interrupts. Whenever a 1 is written to a bit of this register, it configures thecorresponding bit on Port A to become an interrupt; otherwise, Port A operates as a normal GPIO signal.  Interrupts are disabled on the corresponding bits of Port A if the corresponding data direction register is set to Output.  O: Configure Port A bit as normal GPIO signal (default)  1: Configure Port A bit as interrupt |

# GPIO\_INTMASK

Address: Operational Base + offset(0x34)

Interrupt mask register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                               |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00        | Controls whether an interrupt on Port A can create an interrupt for the interrupt controller by not masking it.  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.  0: Interrupt bits are unmasked (default)  1: Mask interrupt                                                                                                            |



#### GPIO\_INTTYPE\_LEVEL

Address: Operational Base + offset(0x38)

Interrupt level register

| Bit  | Attr | Reset Value | Description                                              |
|------|------|-------------|----------------------------------------------------------|
|      |      |             | Controls the type of interrupt that can occur on Port A. |
| 31:0 | RW   | 0x00        | 0: Level-sensitive (default)                             |
|      |      |             | 1: Edge-sensitive                                        |

#### **GPIO\_INT\_POLARITY**

Address: Operational Base + offset(0x3C)

Interrupt polarity register

| Bit  | Attr | Reset Value | Description                                             |
|------|------|-------------|---------------------------------------------------------|
|      |      |             | Controls the polarity of edge or level sensitivity that |
| 31:0 | RW   | 0×00        | can occur on input of Port A.                           |
| 31:0 | KVV  | UXUU        | 0: Active-low (default)                                 |
|      |      |             | 1: Active-high                                          |

### **GPIO\_INT\_STATUS**

Address: Operational Base + offset(0x40)

Interrupt status register

| Bit  | Attr | Reset Value | Description                |
|------|------|-------------|----------------------------|
| 31:0 | R    | 0x00        | Interrupt status of Port A |

#### **GPIO\_INT\_RAWSTATUS**

Address: Operational Base + offset(0x44)

Raw Interrupt status register

| Bit  | Attr | Reset Value | Description                                         |
|------|------|-------------|-----------------------------------------------------|
| 31:0 | R    | 0x00        | Raw interrupt of status of Port A (premasking bits) |

## GPIO\_DEBOUNCE

Address: Operational Base + offset(0x48)

Debounce enable register

| Bit  | Attr | Reset Value | Description                                              |
|------|------|-------------|----------------------------------------------------------|
| 31:0 | RW   | 0x00        | Controls whether an external signal that is the source   |
|      |      |             | of an interrupt needs to be debounced to remove any      |
|      |      |             | spurious glitches. 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.                                    |
|      |      |             | 0: No debounce (default)                                 |
|      |      |             | 1: Enable debounce                                       |

#### GPIO\_PORTA\_EOI

Address: Operational Base + offset(0x4C)

Port A clear interrupt register

| Bit  | Attr | Reset Value | Description                                             |
|------|------|-------------|---------------------------------------------------------|
| 31:0 | W    | ()x()()     | Controls the clearing of edge type interrupts from Port |
|      |      |             | A. When a 1 is written into a corresponding bit of this |



| register, the interrupt is cleared. All interrupts are |
|--------------------------------------------------------|
| cleared when Port A is not configured for interrupts.  |
| 0: No interrupt clear (default)                        |
| 1: Clear interrupt                                     |

# **GPIO\_EXT\_PORTA**

Address: Operational Base + offset(0x50)

Port A external port register

| Bit  | Attr | Reset Value | Description                                                                                                                                                     |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | R    | 0x00        | When Port A is configured as Input, then reading this location reads the values on the signal. When the data direction of Port A is set as Output, reading this |
|      |      |             | location reads the data register for Port A.                                                                                                                    |

# GPIO\_LS\_SYNC

Address: Operational Base + offset(0x60) Level sensitive synchronization enable register

| Bit  | Attr | Reset Value | Description                                                                                             |
|------|------|-------------|---------------------------------------------------------------------------------------------------------|
| 31:1 | -    | -           | Reserved                                                                                                |
| 0    | RW   | 0x00        | Writing a 1 to this register results in all level-sensitive interrupts being synchronized to pclk_intr. |
|      |      |             | 0: No synchronization to pclk_intr (default)     1: Synchronize to pclk_intr                            |

# **Chapter 39 Timer**

## 39.1 Overview

Timer is a programmable timer peripheral. This component is an APBslave device. Timers count down from a programmed value and generate an interrupt when the count reaches zero.

The features of timer are as follow:

- Three programmable 32 bits timers
- Two operation modes: free-running and user-defined count
- Maskable for each individual interrupt

# 39.2 Block Diagram



Fig. 39-1Timer Block Diagram

# 39.3 Function description

### 39.3.1 Timer clk selection

Timer0 and timer1 are in the CPU subsystem, and timer clock is 24MHz OSC; Timer2 is in the ALIVE subsystem, and timer clock is 24MHz OSC.

# 39.3.2 Programming sequence

- 1. Initialize the timer through the TIMER1\_CONTROLREG register:
  - a. Disable the timer by writing a "0" to the timer enable bit (bit 0); accordingly, the timer\_enoutput signal is de-asserted.
  - b. Program the timer mode—user-defined or free-running—by writing a "0" or "1," respectively, to the timer mode bit (bit 1).
  - c. Set the interrupt mask as either masked or not masked by writing a "0" or "1," respectively, tothe timer interrupt mask bit (bit 2).
- 2. Load the timer counter value into the TIMER1\_LOAD\_COUNT register.
- 3. Enable the timer by writing a "1" to bit 0 of TIMER1\_CONTROLREG.

Timers Usage flow





Fig. 39-2 Timer Usage Flow

#### 39.3.3 Enabling and Disabling a Timer

You use bit 0 of the TIMER1 CONTROLREG, to either enable or disable a timer.

#### **Enabling a Timer**

If you want to enable a timer, you write a "1" to bit 0 of its TIMER1 CONTROLREG register.

#### Disabling a Timer

To disable a timer, write a "0" to bit 0 of its TIMER1\_CONTROLREG register. When a timer is enabled and running, its counter decrements on each rising edge of its clock signal, timer\_N\_clk. When a timer transitions from disabled to enabled, the current value of its TIMER1 LOAD COUNT register is loaded into the timer counter on the next rising edge of timer\_N\_clk.

When the timer enable bit is de-asserted and the timer stops running, the timer counter and any associated registers in the timer clock domain, such as the toggle register, are asynchronously reset.

When the timer enable bit is asserted, then a rising edge on the timer\_en signal is used to load the initial value into the timer counter. A "0" is always read back when the timer is not enabled.

#### 39.3.4 Loading a Timer Countdown Value

The initial value for each timer—that is, the value from which it counts down—is loaded into the timer using the appropriate load count register (TIMER1 LOAD COUNT). Two events can cause a timer to load the initial count from its TIMER1\_LOAD\_COUNT register:

- Timer is enabled after being reset or disabled
- Timer counts down to 0

When a timer counts down to 0, it loads one of two values, depending on the timer operating mode:

- User-defined count mode Timer loads the current value of the TIMER1\_LOAD\_COUNT register. Use this mode if you want a fixed, timed interrupt. Designate this mode by writing a "1" to bit 1 of TIMER1 CONTROLREG.
- Free-running mode Timer loads the maximum value, which is dependent on the timer width; that is, the TIMER1\_LOAD\_COUNT register is comprised of 2TIMER\_WIDTH\_N - 1 bits, all of which are loaded with 1s. The timer counter wrapping to its maximum value allows time to reprogram or disable the timer before another interrupt occurs. Use this mode if you want a single timed interrupt. Designate this mode by writing a "0" to bit 1 of TIMER1\_CONTROLREG.



# 39.4 Register description

This chapter describes the control/status registers of the design. Software should read and write these registers using 32-bits accesses.

There are 3 individual timers. (Timer0 ~ Timer2)

#### 39.4.1 Registers Summary

| Name                     | Offset | Size | Reset<br>Value | Description                             |
|--------------------------|--------|------|----------------|-----------------------------------------|
| TIMER1_LOAD_COUN<br>T    | 0x0000 | W    | 0x00000000     | Timer1 Load Count Register              |
| TIMER1_CURRENT_V<br>ALUE | 0x0004 | W    | 0x00000000     | Timer1 Current Value Register           |
| TIMER1_CONTROLRE G       | 0x0008 | W    | 0x00000000     | Timer1 Control Register                 |
| TIMER1_EOI               | 0x000C | W    | 0x0000000      | Timer1 End-of-Interrupt<br>Register     |
| TIMER1_INTSTATUS         | 0x0010 | W    | 0x0000000      | Timer1 Interrupt Status<br>Register     |
| TIMERS_INTSTATUS         | 0x00a0 | W    | 0x0000000      | Timers Interrupt Status<br>Register     |
| TIMERS_EOI               | 0x00a4 | W    | 0x0000000      | Timers End-of-Interrupt<br>Register     |
| TIMERS_RAWSTATUS         | 0x00a8 | w    | 0x0000000      | Timers Raw Interrupt Status<br>Register |

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

### 39.4.2 Detail Register Description

### TIMER1\_LOAD\_COUNT

Address: Operational Base + offset(0x00)

Timer1 Load Count Register

| Bit  | Attr | Reset Value | Description                                                                      |
|------|------|-------------|----------------------------------------------------------------------------------|
| 31:0 | RW   | 0x1f        | Value to be loaded into Timer1. This is the value from which counting commences. |

## TIMER1\_CURRENT\_VALUE

Address: Operational Base + offset(0x04)

Timer1 Current Value Register

| Bit  | Attr | Reset Value | Description              |
|------|------|-------------|--------------------------|
| 31:0 | R    | 0x1f        | Current Value of Timer1. |

#### TIMER1\_CONTROLREG

Address: Operational Base + offset(0x08)

Timer1 Control Register

| Bit  | Attr | Reset Value | Description           |
|------|------|-------------|-----------------------|
| 31:3 | -    | -           | Reserved              |
|      |      |             | Timer interrupt mask. |
| 2    | RW   | 0x0         | 0: not mask           |
|      |      |             | 1: mask               |



| 1 | RW | 0x0 | Timer mode. 0: free-running mode 1: user-defined count mode |
|---|----|-----|-------------------------------------------------------------|
| 0 | RW | 0x0 | Timer enable. 0: disable 1: enable                          |

#### TIMER1\_EOI

Address: Operational Base + offset(0x0C)

Timer1 End-of-Interrupt Register

| Bit  | Attr | Reset Value | Description                                                                     |
|------|------|-------------|---------------------------------------------------------------------------------|
| 31:1 | -    | -           | Reserved                                                                        |
| 0    | R    | 0x0         | Reading from this register returns all zeros(0) and clear interrupt from timer1 |

#### TIMER1\_INTSTATUS

Address: Operational Base + offset(0x10)

Timer1 Interrupt Status Register

| Bit  | Attr | Reset Value | Description                                            |
|------|------|-------------|--------------------------------------------------------|
| 31:1 | -    | -           | Reserved                                               |
| 0    | R    | 0x0         | This register contains the interrupt status for timer1 |

### TIMERS\_INTSTATUS

Address: Operational Base + offset(0xa0)

Timers Interrupt Status Register

| Bit  | Attr | Reset Value | Description                                            |
|------|------|-------------|--------------------------------------------------------|
| 31:3 | -    | -           | Reserved                                               |
| 2    | R    | 0x0         | This register contains the interrupt status for timer3 |
| 1    | R    | 0x0         | This register contains the interrupt status for timer2 |
| 0    | R    | 0x0         | This register contains the interrupt status for timer1 |

#### TIMERS EOI

Address: Operational Base + offset(0xa4)

Timers End-of-Interrupt Register

| Bit  | Attr | Reset Value | Description                                                                         |
|------|------|-------------|-------------------------------------------------------------------------------------|
| 31:3 | -    | -           | Reserved                                                                            |
| 2:0  | R    | 0x0         | Reading from this register returns all zeros(0) and clear interrupt from all timers |

## TIMERS\_RAWSTATUS

Address: Operational Base + offset(0xa8) Timers Raw Interrupt Status Register

| Bit  | Attr | Reset Value | Description                                                             |
|------|------|-------------|-------------------------------------------------------------------------|
| 31:3 | -    | -           | Reserved                                                                |
| 2    | R    | 0x0         | This register contains the interrupt status for timer3 prior to masking |
| 1    | R    | 0x0         | This register contains the interrupt status for timer2 prior to masking |
| 0    | R    | 0x0         | This register contains the interrupt status for timer1 prior to masking |

Notes: Attr: **RW** - Read/writable, **R** - read only, **W** - write only

# 39.5 Application Notes

#### timer0 ~ timer2 usage flow

Timer0 and timer1 are in the CPU subsystem, timer2 is in the ALIVE subsystem, and the timer clock of timer0 ~ timer2 is 24MHz OSC. In this case, the timer\_clk signal is asynchronous to pclk;

In the condition of the timer\_clk signal is asynchronous to pclk. When you disable the timer enable bit (bit 0 of TIMER1\_CONTROLREG), the timer\_en output signal is de-asserted and, accordingly, timer\_clk should stop. Then when you enable the timer, the timer\_en signal is asserted and timer\_clk should start running.



Fig. 39-3Timing of Timer\_en and Timer\_clk (timer\_clk is async to pclk)

When the timer\_clk signal is asynchronous to pclk, the timer usage flow is as follow:

- 1. Before using the timer, make sure that the timer\_clk and timer\_en are disabled. (Disable timer0 ~ timer2 clock by writing "1" into CRU\_CLKGATE1\_CON bit0~bit2 respectively, and disable timer\_en by writing a "0" to the timer enable bit (TIMER1\_CONTROLREGbit0))
- 2. Initialize the timer through the TIMER1\_CONTROLREG register:
  - a. Program the timer mode—user-defined or free-running—by writing a "0" or "1," respectively, to the timer mode bit (bit 1).
  - b. Set the interrupt mask as either masked or not masked by writing a "0" or "1," respectively, tothe timer interrupt mask bit (bit 2).
- 3. After timer initialization, enable timer\_en firstly. (enable the timer by writing a "1" to bit 0 of TIMER1\_CONTROLREG)
- 4.After timer\_en enabled, enable timer\_clk. (enable timer0 ~timer2 clock by writing "0" into CRU\_CLKGATE1\_CONbit0~bit2 respectively.)
- 5. When you want to disable the timer, firstly, disable the timer\_en.
- 6. After timer\_en diabled, disable the timer\_clk.

Timers Usage flow(timer\_clk signal is asynchronous to pclk)



Fig. 39-4Timer0 and Timer1Usage Flow

## **Chapter 40 PWM**

#### 40.1 Overview

There are four PWM blocks in PWM Timer (PWM0, PWM1, PWM2 and PWM3). Each PWM block built-in 4-bit pre-scalar from PCLK. The PWM Timer supports both reference mode, which can output various duty-cycle waveforms, and capture, which can measure the duty-cycle of input waveform.

#### 40.1.1 Features

- Built-in three 32 bit timer modulers
- Programmable counter
- Chained timer for long period purpose
- 4-channel 32-bit timer with Pulse Width Modulation(PWM)
- Support maskable interrupt

# 40.2 Block Diagram



Fig. 40-1 PWM architecture

#### **PWM Register Block**

This block controls the setting of PWM mode.

## **PWM Circuitry**

This block includes clock pre-scalar and reference comparator for PWM timer.

#### **Interrupt Generator**

This block handles the interrupt generation, masking, and clearing.

# 40.3 Register description

#### 40.3.1 Register Summary

| Name | Offset Si | Sizo | Reset | Description |
|------|-----------|------|-------|-------------|
| Name | Oliset    | Size | Value | Description |



| Name      | Offset | Size | Reset<br>Value | Description                         |
|-----------|--------|------|----------------|-------------------------------------|
| PWM0_CNTR | 0x0000 | W    | 0x00000000     | Main counter register               |
| PWM0_HRC  | 0x0004 | W    | 0x00000000     | PWM HIGH Reference/Capture register |
| PWM0_LRC  | 0x0008 | W    | 0x00000000     | PWM LOW Reference/Capture register  |
| PWM0_CTRL | 0x000c | W    | 0x0000000      | Current value register              |
| PWM1_CNTR | 0x0010 | W    | 0x00000000     | Main counter register               |
| PWM1_HRC  | 0x0014 | W    | 0x00000000     | PWM HIGH Reference/Capture register |
| PWM1_LRC  | 0x0018 | W    | 0x00000000     | PWM LOW Reference/Capture register  |
| PWM1_CTRL | 0x001c | W    | 0x0000000      | Current value register              |
| PWM2_CNTR | 0x0020 | W    | 0x00000000     | Main counter register               |
| PWM2_HRC  | 0x0024 | W    | 0x00000000     | PWM HIGH Reference/Capture register |
| PWM2_LRC  | 0x0028 | W    | 0x0000000      | PWM LOW Reference/Capture register  |
| PWM2_CTRL | 0x002c | W    | 0x00000000     | Current value register              |
| PWM3_CNTR | 0x0030 | W    | 0x0000000      | Main counter register               |
| PWM3_HRC  | 0x0034 | W    | 0x00000000     | PWM HIGH Reference/Capture register |
| PWM3_LRC  | 0x0038 | W    | 0x0000000      | PWM LOW Reference/Capture register  |
| PWM3_CTRL | 0x003c | W    | 0x0000000      | Current value register              |

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

### 40.3.2 Detail Register Description

### PWMn\_CNTR (n=0~3)

Address: Operational Base + offset (0x00, 0x10, 0x20, 0x30)

Main counter register

| Bit  | Attr | Reset Value | Description                                               |
|------|------|-------------|-----------------------------------------------------------|
| 31:0 | RW   |             | main_pwm_timer_cnt Main PWM timer counter. Counting value |
|      |      |             | ranges from $0 \sim (2^32 - 1)$ .                         |

### PWMn\_HRC (n=0~3)

Address: Operational Base + offset (0x04, 0x14, 0x24, 0x34)

PWM HIGH Reference/Capture register

| Bit  | Attr | Reset Value | Description                                             |
|------|------|-------------|---------------------------------------------------------|
| 31:0 | RW   | 10×00000000 | high_reference_cap PWM HIGH reference/capture registers |

### PWMn\_LRC (n=0~3)

Address: Operational Base + offset (0x08, 0x18, 0x28, 0x38)

PWM LOW Reference/Capture register



## PWMn\_CTRL (n=0~3)

Address: Operational Base + offset (0x0C, 0x1C, 0x2C, 0x3C)

Current value register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                      |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13 | RO   | 0x0         | reserved                                                                                                                                                                                                         |
| 12:9  | RW   | 0×0         | prescale_factor  Prescale factor.  0000: 1/2                                                                                                                                                                     |
| 8     | RW   | 0×0         | cap_mode_en Capture mode enable/disable 0: Disable 1: Enable                                                                                                                                                     |
| 7     | W1C  | 0x0         | pwm_reset PWM reset. 0: Normal operation 1: Reset PWM                                                                                                                                                            |
| 6     | W1C  | 0x0         | int_status_clr Interrupt status and clear bit. Write "1" to clear interrupt status.                                                                                                                              |
| 5     | RW   | 0x0         | pwm_timer_int_en PWM timer interrupt enable/disable. PWM timer will assert an interrupt when PWMTx_CNTR value is equal to the value of PWMTx_LRC or PWMTx_HRC. 0: Disable 1: Enable                              |
| 4     | RW   | 0x0         | single_cnt_mode Single counter mode. 0: PWMTx_CNTR is restarted after it reaches value equal to the PWMTx_LRC value. 1: PWMTx_CNTR is not increased anymore after it reaches value equal to the PWMTx_LRC value. |
| 3     | RW   | 0×0         | pwm_output_en PWM output enable/disable. 0: Disable 1: Enable                                                                                                                                                    |



| Bit | Attr | Reset Value | Description               |
|-----|------|-------------|---------------------------|
| 2:1 | RO   | 0x0         | reserved                  |
|     |      |             | pwm_timer_en              |
| 0   | RW   | 0x0         | PWM timer enable/disable. |
|     |      |             | 0: Disable 1: Enable      |

# **40.4 Interface description**

Table 40-1 PWM Interface Description

| Table to 11 Will interface Description |           |            |                        |  |  |
|----------------------------------------|-----------|------------|------------------------|--|--|
| Module pin                             | Direction | Pad name   | IOMUX                  |  |  |
| pwm3                                   | 0         | GPIO0_D[7] | GRF_GPIO0D_IOMUX[14]=1 |  |  |
| pwm2                                   | 0         | GPIO0_D[6] | GRF_GPIO0D_IOMUX[12]=1 |  |  |
| pwm1                                   | 0         | GPIO0_A[4] | GRF_GPIO0A_IOMUX[8]=1  |  |  |
| pwm0                                   | 0         | GPIO0_A[3] | GRF_GPIO0A_IOMUX[6]=1  |  |  |

# **Chapter 41 WatchDog**

#### 41.1 Overview

Watchdog Timer (WDT) is an APB slave peripheral that can be used to prevent system lockup that may becaused by conflicting parts or programs in a SoC.The WDT would generated interrupt or reset signal when it's counter reaches zero, then a reset controller would reset the system.

The features of WDT are as follow:

- 32 bits APB bus width
- WDT counter's clock is pclk
- 32 bits WDT counter width
- Counter counts down from a preset value to 0 to indicate the occurrence of a timeout
- WDT can perform two types of operations when timeout occurs:
  - (1) Generate a system reset;
  - (2) 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

## 41.2 Block Diagram



Fig. 41-1WDT block diagram

#### **Block Descriptions:**

#### **APB Interface**

The APB Interface implements the APB slave operation. It's bus width is 32 bits.

#### Register Block

A register block with read coherency for the current count register.

#### **Interrupt & system reset control**

An interrupt/system reset generation block comprising of a decrementing counter and control logic.

# 41.3 Function Description

41.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 to as kicking the dog. As a safety feature to prevent accidental restarts, the value 0x76 must be written to the Current Counter Value Register (WDT\_CRR).

#### **Interrupts**

The WDT can be programmed to generate an interrupt (and then a system reset) when a timeout occurs. When a 1 is written to the response mode field (RMOD, bit 1) of the Watchdog Timer Control Register (WDT CR), the WDT generates an interrupt. If it is not cleared by the time a second timeout occurs, then it generates a system reset. If a restart occurs at the same time the watchdog counter reaches zero, an interrupt is not generated.

#### **System Resets**

When a 0 is written to the output response mode field (RMOD, bit 1) of the Watchdog Timer Control Register (WDT\_CR), the WDT generates a system reset when a timeout occurs.

#### **Reset Pulse Length**

The reset pulse length is the number of pclk cycles for which a system reset is asserted. When a system reset is generated, it remains asserted for the number of cycles specified by the reset pulse length or until the system is reset. A counter restart has no effect on the system reset once it has been asserted.

41.3.2 Programming sequence

Operation Flow Chart (Response mode=1)





Fig. 41-2WDT Operation Flow

# 41.4 Register description

### 41.4.1 Register Summary

| Name     | Offset | Size | Reset<br>Value | Description                    |
|----------|--------|------|----------------|--------------------------------|
| WDT_CR   | 0x0000 | W    | 0x0000000a     | Control Register               |
| WDT_TORR | 0x0004 | W    | 0x00000000     | Timeout range Register         |
| WDT_CCVR | 0x0008 | W    | 0x00000000     | Current counter value Register |
| WDT_CRR  | 0x000c | W    | 0x00000000     | Counter restart Register       |
| WDT_STAT | 0x0010 | W    | 0x00000000     | Interrupt status Register      |
| WDT_EOI  | 0x0014 | W    | 0x00000000     | Interrupt clear Register       |

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

#### 41.4.2 Detail Register Description

## WDT\_CR

Address: Operational Base + offset (0x0000)

Control Register

| Bit Attr Reset Value Description |  |
|----------------------------------|--|
|----------------------------------|--|



| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                               |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                  |
| 4:2  | RW   | 0x2         | rst_pluse_lenth Reset pulse length. This is used to select the number of pclk cycles for which the system reset stays asserted. 000: 2 pclk cycles 001: 4 pclk cycles 010: 8 pclk cycles 011: 16 pclk cycles 100: 32 pclk cycles 101: 64 pclk cycles 111: 356 pclk cycles |
| 1    | RW   | 0×1         | resp_mode Response mode. Selects the output response generated to a timeout. 0: Generate a system reset. 1: First generate an interrupt and if it is not cleared by the time a second timeout occurs then generate a system reset.                                        |
| 0    | RW   | 0x0         | wdt_en WDT enable 0: WDT disabled; 1: WDT enabled.                                                                                                                                                                                                                        |

# WDT\_TORR

Address: Operational Base + offset (0x0004)

Timeout range Register

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:4 | RO   | 0x0         | reserved    |



| Bit | Attr | Reset Value | Description                                     |
|-----|------|-------------|-------------------------------------------------|
|     |      |             | timeout_period                                  |
|     |      |             | Timeout period.                                 |
|     |      |             | 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).          |
|     |      |             | The range of values available for a 32-bit      |
|     |      |             | watchdog counter are:                           |
|     |      |             | 0000: 0x0000ffff                                |
|     |      |             | 0001: 0x0001ffff                                |
|     |      |             | 0010: 0x0003ffff                                |
| 3:0 | RW   | 0x0         | 0011: 0x0007ffff                                |
|     |      |             | 0100: 0x000fffff                                |
|     |      |             | 0101: 0x001fffff                                |
|     |      |             | 0110: 0x003fffff                                |
|     |      |             | 0111: 0x007fffff                                |
|     |      |             | 1000: 0x00ffffff                                |
|     |      |             | 1001: 0x01ffffff                                |
|     |      |             | 1010: 0x03ffffff                                |
|     |      |             | 1011: 0x07ffffff                                |
|     |      |             | 1100: 0x0ffffff                                 |
|     |      |             | 1101: 0x1ffffff                                 |
|     |      |             | 1110: 0x3ffffff                                 |
|     |      |             | 1111: 0x7fffffff                                |

## WDT\_CCVR

Address: Operational Base + offset (0x0008)

Current counter value Register

| Bit      | Attr | Reset Value | Description                                    |
|----------|------|-------------|------------------------------------------------|
|          |      | 7           | cur_cnt                                        |
|          |      |             | Current counter value                          |
| 31:0     | RO   | 0x0000000   | This register, when read, is the current value |
| <b>Y</b> |      |             | of the internal counter. This value is read    |
|          |      |             | coherently when ever it is read                |

### WDT\_CRR

Address: Operational Base + offset (0x000c)

Counter restart Register

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:8 | RO   | 0x0         | reserved    |



| Bit | Attr | Reset Value | Description                                    |
|-----|------|-------------|------------------------------------------------|
|     |      |             | cnt_restart                                    |
|     |      |             | Counter restart                                |
|     |      |             | This register is used to restart the WDT       |
| 7:0 | W1C  | 0x00        | 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)

Interrupt status Register

| Bit  | Attr | Reset Value | Description                                                                                                                              |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x0         | reserved                                                                                                                                 |
| 0    | RO   | 0x0         | wdt_status This register shows the interrupt status of the WDT. 1: Interrupt is active regardless of polarity; 0: Interrupt is inactive. |

## WDT\_EOI

Address: Operational Base + offset (0x0014)

Interrupt clear Register

| Bit  | Attr | Reset Value | Description                                    |
|------|------|-------------|------------------------------------------------|
| 31:1 | RO   | 0x0         | reserved                                       |
|      | RO   | • 0         | wdt_int_clr                                    |
|      |      | 0x0         | Clears the watchdog interrupt. This can be     |
| 0    |      |             | used to clear the inter                        |
| U    |      |             | Clears the watchdog interrupt. This can be     |
|      |      |             | used to clear the interrupt without restarting |
|      |      | Y           | the watchdog counter.                          |

## Chapter 42 SAR-ADC

#### 42.1 Overview

The ADC is an 4-channel signal-ended 10-bit Successive Approximation Register (SAR) A/D Converter. It uses the supply and ground as it reference which avoid use of any external reference . It converts the analog input signal into 10-bit binary digital codes at maximum conversion rate of 100KSPS with 1MHz A/D converter clock .

## 42.2 Block Diagram



Fig. 42-1RK30xx SAR-ADC block diagram

#### **Successive-Approximate Register and Control Logic Block**

This block is exploited to realize binary search algorithm, storing the intermediate result and generate control signal for analog block.

#### **Comparator Block**

This block compares the analog input SARADC\_AIN[3:0] with the voltage generated from D/A Converter, and output the comparison result to SAR and Control Logic Block for binary search. Three level amplifiers are employed in this comparator to provide enough gain.

# 42.3 Function Description

In RK30xx, SAR-ADC work at single-sample operation mode.

#### Single-sample conversion

This mode is useful to sample an analog input when there is a gap between two samples to be converted. In this mode START is asserted only on the rising edge of CLKIN where conversion is needed. At the end of every conversion EOC signal is made high and valid output data is available at the rising edge of EOC. The detailed timing diagram will be shown in the following.

# 42.4 Register description

#### 42.4.1 Register Summary

| Name              | Offset | Size | Reset<br>Value | Description                                           |
|-------------------|--------|------|----------------|-------------------------------------------------------|
| SARADC_DATA       | 0x0000 | W    | 0x00000000     | This register contains the data after A/D Conversion. |
| SARADC_STAS       | 0x0004 | W    | 0x00000000     | The status register of A/D Converter.                 |
| SARADC_CTRL       | 0x0008 | W    | 0x00000000     | The control register of A/D Converter.                |
| SARADC_DLY_PU_SOC | 0x000c | W    | 0×00000000     | delay between power up and start command              |

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

### 42.4.2 Detail Register Description

### SARADC\_DATA

Address: Operational Base + offset (0x0000)

This register contains the data after A/D Conversion.

| Bit   | Attr | Reset Value         | Description                                            |
|-------|------|---------------------|--------------------------------------------------------|
| 31:10 | RO   | 0x0                 | reserved                                               |
| 9:0   | RO   | 1() <b>x</b> ()()() | adc_data A/D value of the last conversion (DOUT[9:0]). |

### SARADC\_STAS

Address: Operational Base + offset (0x0004)

The status register of A/D Converter.

| Bit  | Attr | Reset Value | Description                |
|------|------|-------------|----------------------------|
| 31:1 | RO   | 0x0         | reserved                   |
|      |      | 7           | adc_status                 |
|      | RO   | $I()\chi()$ | ADC status (EOC)           |
|      |      |             | 0: ADC stop;               |
|      |      |             | 1: Conversion in progress. |

## SARADC\_CTRL

Address: Operational Base + offset (0x0008)

The control register of A/D Converter.

| Bit  | Attr | Reset Value | Description |  |
|------|------|-------------|-------------|--|
| 31:7 | RO   | 0x0         | reserved    |  |



| Bit | Attr | Reset Value | Description                                  |
|-----|------|-------------|----------------------------------------------|
|     |      |             | int_status                                   |
|     |      |             | Interrupt status.                            |
| 6   | RW   | 0x0         | This bit will be set to 1 when               |
|     |      |             | end-of-conversion.                           |
|     |      |             | Set 0 to clear the interrupt.                |
|     |      |             | int_en                                       |
| 5   | RW   | 0×0         | Interrupt enable.                            |
|     | KVV  | UXU         | 0: Disable;                                  |
|     |      |             | 1: Enable                                    |
| 4   | RO   | 0x0         | reserved                                     |
|     |      |             | adc_power_ctrl                               |
|     |      |             | ADC power down control bit                   |
| 3   | RW   | 0×0         | 0: ADC power down;                           |
|     | KVV  | UXU         | 1: ADC power up and reset.                   |
|     |      |             | start signal will be asserted (DLY_PU_SOC+2) |
|     |      |             | sclk clock period later after power up       |
|     |      |             | adc_input_src_sel                            |
|     |      | 0x0         | ADC input source selection(CH_SEL[2:0]).     |
|     |      |             | 111 : Input source 0 (SARADC_AIN[0])         |
| 2:0 | RW   |             | 110 : Input source 1 (SARADC_AIN[1])         |
|     |      |             | 101 : Input source 2 (SARADC_AIN[2])         |
|     |      |             | 100 : Input source 3 (SARADC_AIN[3])         |
|     |      |             | Others: Reserved                             |

# SARADC\_DLY\_PU\_SOC

Address: Operational Base + offset (0x000c) delay between power up and start command

| Bit      | Attr | Reset Value | Description                              |
|----------|------|-------------|------------------------------------------|
| 31:6     | RO   | 0x0         | reserved                                 |
|          |      | 7           | DLY_PU_SOC                               |
|          |      |             | delay between power up and start command |
| 5:0      | RW   | 0x08        | The start signal will be asserted        |
|          | V    |             | (DLY_PU_SOC + 2) sclk clock period later |
| <b>Y</b> |      |             | after power up                           |

# **42.5 Timing Diagram**



Fig. 42-2SAR-ADC timing diagram in single-sample conversion mode

# **42.6 Application Notes**

The following is an example sequence of setting up A/D Converter, starting of conversion, and acquiring the result value.

- Power-down A/D Converter in SARADC\_CTRL[3]
- Power-up A/D Converter in SARADC\_CTRL[3] and select input channel of A/D Converter in SARADC\_CTRL[2:0] bit
- Wait an A/D interrupt or poll the SARADC\_STAS register to determine when the conversion is completed
- Read the conversion result in the SARADC\_DATA register

Another, as for input clock period of SAR-ADC, it must be minimum 1000ns.

## Chapter 43 TS-ADC

#### 43.1 Overview

TS-ADC is a temperature-sensor IP providing an accuracy of  $\pm$ 0 °C without trim on the Temp sense core (for temp range  $\pm$ 40 °C to 125 °C).

The IP comprises of a bipolar-based temperature-sensing cell that converts temperature into an analog voltage, and a 12-bit SAR ADC that operates on the sensed analog value to provide a 12-bit digital readout. The IP supports 2-channel input; 1 channel connected to internal temperature sensor cell and 1 channels for external temperature measurement. The sensed analog values are routed to the ADC. Internal or external sensors can be controlled by channel select bits.

## 43.2 Block Diagram



Fig. 43-1RK30xx TS-ADC block diagram

#### **Successive-Approximate Register and Control Logic Block**

This block is exploited to realize binary search algorithm, storing the intermediate result and generate control signal for analog block.

### **Comparator Block**

This block compares the analog input SARADC\_AIN[3:0] with the voltage generated from D/A Converter, and output the comparison result to SAR and Control Logic Block for binary search. Three level amplifiers are employed in this comparator to provide enough gain.

# 43.3 Function description

In RK30xx, TS-ADC work at single-sample operation mode.

#### Single-sample conversion

This mode is useful to sample an analog input when there is a gap between two samples to be converted. In this mode START is asserted only on the rising edge of CLKIN where conversion is needed. At the end of every conversion EOC signal is made high and valid output data is available at the rising edge of EOC. The detailed timing diagram will be shown in the following.

Temperature to code mapping

| tama (C) | Cada |
|----------|------|
| temp (C) | Code |
| -40      | 3800 |
| -35      | 3792 |
| -30      | 3783 |
| -25      | 3774 |
| -20      | 3765 |
| -15      | 3756 |
| -10      | 3747 |
| -5       | 3737 |
| 0        | 3728 |
| 5        | 3718 |
| 10       | 3708 |
| 15       | 3698 |
| 20       | 3688 |
| 25       | 3678 |
| 30       | 3667 |
| 35       | 3656 |
| 40       | 3645 |
| 45       | 3634 |
| 50       | 3623 |
| 55       | 3611 |
| 60       | 3600 |
| 65       | 3588 |
| 70       | 3575 |
| 75       | 3563 |
| 80       | 3550 |
| 85       | 3537 |
| 90       | 3524 |
| 95       | 3510 |
| 100      | 3496 |
| 105      | 3482 |
| 110      | 3467 |
| 115      | 3452 |
| 120      | 3437 |
| 125      | 3421 |
|          |      |

# 43.4 Register description

## 43.4.1 Register Summary

| Name             | Offset | Size | Reset<br>Value | Description                                           |
|------------------|--------|------|----------------|-------------------------------------------------------|
| TSADC_DATA       | 0x0000 | W    | 0x00000000     | This register contains the data after A/D Conversion. |
| TSADC_STAS       | 0x0004 | W    | 0x00000000     | The status register of A/D Converter.                 |
| TSADC_CTRL       | 0x0008 | W    | 0x00000000     | The control register of A/D Converter.                |
| TSADC_DLY_PU_SOC | 0x000c | W    | 0x00000008     | delay between power up and start command              |

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

### 43.4.2 Detail Register Description

## TSADC\_DATA



Address: Operational Base + offset (0x0000)

This register contains the data after A/D Conversion.

| Bit   | Attr | Reset Value | Description                      |
|-------|------|-------------|----------------------------------|
| 31:12 | RO   | 0x0         | reserved                         |
|       |      |             | adc_data                         |
| 11:0  | RO   | 0x000       | A/D value of the last conversion |
|       |      |             | (DOUT[11:0]).                    |

## TSADC\_STAS

Address: Operational Base + offset (0x0004)

The status register of A/D Converter.

| Bit  | Attr | Reset Value | Description                 |  |
|------|------|-------------|-----------------------------|--|
| 31:1 | RO   | 0x0         | reserved                    |  |
| 0    | RO   | 0x0         | adc_status ADC status (EOC) |  |
| U    |      |             | 0: ADC stop;                |  |
|      |      |             | 1: Conversion in progress.  |  |

## TSADC\_CTRL

Address: Operational Base + offset (0x0008)

The control register of A/D Converter.

| Bit  | Attr | Reset Value | Description                                   |  |  |
|------|------|-------------|-----------------------------------------------|--|--|
| 31:7 | RO   | 0x0         | reserved                                      |  |  |
|      |      |             | int_status                                    |  |  |
|      |      |             | Interrupt status.                             |  |  |
| 6    | RW   | 0x0         | This bit will be set to 1 when                |  |  |
|      |      | 1           | end-of-conversion.                            |  |  |
|      |      | AC y        | Set 0 to clear the interrupt.                 |  |  |
|      | RW   | 0×0         | int_en                                        |  |  |
| 5    |      |             | Interrupt enable.                             |  |  |
| ٦    |      |             | 0: Disable;                                   |  |  |
|      |      |             | 1: Enable                                     |  |  |
|      | 00   |             | start_convert                                 |  |  |
|      |      | 0×0         | Start of Conversion(START)                    |  |  |
| 4    | RW   |             | Set this bit to 1 to start an ADC conversion. |  |  |
|      |      |             | This bit will reset to 0 by hardware when ADC |  |  |
|      |      |             | conversion has started.                       |  |  |
| 3    | RW   | 0x0         | adc_power_ctrl                                |  |  |
|      |      |             | ADC power down control bit                    |  |  |
| ٦    |      |             | 0: ADC power down;                            |  |  |
|      |      |             | 1: ADC power up and reset.                    |  |  |

| Bit    | Attr | Reset Value | Description                              |  |  |
|--------|------|-------------|------------------------------------------|--|--|
|        |      |             | adc_input_src_sel                        |  |  |
|        |      |             | ADC input source selection(CH_SEL[2:0]). |  |  |
|        |      |             | 111 : Input source 0 (SARADC_AIN[0])     |  |  |
| 2:0 RW |      | 0x0         | 110 : Input source 1 (SARADC_AIN[1])     |  |  |
|        |      |             | 101 : Input source 2 (SARADC_AIN[2])     |  |  |
|        |      |             | 100 : Input source 3 (SARADC_AIN[3])     |  |  |
|        |      |             | Others: Reserved                         |  |  |

### TSADC\_DLY\_PU\_SOC

Address: Operational Base + offset (0x000c) delay between power up and start command

| Bit  | Attr | Reset Value | Description                              |  |  |
|------|------|-------------|------------------------------------------|--|--|
| 31:6 | RO   | 0x0         | reserved                                 |  |  |
| 5:0  | RW   | 10x08       | DLY_PU_SOC                               |  |  |
|      |      |             | delay between power up and start command |  |  |

# 43.5 Timing Diagram



Fig. 43-2TS-ADC timing diagram in single-sample conversion mode

# **43.6 Application Notes**

The following is an example sequence of setting up A/D Converter, starting of conversion, and acquiring the result value.

- Power-down A/D Converter in TSADC\_CTRL[3]
- Power-up A/D Converter in TSADC\_CTRL[3] and select input channel of A/D Converter in TSADC\_CTRL[2:0] bit
- Wait an A/D interrupt or poll the TSADC\_STAS register to determine



when the conversion is completed

• Read the conversion result in the TSADC\_DATA register

Another, as for input clock period of TS-ADC, it must be minimum 20us.



# **Chapter 44 eFuse**

#### 44.1 Overview

In RK30xx, eFuse is organized as 32bits by 8 one-time programmable electrical fuses with random access interface. It is a type of non-volatile memory fabricated in standard CMOS logic process. The main features are as follows:

- Programming condition : EFUSE\_VDDQ =  $2.5V\pm10\%$  , Program time : 10us  $\pm1$ us .
- Read condition : EFUSE\_VDDQ = 0V or floating or  $(2.5V \pm 10\%)$
- Embedded power-switch
- Provide power-down and standby mode

For detailed information about eFuse, please refer to RK30xx eFuse.pdf.

# **Chapter 45 Chip Test Solution**

### 45.1 Overview

In RK30xx, there are lots of test modes for different intention as the following table, which will be decided by signals test and  $testmode_i(i=0~3)$ , which is muxed with function GPIO.

Table 45-1 RK30xx test mode list

| TEST | testmode3 | testmode2 | testmode1 | testmode0 | mode description                                           |
|------|-----------|-----------|-----------|-----------|------------------------------------------------------------|
| 0    | Х         | Х         | Х         | Х         | Normal mode                                                |
| 1    | 0         | 0         | 0         | 0         | SOC general scan test mode                                 |
| 1    | 0         | 0         | 0         | 1         | SOC at-speed scan test mode                                |
| 1    | 0         | 0         | 1         | 0         | SOC general memory bist mode / SOC general Rom bist mode   |
| 1    | 0         | 0         | 1         | 1         | SOC at-speed memory bist mode / SOC at-speed Rom bist mode |
| 1    | 0         | 1         | 0         | 1         | Cortex-A9(L1) at-speed memory bist mode                    |
| 1    | 0         | 1         | 1         | 0         | Cortex-A9(L2) at-speed memory bist mode                    |
| 1    | 0         | 1         | 1         | 1         | SOC leakage test mode                                      |
| 1    | 1         | 0         | 0         | 0         | USB PHY bist mode                                          |
| 1    | 1         | 0         | 0         | 1         | DDR PHY test mode                                          |
| 1    | 1         | 0         | 1         | 0         | HDMI PHY test mode                                         |
| 1    | 1         | 0         | 1         | 1         | PLL test mode                                              |
| 1    | 1         | 1         | 0         | 0         | eFuse test mode                                            |
| 1    | 1         | 1         | 0         | 1         | 10bit SAR-ADC test mode                                    |
| 1    | 1         | 1         | 1         | 0         | 12bit TS-ADC test mode                                     |

The key application notes are as follows:

- For SOC at-speed scan test mode, RK30xx provides six test solution with different internal test frequency, which is decided by signals test\_freq\_sel; (i=0~2), and need four input clocks from XIN24M,TCK,CLK32K andCLK27M input pins all with 24MHz frequency.
- For SOC at-speed memory bist mode, SOC at-speed Rom bist mode and Cortex-A9(L1/L2) at-speed memorybist mode, RK30xx provides six test solution with different test frequency, which is decided by signals test\_freq\_sel<sub>i</sub> (i=0~1), and only need one input clock from XIN24M input pin with 24MHz frequency.
- For SOC general scan test mode, RK30xx need three input clocks from TCK,CLK32K andCLK27M input pins with 24MHz frequency.
- For SOC general memory bist modeand SOC general rom bist mode,



RK30xx only need one input clock from XIN24M input pin with 24MHz frequency.

- For DDR PHY test mode and HDMI PHY test mode, RK30xx provides six test solution with different test frequency, which is decided by signals test freq sel<sub>i</sub> (i=0 $\sim$ 1), and only need one input clock from XIN24M input pin with 24MHz frequency.
- For all other test modes for internal Analog macro inside RK30xx, only need one input clock from XIN24M input pin with 24MHz frequency.
- The reset signal for all of test modes is all from NPOR input pin directly.

In the above description, some miscellaneous signals related with test mode are not dedicated pins, always mux with function pin except TEST. The detailed information is as the following list.

Table 45-2 RK30xx iomux for misc signal in test mode

| test pins      | test IO | function pins | IOMUX setting     |
|----------------|---------|---------------|-------------------|
| testmode0      | I       | GPIO6_B[0]    | TEST = high level |
| testmode1      | I       | GPIO6_B[1]    | TEST = high level |
| testmode2      | I       | GPIO6_B[2]    | TEST = high level |
| testmode3      | I       | GPIO6_B[3]    | TEST = high level |
| test_freq_sel0 | I       | GPIO6_B[5]    | TEST = high level |
| test_freq_sel1 | I       | GPIO6_B[6]    | TEST = high level |
| test_freq_sel2 | I       | GPIO6_B[7]    | TEST = high level |

For detailed information about Chip Test Solution, please refer to RK30xx Chip Test Solution.pdf.